# *Rockchip RK3308 Technical Reference Manual Part1*

Revision 1.1 Aug. 2018

| Date      | Revision | Description         |
|-----------|----------|---------------------|
| 2018-8-10 | 1.1      | Update some feature |
| 2018-5-20 | 1.0      | Initial Release     |

# **Revision History**

### **Table of Content**

| Table of Content                                                                 |     |
|----------------------------------------------------------------------------------|-----|
| Figure Index                                                                     |     |
| Table Index                                                                      |     |
| Warranty Disclaimer<br>Chapter 1 System Overview                                 |     |
| 1.1 Address Mapping                                                              |     |
| 1.2 System Boot                                                                  |     |
| 1.3 System Interrupt Connection                                                  |     |
| , , ,                                                                            |     |
| 1.4 System DMA Hardware Request Connection<br>Chapter 2 Clock & Reset Unit (CRU) |     |
| 2.1 Overview                                                                     |     |
| 2.2 Block Diagram                                                                |     |
|                                                                                  |     |
| 2.3 Function Description                                                         |     |
| 2.4 Register Description                                                         |     |
| 2.5 Application Notes                                                            |     |
| Chapter 3 Cortex-A35                                                             |     |
| 3.1 Overview                                                                     |     |
| 3.2 Block Diagram                                                                |     |
| 3.3 Function Description                                                         |     |
| Chapter 4 AXI PERF                                                               |     |
| 4.1 Overview                                                                     |     |
| 4.2 Block Diagram                                                                |     |
| 4.3 Register Description of CPU_AXI_PERF                                         |     |
| 4.4 Application Notes                                                            |     |
| Chapter 5 CPU_BOOST                                                              |     |
| 5.1 Overview                                                                     |     |
| 5.2 Block Diagram                                                                |     |
| 5.3 Register Description                                                         |     |
| 5.4 Application Notes                                                            |     |
| Chapter 6 Audio Subsystem                                                        |     |
| 6.1 Overview                                                                     | 122 |
| 6.2 Block Diagram                                                                | 122 |
| 6.3 Function Description                                                         | 122 |
| 6.4 Register Description                                                         | 130 |
| 6.5 Application Notes                                                            | 130 |
| Chapter 7 Audio Serial Port Controller (ASPC)                                    |     |
| 7.1 Overview                                                                     | 131 |
| 7.2 Block Diagram                                                                | 131 |
| 7.3 Function Description                                                         | 132 |
| 7.4 Register Description                                                         | 134 |
| 7.5 Interface Description                                                        |     |
| 7.6 Application Notes                                                            |     |
| Chapter 8 Audio Codec                                                            |     |
| 8.1 Overview                                                                     |     |
| 8.2 Block Diagram                                                                |     |
| 8.3 Function description                                                         |     |
| 8.4 Register Description                                                         |     |
|                                                                                  |     |

| 8.5 Interface Description                     |     |
|-----------------------------------------------|-----|
| 8.6 Application Note                          | 179 |
| Chapter 9 DMA Controller (DMAC)               |     |
| 9.1 Overview                                  |     |
| 9.2 Block Diagram                             |     |
| 9.3 Function Description                      |     |
| 9.4 Register Description                      |     |
| 9.5 Timing Diagram                            | 244 |
| 9.6 Interface Description                     | 244 |
| 9.7 Application Notes                         | 245 |
| Chapter 10 Generic Interrupt Controller (GIC) |     |
| 10.1 Overview                                 |     |
| 10.2 Block Diagram                            | 251 |
| 10.3 Function Description                     |     |
| Chapter 11 Power Management Unit (PMU)        |     |
| 11.1 Overview                                 | 252 |
| 11.2 Block Diagram                            | 252 |
| 11.3 Function Description                     | 253 |
| 11.4 Register Description                     |     |
| 11.5 Timing Diagram                           |     |
| 11.6 Application Note                         |     |
| Chapter 12 NAND Flash Controller (NANDC)      |     |
| 12.1 Overview                                 |     |
| 12.2 Block Diagram                            |     |
| 12.3 Function Description                     |     |
| 12.4 Register Description                     |     |
| 12.5 Interface Description                    |     |
| 12.6 Application Notes                        |     |
| Chapter 13 Embedded SRAM                      |     |
| 13.1 Overview                                 |     |
| 13.2 Block Diagram                            |     |
| 13.3 Function Description                     |     |
| Chapter 14 System Debug                       |     |
| 14.1 Overview                                 |     |
| 14.2 Block Diagram                            |     |
| 14.3 Function Description                     |     |
| 14.4 Register Description                     |     |
| 14.5 Interface Description                    |     |
| Chapter 15 UART                               |     |
| 15.1 Overview                                 |     |
| 15.2 Block Diagram                            |     |
| 15.3 Function Description                     |     |
| 15.4 Register Description                     |     |
| 15.5 Interface Description                    |     |
| 15.6 Application Notes                        |     |
| Chapter 16 Pulse Width Modulation (PWM)       |     |
| 16.1 Overview                                 |     |
| 16.2 Block Diagram                            |     |
| 5                                             |     |

| 16.3 Function Description                                                                                                                                                                                                                                                                                                                                             | 334                                                                                                                                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16.4 Register Description                                                                                                                                                                                                                                                                                                                                             | 335                                                                                                                                                           |
| Chapter 17 I2C Interface                                                                                                                                                                                                                                                                                                                                              | 356                                                                                                                                                           |
| 17.1 Overview                                                                                                                                                                                                                                                                                                                                                         | 356                                                                                                                                                           |
| 17.2 Block Diagram                                                                                                                                                                                                                                                                                                                                                    | 356                                                                                                                                                           |
| 17.3 Function Description                                                                                                                                                                                                                                                                                                                                             | 356                                                                                                                                                           |
| 17.5 Interface Description                                                                                                                                                                                                                                                                                                                                            | 368                                                                                                                                                           |
| 17.6 Application Notes                                                                                                                                                                                                                                                                                                                                                | 369                                                                                                                                                           |
| Chapter 18 I2S 2-channel                                                                                                                                                                                                                                                                                                                                              | 373                                                                                                                                                           |
| 18.1 Overview                                                                                                                                                                                                                                                                                                                                                         | 373                                                                                                                                                           |
| 18.2 Block Diagram                                                                                                                                                                                                                                                                                                                                                    | 373                                                                                                                                                           |
| 18.3 Function description                                                                                                                                                                                                                                                                                                                                             | 374                                                                                                                                                           |
| 18.4 Register Description                                                                                                                                                                                                                                                                                                                                             | 376                                                                                                                                                           |
| 18.5 Interface Description                                                                                                                                                                                                                                                                                                                                            | 386                                                                                                                                                           |
| 18.6 Application Notes                                                                                                                                                                                                                                                                                                                                                | 386                                                                                                                                                           |
| Chapter 19 I2S 8-channel                                                                                                                                                                                                                                                                                                                                              | 390                                                                                                                                                           |
| 19.5 Interface Description                                                                                                                                                                                                                                                                                                                                            | 412                                                                                                                                                           |
| Chapter 20 Serial Peripheral Interface (SPI)                                                                                                                                                                                                                                                                                                                          | 418                                                                                                                                                           |
| 20.1 Overview                                                                                                                                                                                                                                                                                                                                                         | 418                                                                                                                                                           |
| 20.2 Block Diagram                                                                                                                                                                                                                                                                                                                                                    | 418                                                                                                                                                           |
| 20.3 Function Description                                                                                                                                                                                                                                                                                                                                             | 419                                                                                                                                                           |
| 20.4 Register Description                                                                                                                                                                                                                                                                                                                                             | 421                                                                                                                                                           |
| 20.5 Interface Description                                                                                                                                                                                                                                                                                                                                            | 429                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                       | 130                                                                                                                                                           |
| 20.6 Application Notes                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                               |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                       | 433                                                                                                                                                           |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433                                                                                                                                                    |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433                                                                                                                                             |
| Chapter 21 Serial Flash Controller (SFC)<br>21.1 Overview<br>21.2 Block Diagram                                                                                                                                                                                                                                                                                       | 433<br>433<br>433<br>433                                                                                                                                      |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>433<br>442                                                                                                                               |
| Chapter 21 Serial Flash Controller (SFC)<br>21.1 Overview<br>21.2 Block Diagram<br>21.3 Function Description                                                                                                                                                                                                                                                          | 433<br>433<br>433<br>433<br>442<br>443                                                                                                                        |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>433<br>442<br>442<br>443<br>446                                                                                                          |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>433<br>442<br>443<br>446<br>446                                                                                                          |
| Chapter 21 Serial Flash Controller (SFC)<br>21.1 Overview.<br>21.2 Block Diagram<br>21.3 Function Description<br>21.5 Interface Description<br>21.6 Application Notes<br>Chapter 22 GPIO.<br>22.1 Overview.                                                                                                                                                           | 433<br>433<br>433<br>442<br>442<br>443<br>446<br>446<br>446                                                                                                   |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>442<br>442<br>443<br>446<br>446<br>446<br>446                                                                                            |
| Chapter 21 Serial Flash Controller (SFC)<br>21.1 Overview.<br>21.2 Block Diagram<br>21.3 Function Description<br>21.5 Interface Description<br>21.6 Application Notes<br>Chapter 22 GPIO<br>22.1 Overview.<br>22.2 Block Diagram<br>22.3 Function Description                                                                                                         | 433<br>433<br>433<br>442<br>442<br>443<br>446<br>446<br>446<br>446<br>448                                                                                     |
| Chapter 21 Serial Flash Controller (SFC)<br>21.1 Overview.<br>21.2 Block Diagram<br>21.3 Function Description<br>21.5 Interface Description<br>21.6 Application Notes<br>Chapter 22 GPIO<br>22.1 Overview.<br>22.2 Block Diagram<br>22.3 Function Description<br>22.4 Register Description.                                                                           | 433<br>433<br>433<br>442<br>442<br>443<br>446<br>446<br>446<br>446<br>448<br>451                                                                              |
| Chapter 21 Serial Flash Controller (SFC)<br>21.1 Overview.<br>21.2 Block Diagram<br>21.3 Function Description<br>21.5 Interface Description<br>21.6 Application Notes<br>Chapter 22 GPIO<br>22.1 Overview.<br>22.2 Block Diagram<br>22.3 Function Description<br>22.4 Register Description<br>22.5 Interface Description                                              | 433<br>433<br>433<br>442<br>442<br>443<br>446<br>446<br>446<br>446<br>448<br>451<br>452                                                                       |
| Chapter 21 Serial Flash Controller (SFC)<br>21.1 Overview.<br>21.2 Block Diagram .<br>21.3 Function Description .<br>21.5 Interface Description .<br>21.6 Application Notes .<br>Chapter 22 GPIO.<br>22.1 Overview.<br>22.2 Block Diagram .<br>22.3 Function Description .<br>22.4 Register Description .<br>22.5 Interface Description .<br>22.6 Application Notes . | 433<br>433<br>433<br>442<br>442<br>443<br>446<br>446<br>446<br>446<br>446<br>451<br>452<br>453                                                                |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>442<br>442<br>442<br>446<br>446<br>446<br>446<br>446<br>448<br>451<br>452<br>453<br>453                                                  |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>442<br>442<br>443<br>446<br>446<br>446<br>446<br>446<br>451<br>451<br>453<br>453<br>454                                                  |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>442<br>442<br>442<br>446<br>446<br>446<br>446<br>446<br>451<br>451<br>453<br>453<br>454<br>454                                           |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>442<br>442<br>443<br>446<br>446<br>446<br>446<br>446<br>451<br>451<br>453<br>453<br>454<br>454<br>459                                    |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>442<br>442<br>442<br>446<br>446<br>446<br>446<br>446<br>451<br>451<br>453<br>453<br>454<br>454<br>459<br>513                             |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>442<br>442<br>443<br>446<br>446<br>446<br>446<br>451<br>451<br>452<br>453<br>453<br>454<br>459<br>459<br>513                             |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>442<br>442<br>443<br>446<br>446<br>446<br>446<br>446<br>451<br>451<br>453<br>453<br>454<br>454<br>459<br>513<br>513<br>526               |
| Chapter 21 Serial Flash Controller (SFC)                                                                                                                                                                                                                                                                                                                              | 433<br>433<br>433<br>442<br>443<br>446<br>446<br>446<br>446<br>446<br>446<br>451<br>451<br>452<br>453<br>453<br>454<br>454<br>459<br>513<br>513<br>526<br>526 |

| 24.4 Register Description                 | 527 |
|-------------------------------------------|-----|
| 24.5 Application Notes                    | 529 |
| Chapter 25 SAR-ADC                        | 531 |
| 25.1 Overview                             | 531 |
| 25.2 Block Diagram                        | 531 |
| 25.3 Function Description                 | 531 |
| 25.4 Register description                 | 531 |
| 25.5 Timing Diagram                       | 533 |
| 25.6 Application Notes                    | 534 |
| Chapter 26 Temperature-Sensor ADC(TS-ADC) | 535 |
| 26.1 Overview                             | 535 |
| 26.2 Block Diagram                        | 535 |
| 26.3 Function Description                 | 535 |
| 26.5 Application Notes                    | 543 |
| Chapter 27 Timer                          | 546 |
| 27.1 Overview                             | 546 |
| 27.2 Block Diagram                        | 546 |
| 27.3 Function Description                 | 546 |
| 27.4 Register Description                 | 547 |
| 27.5 Application Notes                    | 549 |
| Chapter 28 SPDIF Transmitter              | 550 |
| 28.1 Overview                             | 550 |
| 28.2 Block Diagram                        | 550 |
| 28.3 Function description                 | 551 |
| 28.4 Register Description                 | 553 |
| 28.5 Interface Description                | 560 |
| 28.6 Application Notes                    | 560 |
| Chapter 29 SPDIF Receiver                 | 562 |
| 29.1 Overview                             | 562 |
| 29.2 Block Diagram                        | 562 |
| 29.3 Function description                 | 563 |
| 29.4 Register Description                 | 565 |
| 29.5 Interface Description                | 572 |
| 29.6 Application Notes                    | 572 |
| Chapter 30 General Register Files (GRF)   |     |
| 30.1 Overview                             | 574 |
| 30.2 Block Diagram                        |     |
| 30.3 Function Description                 | 574 |
| 30.4 Register Description                 | 574 |
| 30.5 Interface Description                | 705 |
| 30.6 Application Notes                    | 705 |

# **Figure Index**

| Fig. | 1-1 RK3308 boot procedure flow                        | 15  |
|------|-------------------------------------------------------|-----|
| Fig. | 2-1 CRU Block Diagram                                 | 21  |
| Fig. | 2-2 PLL Block Diagram                                 | 22  |
| Fig. | 2-3 Reset Architecture Diagram                        | 22  |
|      | 2-4 Clock Architecture Diagram                        |     |
|      | 2-5 PLL setting change timing                         |     |
|      | 3-1 Block Diagram                                     |     |
|      | 4-1 AXI_PERF block diagram                            |     |
|      | 5-1 CPU_BOOST block diagram                           |     |
|      | 6-1 I2S_2CH_0 application topology                    |     |
|      | 6-2 I2S_8CH_1 application topology                    |     |
|      | 6-3 I2S_8CH_0 application topology                    |     |
|      | 6-4 I2S_8CH_1 application topology                    |     |
|      | 6-5 I2S_16CH application topology                     |     |
|      | 6-6 I2S_8CH_2 application topology                    |     |
|      | 6-7 I2S_8CH_3 application topology                    |     |
|      | 6-8 I2S_2CH_3 application topology                    |     |
|      | 6-9 I2S_8CH_0 DMA request and acknowledge             |     |
|      | 7-1 ASPC Block Diagram                                |     |
|      | 7-2 ASPC with Eight Mono MIC                          |     |
|      | 7-3 ASPC with Four Stereo MIC                         |     |
| Fig. | 7-4 ASPC interface diagram with external MIC          | 122 |
|      | 7-5 ASPC Clock Structure                              |     |
|      |                                                       |     |
|      | 7-6 ASPC operation flow                               |     |
|      | 8-1 Audio Codec overview                              |     |
|      | 8-2 Left Justified Mode (assuming n-bit word length)  |     |
|      | 8-3 Right Justified Mode (assuming n-bit word length) |     |
|      | 8-4 I2S Mode (assuming n-bit word length)             |     |
|      | 8-5 DSP/PCM Mode A (assuming n-bit word length)       |     |
|      | 8-6 DSP/PCM Mode B (assuming n-bit word length)       |     |
|      | 8-7 Microphone Input                                  |     |
|      | 8-8 Input DC-blocking capacitor                       |     |
|      | 8-9 Input single-ended DC-blocking capacitor          |     |
|      | 8-10 Output DC-blocking capacitor                     |     |
|      | 8-11 ADC Channels Relationship                        |     |
|      | 8-12 DAC Channels Relationship                        |     |
|      | 9-1 Block diagram of DMAC                             |     |
|      | 9-2 DMAC operation states                             |     |
| Fig. | 9-3 DMAC request and acknowledge timing               | 244 |
|      | 10-1 Block Diagram                                    |     |
|      | 11-1 RK3308 Power Domain Partition                    |     |
| Fig. | 11-2 PMU Block Diagram                                | 253 |
| Fig. | 11-3 Each Domain Power Switch Timing                  | 275 |
| Fig. | 11-4 External Wakeup Source PAD Timing                | 275 |
|      | 11-5 PMU Info TX Timing                               |     |
|      | 11-6 PMU Control Register Relationship                |     |
|      | 12-1 NANDC Block Diagram                              |     |
|      | 12-2 NANDC Address Assignment                         |     |
|      | 12-3 NANDC Data Format                                |     |
|      | 12-4 FIFO Data Format                                 |     |
|      | 13-1 Embedded SRAM block diagram                      |     |
|      | 14-1 Debug system structure                           |     |
|      | 14-2 DAP SWJ interface                                |     |
|      | 14-3 SW-DP acknowledgement timing                     |     |
| _    | 15-1UART Block Diagram                                |     |
| 9.   |                                                       | 200 |

| Fia  | 15-2UART Serial protocol                                                                                    | 309 |
|------|-------------------------------------------------------------------------------------------------------------|-----|
|      | 15-3IrDA 1.0                                                                                                |     |
|      | 15-4 UART baud rate                                                                                         |     |
|      | 15-5 UART Auto flow control block diagram                                                                   |     |
|      | 15-6 UART AUTO RTS TIMING                                                                                   |     |
|      | 15-7 UART AUTO CTS TIMING                                                                                   |     |
|      | 15-8 UART none fifo mode                                                                                    |     |
|      | 15-9 UART Serial protocol                                                                                   |     |
|      | 15-10 UART clock generation                                                                                 |     |
|      | 16-1 PWM Block Diagram                                                                                      |     |
|      | 16-2 PWM Capture Mode                                                                                       |     |
|      | 16-3 PWM Continuous Left-aligned Output Mode                                                                |     |
|      | 16-4 PWM Continuous Center-aligned Output Mode                                                              |     |
|      | 16-5 PWM One-shot Center-aligned Output Mode                                                                |     |
|      | 17-1 I2C architecture                                                                                       |     |
|      | 17-1 I2C architecture                                                                                       |     |
|      | 17-3 I2C Start and stop conditions                                                                          |     |
|      | 17-3 I2C Start and stop conditions                                                                          |     |
|      | 17-4 I2C Acknowledge                                                                                        |     |
|      | 17-5 I2C byte transfer                                                                                      |     |
| Fig. | 17-7 I2C Flow chat for receive only mode                                                                    | 270 |
|      | 17-7 I2C Flow chat for mix mode                                                                             |     |
|      |                                                                                                             |     |
| Fig. | 18-1 I2S/PCM controller (2 channel) Block Diagram<br>18-2 I2S transmitter-master & receiver-slave condition | 2/2 |
|      | 18-3 I2S transmitter-slave & receiver-master condition                                                      |     |
| FIG. | 18-4 I2S normal mode timing format                                                                          | 374 |
|      |                                                                                                             |     |
|      | 18-5 I2S left justified mode timing format                                                                  |     |
|      | 18-6 I2S right justified mode timing format                                                                 |     |
|      | 18-7 PCM early mode timing format                                                                           |     |
|      | 18-8 PCM late1 mode timing format                                                                           |     |
|      | 18-9 PCM late2 mode timing format                                                                           |     |
|      | 18-10 PCM late3 mode timing format                                                                          |     |
|      | 18-11 I2S/PCM controller transmit operation flow chart                                                      |     |
|      | 18-12 I2S/PCM controller receive operation flow chart                                                       |     |
|      | 18-13 I2S/PCM normal mode                                                                                   |     |
|      | 18-14 I2S/PCM TX common mode                                                                                |     |
|      | 18-15 I2S/PCM RX common mode                                                                                |     |
|      | 19-1 I2S/PCM/TDM controller (8 channel) Block Diagram                                                       |     |
|      | 19-2 I2S transmitter-master & receiver-slave condition                                                      |     |
|      | 19-3 I2S transmitter-slave & receiver-master condition                                                      |     |
|      | 19-4 I2S normal mode timing format                                                                          |     |
|      | 19-5 I2S left justified mode timing format                                                                  |     |
|      | 19-6 I2S right justified mode timing format                                                                 |     |
|      | 19-7 PCM early mode timing format                                                                           |     |
|      | 19-8 PCM late1 mode timing format                                                                           |     |
|      | 19-9 PCM late2 mode timing format                                                                           |     |
|      | 19-10 PCM late3 mode timing format                                                                          |     |
|      | 19-11 I2S/PCM/TDM controller transmit operation flow chart                                                  |     |
|      | 19-12 I2S/PCM/TDM controller receive operation flow chart                                                   |     |
|      | 19-13 I2S/PCM normal mode                                                                                   |     |
|      | 19-14 I2S/PCM TX common mode                                                                                |     |
|      | 19-15 I2S/PCM RX common mode                                                                                |     |
|      | 20-1 SPI Controller Block diagram                                                                           |     |
|      | 20-2 SPI Master and Slave Interconnection                                                                   |     |
| -    | 20-3 SPI Format (SCPH=0 SCPOL=0)                                                                            |     |
|      | 20-4 SPI Format (SCPH=0 SCPOL=1)                                                                            |     |
| Fig. | 20-5 SPI Format (SCPH=1 SCPOL=0)                                                                            | 421 |

| Fig. 20-6 SPI Format (SCPH=1 SCPOL=1)                             |     |
|-------------------------------------------------------------------|-----|
| Fig. 20-7 SPI Master transfer flow diagram                        |     |
| Fig. 20-8 SPI Slave transfer flow diagram                         |     |
| Fig. 21-1 SFC Architecture                                        |     |
| Fig. 21-2 idle cycles                                             |     |
| Fig. 21-3 SPI mode                                                |     |
| Fig. 21-4 slave mode write                                        |     |
| Fig. 21-5 slave mode read                                         |     |
| Fig. 21-6 master mode flow                                        |     |
| Fig. 21-7 SPI mode                                                |     |
| Fig. 22-1GPIO block diagram                                       |     |
| Fig. 22-2 GPIO Interrupt RTL Block Diagram                        |     |
| Fig. 23-1 Wake-Up Frame Filter Register                           |     |
| Fig. 24-1 WDT block diagram                                       |     |
| Fig. 24-2 WDT Operation Flow                                      | 530 |
| Fig. 25-1 RK3308 SAR-ADC block diagram                            |     |
| Fig. 25-2 SAR-ADC timing diagram in single-sample conversion mode | 533 |
| Fig. 26-1 TS-ADC Controller Block Diagram                         |     |
| Fig. 26-2 the start flow to enable the sensor and adc             |     |
| Fig. 27-1 Timer Block Diagram                                     |     |
| Fig. 27-2 Timer Usage Flow                                        |     |
| Fig. 27-3 Timing between timer_en and timer_clk                   |     |
| Fig. 28-1 SPDIF transmitter Block Diagram                         |     |
| Fig. 28-2 SPDIF Frame Format                                      |     |
| Fig. 28-3 SPDIF Sub-frame Format                                  |     |
| Fig. 28-4 SPDIF Channel Coding                                    | 552 |
| Fig. 28-5 SPDIF Preamble                                          |     |
| Fig. 28-6 SPDIF transmitter operation flow chart                  |     |
| Fig. 29-1 SPDIF receiver Block Diagram                            |     |
| Fig. 29-2 SPDIF Frame Format                                      |     |
| Fig. 29-3 SPDIF Sub-frame Format                                  |     |
| Fig. 29-4 SPDIF Channel Coding                                    |     |
| Fig. 29-5 SPDIF Preamble                                          |     |
| Fig. 29-6 SPDIF receiver operation flow chart                     | 573 |

### **Table Index**

| Table 1-1 RK3308 Address Mapping                          | 12  |
|-----------------------------------------------------------|-----|
| Table 1-2 RK3308 remap function                           |     |
| Table 1-3 RK3308 Interrupt connection list                | 16  |
| Table 1-4 RK3308 DMACO hardware request connection list   | 19  |
| Table 1-5 RK3308 DMAC1 hardware request connection list   | 19  |
| Table 2-1 Source Clock Limitation of Fractional Divider   | 108 |
| Table 2-2 Clock Limitation of reset                       | 109 |
| Table 3-1 CPU Configuration                               |     |
| Table 7-1 Relation between ASP_CLK and sample rate        | 134 |
| Table 7-2 ASPC Interface Description                      | 142 |
| Table 8-1 Supported Data Formats in Different Modes       | 145 |
| Table 9-1 DMAC0 Request Mapping Table                     |     |
| Table 9-2 DMAC1 Request Mapping Table                     | 186 |
| Table 9-3 DMAC0 boot interface                            | 244 |
| Table 9-4 DMAC1 boot interface                            | 244 |
| Table 9-5 Source size in CCRn                             | 249 |
| Table 9-6 DMAC Instruction sets                           | 249 |
| Table 9-7 DMAC instruction encoding                       | 250 |
| Table 10-1 CPU interface connectivity                     |     |
| Table 11-1 RK3308 Power Domain and Voltage Domain Summary |     |
| Table 11-2 Low Power State                                |     |
| Table 11-3 Debug IO MUX                                   | 276 |
| Table 12-1 NANDC Address Mapping                          |     |
| Table 12-2 NANDC Interface Description                    |     |
| Table 12-3 NANDC Interface Connection                     |     |
| Table 14-1 Debug Address Mapping Table         Table 14-1 | 305 |
| Table 14-2 SW-DP Interface Description                    |     |
| Table 15-1 UART Interface Description                     |     |
| Table 15-2 UART baud rate configuration                   |     |
| Table 15-3 UART baud rate configuration                   |     |
| Table 15-4 UART dma_req enable configuration              |     |
| Table 16-1 PWM Interface Description                      |     |
| Table 17-112C Interface Description                       |     |
| Table 18-1 I2S02CH Interface Description                  |     |
| Table 18-2 I2S12CH Interface Description                  |     |
| Table 19-1 I2S Interface Description                      |     |
| Table 20-1 1SPI interface description                     |     |
| Table 21-11SFC interface description                      |     |
| Table 22-1 GPIO interface description                     |     |
| Table 23-1 RMII Interface Description                     |     |
| Table 27-1 Timer Internal Address Mapping Table           |     |
| Table 28-1 spdif transmitter interface                    |     |
| Table 29-1 SPDIF receiver interface                       |     |
| Table 30-1 GRF Address Mapping Table                      |     |
|                                                           |     |

### **Warranty Disclaimer**

Rockchip Electronics Co., Ltd makes no warranty, representation or guarantee (expressed, implied, statutory, or otherwise) by or with respect to anything in this document, and shall not be liable for any implied warranties of non-infringement, merchantability or fitness for a particular purpose or for any indirect, special or consequential damages.

Information furnished is believed to be accurate and reliable. However, Rockchip Electronics Co.,Ltd assumes no responsibility for the consequences of use of such information or for any infringement of patents or other rights of third parties that may result from its use.

Rockchip Electronics Co., Ltd's products are not designed, intended, or authorized for using as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Rockchip Electronics Co., Ltd's product could create a situation where personal injury or death may occur, should buyer purchase or use Rockchip Electronics Co., Ltd's products for any such unintended or unauthorized application, buyers shall indemnify and hold Rockchip Electronics Co., Ltd and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, expenses, and reasonable attorney fees arising out of, either directly or indirectly, any claim of personal injury or death that may be associated with such unintended or unauthorized use, even if such claim alleges that Rockchip Electronics Co., Ltd was negligent regarding the design or manufacture of the part.

#### **Copyright and Patent Right**

Information in this document is provided solely to enable system and software implementers to use Rockchip Electronics Co.,Ltd 's products. There are no expressed and patent or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document.

## Rockchip Electronics Co., Ltd does not convey any license under its copyright and patent rights nor the rights of others.

All copyright and patent rights referenced in this document belong to their respective owners and shall be subject to corresponding copyright and patent licensing requirements.

#### Trademarks

Rockchip and Rockchip<sup>™</sup> logo and the name of Rockchip Electronics Co., Ltd's products are trademarks of Rockchip Electronics Co., Ltd. and are exclusively owned by Rockchip Electronics Co., Ltd. References to other companies and their products use trademarks owned by the respective companies and are for reference purpose only.

#### Confidentiality

The information contained herein (including any attachments) is confidential. The recipient hereby acknowledges the confidentiality of this document, and except for the specific purpose, this document shall not be disclosed to any third party.

#### Reverse engineering or disassembly is prohibited.

ROCKCHIP ELECTRONICS CO.,LTD. RESERVES THE RIGHT TO MAKE CHANGES IN ITS PRODUCTS OR PRODUCT SPECIFICATIONS WITH THE INTENT TO IMPROVE FUNCTION OR DESIGN AT ANY TIME AND WITHOUT NOTICE AND IS NOT REQUIRED TO UNDATE THIS DOCUMENTATION TO REFLECT SUCH CHANGES.

#### **Copyright © 2018 Rockchip Electronics Co., Ltd.**

All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, electric or mechanical, by photocopying, recording, or otherwise, without the prior written consent of Rockchip Electronics Co., Ltd.

### **Chapter 1 System Overview**

### **1.1 Address Mapping**

RK3308 boot from internal BootROM, which supports remap function by software programming. Remap is controlled by SGRF\_SOC\_CON0[8]. When remap is set to 1, the BootROM is un-accessible and System SRAM is mapped to address 0xfff0000.

| Table 1-1 RK3308 Address Mapping |                |          |              |          |                               |  |
|----------------------------------|----------------|----------|--------------|----------|-------------------------------|--|
| Addr                             | IP             | Addr     | IP           | Addr     | IP                            |  |
| ff210000                         | No Secure OTPC | ff3d0000 | Reserved     | ffff0000 | BootROM(32K)/System SRAM(64K) |  |
|                                  | 64K            | 11546666 | 192K         |          | 64K                           |  |
| ff200000                         | Reserved       | ff3c0000 | VAD          | fffc0000 | Reserved                      |  |
| 11200000                         | 64K            | 11500000 | 64K          | meeeee   | 192K                          |  |
| ff1f0000                         | TSADC CTL      | ff3c0000 | VAD          | fff80000 | System SRAM(256K)             |  |
|                                  | 64K            |          | 64K          |          | 256K                          |  |
| ff1e0000                         | SARADC CTL     | ff3b0000 | SPDIF_8CH_RX | ff840000 | Reserved                      |  |
|                                  | 64K            |          | 64K          |          | 7.25M                         |  |
| ff1c0000                         | Reserved       | ff3a0000 | SPDIF_8CH_TX | ff800000 | A35 DEBUG                     |  |
|                                  | 128K           |          | 64K          |          | 256K                          |  |
| ff1b0000                         | TIMER_6CH_1    | ff390000 | Reserved     | ff600000 | Reserved                      |  |
|                                  | 64K            |          | 64K          |          | 2M                            |  |
| ff1a0000                         | TIMER_6CH_0    | ff380000 | PDM_8CH      | ff5f0000 | DDR FireWall                  |  |
|                                  | 64K            |          | 64K          |          | 64K                           |  |
| ff190000                         | Reserved       | ff370000 | Reserved     | ff5c0000 | Interconnect Service          |  |
|                                  | 64K            |          | 64K          |          | 192K                          |  |
| ff180000                         | PWM_4CH        | ff360000 | I2S_2CH_1    | ff590000 | Reserved                      |  |
|                                  | 64K            |          | 64K          |          | 192K                          |  |
| ff150000                         | Reserved       | ff350000 | I2S_2CH_0    | ff580000 | GIC                           |  |
|                                  | 192K           |          | 64K          |          | 64K                           |  |
| ff140000                         | SPI2           | ff340000 | Reserved     | ff570000 | Reserved                      |  |
|                                  | 64K            |          | 64K          |          | 64K                           |  |
| ff130000                         | SPI1           | ff330000 | I2S_8CH_3    | ff560000 | Audio Codec PHY               |  |
|                                  | 64K            |          | 64K          |          | 64K                           |  |
| ff120000                         | SPI0           | ff320000 | I2S_8CH_2    | ff550000 | CPU BOOST                     |  |
|                                  | 64K            |          | 64K          |          | 64K                           |  |
| ff0f0000                         | Reserved       | ff310000 | I2S_8CH_1    | ff540000 | OTP Masker                    |  |
|                                  | 192K           |          | 64K          |          | 64K                           |  |
| ff0e0000                         | UART4          | ff300000 | I2S_8CH_0    | ff530000 | DDR PHY                       |  |
|                                  | 64K            |          | 64K          |          | 64K                           |  |
| ff0d0000                         | UART3          | ff2f0000 | CRYPTO       | ff520000 | PMU                           |  |
|                                  | 64K            | 11210000 | 64K          |          | 64K                           |  |
| ff0c0000                         | UART2          | ff2e0000 | VOP          | ff510000 | Reserved                      |  |
|                                  | 64K            |          | 64K          |          | 64K                           |  |
| ff0b0000                         | UART1          | ff2d0000 | DMAC1        | ff500000 | CRU                           |  |
|                                  | 64K            | 00000    | 64K          |          | 64K                           |  |

| Addr     | IP          | Addr            | IP           | Addr      | IP               |
|----------|-------------|-----------------|--------------|-----------|------------------|
| ff0=0000 | UART0       | ff2=0000        | DMAC0        | ££4£0.000 | Reserved         |
| ff0a0000 | 64K         | ff2c0000        | 64K          | ff4f0000  | 64K              |
| ff090000 | Reserved    | ff2b0000        | SGRF         | ff4e0000  | MAC              |
| 11090000 | 64K         | 11200000        | 64K          | 1140000   | 64K              |
| ff080000 | WDT         | ff2a8000        | Secure OTPC  | ((4))0000 | Reserved         |
| 11080000 | 64K         | 11280000        | 32K          | ff4d0000  | 64K              |
| ff070000 | I2C3        | ff2a0000        | KEY Reader   | ff4c0000  | SFC              |
| 11070000 | 64K         | 11280000        | 32K          | 1140000   | 64K              |
| ff060000 | I2C2        | ff290000        | Secure DMAC1 | ff4b0000  | NANDC            |
| 11000000 | 64K         | 11290000        | 64K          | 11400000  | 64K              |
| ff050000 | I2C1        | ff280000        | Secure DMAC0 | ff4a0000  | SDIO             |
| 11050000 | 64K         |                 | 64K          |           | 64K              |
| ff040000 | I2C0        | ff270000        | Reserved     | ff490000  | EMMC             |
| 11040000 | 64K         | 11270000        | 64K          | 11490000  | 64K              |
| ff030000 | DDR STANDBY | ff260000        | GPIO4        | ff480000  | SD/MMC           |
| 11030000 | 64K         | 11200000        | 64K          | 11480000  | 64K              |
| ff020000 | DFI MONITOR | ff250000        | GPIO3        | ff460000  | Reserved         |
| 11020000 | 64K         | 11230000        | 64K          | 11400000  | 128K             |
| ff010000 | DDR UPCTL   | ff240000        | GPIO2        | ff450000  | USB2.0 HOST OHCI |
| 1010000  | 64K         |                 | 64K          |           | 64K              |
| ff000000 | GRF         | <i>#</i> 220000 | GPIO1        | ff440000  | USB2.0 HOST EHCI |
| 100000   | 64K         | ff230000        | 64K          | 11440000  | 64K              |
| 00000000 | DDR         | ff220000        | GPIO0        | ff400000  | USB2.0 OTG       |
| 0000000  | 4080M       | 11220000        | 64K          | 11400000  | 256K             |

The following table shows the BootROM /System SRAM address before and after remapping. Before remapping, 0xfff80000 and 0xffff0000 is the base address for System SRAM and BootROM separately. After remapping, BootROM could not be accessed, both 0xfff80000 and 0xffff0000 are the base address for System SRAM and only 64KB System SRAM space could be accessed from 0xffff0000 base address.

| Table 1-2 RK3308 | remap function |
|------------------|----------------|
|------------------|----------------|

|  | Before remap |                   |        | After remap  |                   |  |
|--|--------------|-------------------|--------|--------------|-------------------|--|
|  |              | System SRAM(256K) |        |              | System SRAM(256K) |  |
|  | fff80000     | 256K              | fff800 | 000/ffff0000 | 256K@fff80000     |  |
|  |              |                   |        |              | 64K@ffff0000      |  |
|  | ffff0000     | BootROM(32K)      | N/A    |              | BootROM(32K)      |  |
|  |              | 64K               | N/A    |              | N/A               |  |

### **1.2 System Boot**

RK3308 provides system boot from off-chip devices such as NAND Flash, eMMC memory, Serial NAND or NOR Flash, SDMMC card. When boot code is not ready in these devices, the boot code can be programmed through USB OTG interface by running ROM code in BootROM. All of the ROM code is hard code in internal BootROM. Below figure shows the procedure of ROM code execution.

The following features are supported by ROM code.

• Support system boot from the following device:

- Asynchronism NAND Flash, 8bit data width
- eMMC Interface, 8bits data width
- Serial NOR Flash, 1bit data width
- SDMMC Card, 4bits data width

• Support system code download by USB OTG

Following figure shows RK3308 boot procedure flow.



Fig. 1-1 RK3308 boot procedure flow

### **1.3 System Interrupt Connection**

RK3308 provides an General Interrupt Controller(GIC) for CPU, which has 89 SPI (shared peripheral interrupts) interrupt sources and 4 PPI (Private peripheral interrupt) interrupt sources and separately generates one nIRQ and one nFIQ to each CPU Core. The triggered level type for each SPI interrupt is high and for each PPI interrupt is low, both of them is Non-programmable. The detailed interrupt sources connection is shown below. For detailed GIC setting, please refer to GIC Chapter.

| Interrupt Type | Interrupt ID | Source          | Polarity   |
|----------------|--------------|-----------------|------------|
|                | 16           | Reserved        | Low level  |
|                | 17           | Reserved        | Low level  |
|                | 18           | Reserved        | Low level  |
|                | 19           | Reserved        | Low level  |
|                | 20           | Reserved        | Low level  |
|                | 21           | Reserved        | Low level  |
|                | 22           | Reserved        | Low level  |
| זחת            | 23           | Reserved        | Low level  |
| PPI            | 24           | Reserved        | Low level  |
|                | 25           | Reserved        | Low level  |
|                | 26           | nCNTHPIRQ       | Low level  |
|                | 27           | nCNTVIRQ        | Low level  |
|                | 28           | Reserved        | Low level  |
|                | 29           | nCNTPSIRQ       | Low level  |
|                | 30           | nCNTPNSIRQ      | Low level  |
|                | 31           | Reserved        | Low level  |
|                | 32           | DMAC0           | High level |
|                | 33           | DMAC0_IRQ_ABORT | High level |
|                | 34           | DMAC1           | High level |
|                | 35           | DMAC1_IRQ_ABORT | High level |
|                | 36           | Reserved        | High level |
|                | 37           | Reserved        | High level |
|                | 38           | Reserved        | High level |
|                | 39           | Reserved        | High level |
|                | 40           | DDR UPCTL       | High level |
|                | 41           | DFI MONITOR     | High level |
| SPI            | 42           | WDT             | High level |
|                | 43           | I2C0            | High level |
|                | 44           | I2C1            | High level |
|                | 45           | I2C2            | High level |
|                | 46           | I2C3            | High level |
|                | 47           | SPI0            | High level |
|                | 48           | SPI1            | High level |
|                | 49           | SPI2            | High level |
|                | 50           | UART0           | High level |
|                | 51           | UART1           | High level |
|                | 52           | UART2           | High level |

Table 1-3 RK3308 Interrupt connection list

| Interrupt Type | Interrupt ID | Source             | Polarity   |
|----------------|--------------|--------------------|------------|
|                | 53           | UART3              | High level |
|                | 54           | UART4              | High level |
|                | 55           | PWM_4CH            | High level |
|                | 56           | <br>PWM_4CH_PWR    | High level |
|                | 57           | <br>TIMER_6CH_0(0) | High level |
|                | 58           | TIMER_6CH_0(1)     | High level |
|                | 59           | TIMER_6CH_0(2)     | High level |
|                | 60           | TIMER_6CH_0(3)     | High level |
|                | 61           | TIMER_6CH_0(4)     | High level |
|                | 62           | TIMER_6CH_0(5)     | High level |
|                | 63           | TIMER_6CH_1(0)     | High level |
|                | 64           | TIMER_6CH_1(1)     | High level |
|                | 65           | TIMER_6CH_1(2)     | High level |
|                | 66           | TIMER_6CH_1(3)     | High level |
|                | 67           | TIMER_6CH_1(4)     | High level |
|                | 68           | TIMER_6CH_1(5)     | High level |
|                | 69           | SARADC CTL         | High level |
|                | 70           | TSADC CTL          | High level |
|                | 71           | Reserved           | High level |
|                | 72           | GPIO0              | High level |
|                | 73           | GPIO1              | High level |
|                | 74           | GPIO2              | High level |
|                | 75           | GPIO3              | High level |
|                | 76           | GPIO4              | High level |
|                | 77           | CRYPTO             | High level |
|                | 78           | VOP_INTR           | High level |
|                | 79           | Reserved           | High level |
|                | 80           | I2S_8CH_0          | High level |
|                | 81           | I2S_8CH_1          | High level |
|                | 82           | I2S_8CH_2          | High level |
|                | 83           | I2S_8CH_3          | High level |
|                | 84           | I2S_2CH_0          | High level |
|                | 85           | I2S_2CH_1          | High level |
|                | 86           | PDM_8CH            | High level |
|                | 87           | SPDIF_8CH_TX       | High level |
|                | 88           | SPDIF_8CH_RX       | High level |
|                | 89           | VAD                | High level |
|                | 90           | Reserved           | High level |
|                | 91           | Reserved           | High level |
|                | 92           | SECURE_OTPC        | High level |
|                | 93           | NO_SECURE_OTPC     | High level |
|                | 94           | KEY_READER         | High level |
|                | 95           | OTP_MASKER         | High level |
|                | 96           | MAC_INTR           | High level |

| Interrupt Type | Interrupt ID | Source                 | Polarity   |
|----------------|--------------|------------------------|------------|
|                | 97           | MAC INTR PMT           | High level |
|                | 98           | USB2.0 OTG             | High level |
|                | 99           | USB2.0 OTG BVALID      | High level |
|                | 100          | USB2.0 OTG ID          | High level |
|                | 101          | USB2.0 OTG LINESTATE   | High level |
|                | 102          | USB2.0 OTG DISCONNECT  | High level |
|                | 103          | USB2.0 HOST EHCI       | High level |
|                | 104          | USB2.0 HOST OHCI       | High level |
|                | 105          | USB2.0 HOST ARB        | High level |
|                | 106          | USB2.0 HOST LINESTATE  | High level |
|                | 107          | USB2.0 HOST DISCONNECT | High level |
|                | 108          | SD/MMC                 | High level |
|                | 109          | EMMC                   | High level |
|                | 110          | SDIO                   | High level |
|                | 111          | ~ SD/MMC DETECT PIN    | High level |
|                | 112          | SD/MMC DETECT          | High level |
|                | 113          | NANDC                  | High level |
|                | 114          | SFC                    | High level |
|                | 115          | ~nPMUIRQ[0]            | High level |
|                | 116          | ~nPMUIRQ[1]            | High level |
|                | 117          | ~nPMUIRQ[2]            | High level |
|                | 118          | ~nPMUIRQ[3]            | High level |
|                | 119          | Reserved               | High level |
|                | 120          | Reserved               | High level |
|                | 121          | Reserved               | High level |
|                | 122          | Reserved               | High level |
|                | 123          | ~nCOMMIRQ[0]           | High level |
|                | 124          | ~nCOMMIRQ[1]           | High level |
|                | 125          | ~nCOMMIRQ[2]           | High level |
|                | 126          | ~nCOMMIRQ[3]           | High level |
|                | 127          | ~nAXIERRIRQ            | High level |
|                | 128          | Reserved               | High level |
|                | 129          | Reserved               | High level |
|                | 130          | Reserved               | High level |
|                | 131          | Reserved               | High level |
|                | 132          | Reserved               | High level |
|                | 133          | Reserved               | High level |
|                | 134          | Reserved               | High level |
|                | 135          | Reserved               | High level |
|                | 136          | Reserved               | High level |
|                | 137          | Reserved               | High level |
|                | 138          | Reserved               | High level |
|                | 139          | Reserved               | High level |
|                | 140          | Reserved               | High level |

| Interrupt Type | Interrupt ID | Source        | Polarity   |
|----------------|--------------|---------------|------------|
|                | 141          | Reserved      | High level |
|                | 142          | CPU_SLV_ERROR | High level |
|                | 143          | PERF_INT_CA35 | High level |
|                | 144          | PMU           | High level |
|                | 145          | HWFFC_INTR    | High level |
|                | 146          | HPDET         | High level |
|                | 147          | Reserved      | High level |
|                | 148          | Reserved      | High level |

### **1.4 System DMA Hardware Request Connection**

RK3308 provides two DMAC in the system. The handshake channel number between peripheral and DMAC is described in this section. For detailed descriptions of DMAC, please refer to DMAC Chapter

| Req Number | Source   | Polarity   |
|------------|----------|------------|
| 0          | SPI0 tx  | High level |
| 1          | SPI0 rx  | High level |
| 2          | SPI1 tx  | High level |
| 3          | SPI1 rx  | High level |
| 4          | UART0 tx | High level |
| 5          | UART0 rx | High level |
| 6          | UART1 tx | High level |
| 7          | UART1 rx | High level |
| 8          | UART2 tx | High level |
| 9          | UART2 rx | High level |
| 10         | UART3 tx | High level |
| 11         | UART3 rx | High level |

Table 1-4 RK3308 DMAC0 hardware request connection list

Table 1-5 RK3308 DMAC1 hardware request connection list

| Req Number         | Source          | Polarity   |
|--------------------|-----------------|------------|
| 0                  | I2S_8CH_0 tx    | High level |
| 1                  | I2S_8CH_0 rx    | High level |
| 2                  | I2S_8CH_1 tx    | High level |
| 3                  | I2S_8CH_1 rx    | High level |
| 4                  | I2S_8CH_2 tx    | High level |
| 5                  | I2S_8CH_2 rx    | High level |
| 6                  | Reserved        | High level |
| 7                  | I2S_8CH_3 rx    | High level |
| 8                  | I2S_2CH_0 tx    | High level |
| 9                  | I2S_2CH_0 rx    | High level |
| 10                 | Reserved        | High level |
| 11                 | I2S_2CH_1 rx    | High level |
| 12                 | PDM_8CH rx      | High level |
| 13 SPDIF_8CH_TX tx |                 | High level |
| 14                 | SPDIF_8CH_RX rx | High level |

### RK3308 TRM-Part1

| Req Number | Source     | Polarity   |
|------------|------------|------------|
| 15         | PWM_4CH rx | High level |
| 16         | SPI2 tx    | High level |
| 17         | SPI2 rx    | High level |
| 18         | UART4 tx   | High level |
| 19         | UART4 rx   | High level |

### Chapter 2 Clock & Reset Unit (CRU)

### 2.1 Overview

The CRU is an APB slave module that is designed for generating all of the internal and system clocks, resets of chip. CRU generates system clocks from PLL output clock or external clock source, and generates system reset from external power-on-reset, watchdog timer reset or software reset or temperature sensor. CRU supports the following features:

- Compliance to the AMBA APB interface
- Embedded 4 PLLs
- Flexible selection of clock source
- Supports the respective divided clocks
- Supports the respective gating of all clocks
- Supports the respective software reset of all modules

### 2.2 Block Diagram

CRU comprises with:

- PLL
- Register configuration unit
- Clock generate unit
- Reset generate unit



Fig. 2-1 CRU Block Diagram

### 2.3 Function Description

### 2.3.1 PLL

There are 4 PLLs in the chip: ARM PLL, DDR PLL, VOICE PLL0 and VOICE PLL1.

PLL is a general purpose, high-performance PLL-based clock generator. The PLL is a multifunction, general purpose frequency synthesizer. Ultra-wide input and output ranges along with best-in-class jitter performance allow the PLL to be used for almost any clocking application. With excellent supply noise immunity, the PLL is ideal for use in noisy mixed signal SoC environments.

All PLL supports the following features:

- Input frequency range:1MHz to 800MHz (Integer Mode) and 10MHz to 800MHz (Fractional Mode)
- Output Frequency Range: 16MHz to 3.2GHz
- 24bit fractional accuracy, and fractional mode jitter performance to nearly match integer mode performance.
- 4:1 VCO frequency range allows PLL to be optimized for minimum jitter or minimum power.
- Isolated analog supply(1.8V) allows for excellent supply rejection in noisy SoC applications.
- Lock Detect Signal indicates when frequency lock has been achieved.
- PLL block diagram is in following figure.



Fig. 2-2 PLL Block Diagram

The REF(reference clock) of all PLL is xin\_osc0(24MHz crystal oscillator), and only the output clock FOUTPOSTDIV(PLL post divided output) is used in the SoC.

The setting(REFDIV, FBDIV, FRAC, POSTDIV1 and POSTDIV2) of all PLL are controlled by CRU registers. A submodule HWFFC (hardware fast frequency change) is designed for changing the APLL frequency with few software interactions. So the setting of APLL also can be controlled by hardware, and the actually setting can be read by some shadow registers when HWFFC mode is enabled.

For each PLL, a submodule SSMOD(Spread spectrum modulator) is designed to work with PLL to produce SSCG(spread spectrum clock generation). SSCG is used to reduce peak EMI. SSMODE can use internal or external wave table, and the external wave table are controlled by CRU registers.

### 2.3.2 Reset Generate Unit(RGU)

RGU generate the reset of all module in SoC. Almost all module have 6 reset source as the following figure shows. The 'xxx' in the figure is the module name.



Fig. 2-3 Reset Architecture Diagram

The reset source are:

- NPOR(Negative Power On Reset): hardware reset from IO.
- oc\_wdt\_rstn: reset from WDT IP in SoC.
- soc\_tsadc\_rstn: reset from TS-ADC IP in SoC.
- xxx\_softrstn\_req: software reset request by programming CRU register SOFTRST\_CONx. each bit of SOFTRST\_CONx is separated to different module.
- glb\_srstn\_1: global software first reset by programming CRU register

CRU\_GLB\_SRST\_FST as 0xfdb9

 glb\_srstn\_2: global software second reset by programming CRU register CRU\_GLB\_SRST\_SND as 0xeca8

The two global software resets will be self-cleared by hardware. glb\_srstn\_1 will reset the all logic, and glb\_srstn\_2 will reset the all logic except GRF, SGRF and all GPIOs.

#### 2.3.3 Clock Generate Unit(CGU)

CGU generate the clock of all modules in SoC. A full architecture with basic unit and clock source is as following figure. For each module clock, it may be part of full architecture base the requirement.



Fig. 2-4 Clock Architecture Diagram

The basic units are:

- Gating
- Selector
- Divfree(Glitch free divider)
  - clk\_out\_freq=clk\_in\_freq/divisor
  - When divisor is even, the clock duty cycle of clk\_out is 50%
  - When divisor is odd, the clock duty cycle of clk\_out is not 50%
- Fracdiv(Fractional divider)
  - clk\_out\_freq=clk\_in\_freq\*numerator/denominator, both numerator and denominator are 16 bits
  - Divfree50(Glitch free divider for duty cycle 50%)
  - clk\_out\_freq=clk\_in\_freq/divisor
    - When divisor is even or odd, the clock duty cycle of clk\_out is 50%
- DivFreeNP5(Glitch free divider for null point 5)
  - clk\_out\_freq = 2\*clk\_in\_freq/(2\*div\_con+3)
    - The clock duty cycle of clk\_out is not 50%

The setting of all basic units are controlled by CRU registers. Especial for core, the setting also can be controlled by submodule HWFFC, the actually setting can be read by some shadow registers when HWFFC mode is enabled.

### 2.4 Register Description

#### 2.4.1 Registers Summary

| Name          | Offset | Size | Reset<br>Value | Description                  |
|---------------|--------|------|----------------|------------------------------|
| CRU APLL CONO | 0x0000 | W    | 0x00003064     | APLL configuration register0 |
| CRU APLL CON1 | 0x0004 | W    | 0x00001041     | APLL configuration register1 |
| CRU_APLL_CON2 | 0x0008 | W    | 0x0000001      | APLL configuration register2 |
| CRU APLL CON3 | 0x000c | W    | 0x0000007      | APLL configuration register3 |
| CRU_APLL_CON4 | 0x0010 | W    | 0x00007f00     | APLL configuration register4 |
| CRU_DPLL_CON0 | 0x0020 | W    | 0x00002064     | DPLL configuration register0 |
| CRU DPLL CON1 | 0x0024 | W    | 0x00001041     | DPLL configuration register1 |
| CRU_DPLL_CON2 | 0x0028 | W    | 0x0000001      | DPLL configuration register2 |
| CRU DPLL CON3 | 0x002c | W    | 0x0000007      | DPLL configuration register3 |

| Name                    | Offset | Size | Reset<br>Value | Description                                                 |
|-------------------------|--------|------|----------------|-------------------------------------------------------------|
| CRU_DPLL_CON4           | 0x0030 | W    | 0x00007f00     | DPLL configuration register4                                |
| CRU VPLLO CONO          | 0x0040 | W    | 0x00001028     | VPLL0 configuration register0                               |
| CRU VPLL0 CON1          | 0x0044 | W    | 0x00000041     | VPLL0 configuration register1                               |
| CRU VPLL0 CON2          | 0x0048 | W    | 0x00f5c28f     | VPLL0 configuration register2                               |
| CRU VPLL0 CON3          | 0x004c | W    | 0x0000007      | VPLL0 configuration register3                               |
| CRU_VPLL0_CON4          | 0x0050 | W    | 0x00007f00     | VPLL0 configuration register4                               |
| CRU VPLL1 CON0          | 0x0060 | W    | 0x00001021     | VPLL1 configuration register0                               |
| CRU VPLL1 CON1          | 0x0064 | W    | 0x00000041     | VPLL1 configuration register1                               |
| CRU VPLL1 CON2          | 0x0068 | W    | 0x00de69ad     | VPLL1 configuration register2                               |
| CRU VPLL1 CON3          | 0x006c | W    | 0x0000007      | VPLL1 configuration register3                               |
| CRU VPLL1 CON4          | 0x0070 | W    | 0x00007f00     | VPLL1 configuration register4                               |
| CRU_MODE                | 0x00a0 | W    | 0x00000000     | MODE register                                               |
| CRU MISC                | 0x00a4 | W    | 0x0000000      | MISC register                                               |
| <u>CRU GLB CNT TH</u>   | 0x00b0 | W    | 0x00000000     | Global reset counter threshold register                     |
| CRU GLB RST ST          | 0x00b4 | W    | 0x0000000      | Global reset state register                                 |
| CRU_GLB_SRST_FST        | 0x00b8 | W    | 0x0000000      | Global software first reset register                        |
| <u>CRU GLB SRST SND</u> | 0x00bc | W    | 0x00000000     | Global software second reset<br>register                    |
| CRU GLB RST CON         | 0x00c0 | W    | 0x0000000      | Global reset control register                               |
| CRU GLB PLL LOCK        | 0x00c4 | W    | 0x00003a98     | Global PLL lock register                                    |
| CRU_HWFFC_CON0          | 0x00e0 | W    | 0x00000000     | Hardware fast frequency change control register0            |
| CRU_HWFFC_TH            | 0x00e8 | W    | 0x0000030f     | Hardware fast frequency change<br>threshold register        |
| CRU_HWFFC_INTSTS        | 0x00ec | W    | 0x00000000     | Hardware fast frequency change<br>interrupt status register |
| CRU APLL CONO S         | 0x00f0 | W    | 0x00003064     | APLL configuration shadow<br>register0                      |
| CRU APLL CON1 S         | 0x00f4 | W    | 0x00001041     | APLL configuration shadow<br>register1                      |
| CRU_CLKSEL_CON0_S       | 0x00f8 | W    | 0x00001300     | Internal clock select and divide shadow register0           |
| CRU_CLKSEL_CON0         | 0x0100 | W    | 0x00001300     | Internal clock select and divide register0                  |
| CRU CLKSEL CON1         | 0x0104 | W    | 0x0000080      | Internal clock select and divide register1                  |
| CRU CLKSEL CON2         | 0x0108 | W    | 0x00000300     | Internal clock select and divide register2                  |
| CRU_CLKSEL_CON3         | 0x010c | W    | 0x00000000     | Internal clock select and divide register3                  |
| CRU_CLKSEL_CON4         | 0x0110 | W    | 0x00007530     | Internal clock select and divide register4                  |

| Name             | Offset | Size | Reset<br>Value | Description                                 |
|------------------|--------|------|----------------|---------------------------------------------|
| CRU CLKSEL CON5  | 0x0114 | W    | 0x00000005     | Internal clock select and divide register5  |
| CRU_CLKSEL_CON6  | 0x0118 | W    | 0x00000b0b     | Internal clock select and divide register6  |
| CRU CLKSEL CON7  | 0x011c | W    | 0x00000305     | Internal clock select and divide register7  |
| CRU CLKSEL CON8  | 0x0120 | W    | 0x0000007      | Internal clock select and divide register8  |
| CRU CLKSEL CON9  | 0x0124 | W    | 0x0000000      | Internal clock select and divide register9  |
| CRU_CLKSEL_CON10 | 0x0128 | W    | 0x000000b      | Internal clock select and divide register10 |
| CRU CLKSEL CON11 | 0x012c | W    | 0x000000b      | Internal clock select and divide register11 |
| CRU CLKSEL CON12 | 0x0130 | W    | 0x0000000      | Internal clock select and divide register12 |
| CRU CLKSEL CON13 | 0x0134 | W    | 0x000000b      | Internal clock select and divide register13 |
| CRU CLKSEL CON14 | 0x0138 | W    | 0x000000b      | Internal clock select and divide register14 |
| CRU CLKSEL CON15 | 0x013c | W    | 0x0000000      | Internal clock select and divide register15 |
| CRU CLKSEL CON16 | 0x0140 | W    | 0x000000b      | Internal clock select and divide register16 |
| CRU CLKSEL CON17 | 0x0144 | W    | 0x000000b      | Internal clock select and divide register17 |
| CRU CLKSEL CON18 | 0x0148 | W    | 0x0000000      | Internal clock select and divide register18 |
| CRU CLKSEL CON19 | 0x014c | W    | 0x000000b      | Internal clock select and divide register19 |
| CRU CLKSEL CON20 | 0x0150 | W    | 0x000000b      | Internal clock select and divide register20 |
| CRU CLKSEL CON21 | 0x0154 | W    | 0x00000000     | Internal clock select and divide register21 |
| CRU CLKSEL CON22 | 0x0158 | W    | 0x0000000b     | Internal clock select and divide register22 |
| CRU CLKSEL CON23 | 0x015c | W    | 0x0000000b     | Internal clock select and divide register23 |
| CRU CLKSEL CON24 | 0x0160 | w    | 0×00000000     | Internal clock select and divide register24 |
| CRU CLKSEL CON25 | 0x0164 | W    | 0x00000005     | Internal clock select and divide register25 |

| Name             | Offset | Size | Reset<br>Value | Description                                 |
|------------------|--------|------|----------------|---------------------------------------------|
| CRU CLKSEL CON26 | 0x0168 | W    | 0x00000005     | Internal clock select and divide register26 |
| CRU_CLKSEL_CON27 | 0x016c | W    | 0x00000005     | Internal clock select and divide register27 |
| CRU CLKSEL CON28 | 0x0170 | W    | 0x0000005      | Internal clock select and divide register28 |
| CRU CLKSEL CON29 | 0x0174 | W    | 0x000000b      | Internal clock select and divide register29 |
| CRU CLKSEL CON30 | 0x0178 | W    | 0x000000b      | Internal clock select and divide register30 |
| CRU_CLKSEL_CON31 | 0x017c | W    | 0x000000b      | Internal clock select and divide register31 |
| CRU CLKSEL CON32 | 0x0180 | w    | 0x000000b      | Internal clock select and divide register32 |
| CRU CLKSEL CON33 | 0x0184 | W    | 0x0000001      | Internal clock select and divide register33 |
| CRU CLKSEL CON34 | 0x0188 | W    | 0x00000017     | Internal clock select and divide register34 |
| CRU CLKSEL CON35 | 0x018c | W    | 0x00000010     | Internal clock select and divide register35 |
| CRU CLKSEL CON36 | 0x0190 | W    | 0×00000005     | Internal clock select and divide register36 |
| CRU CLKSEL CON37 | 0x0194 | w    | 0x00000b0b     | Internal clock select and divide register37 |
| CRU CLKSEL CON38 | 0x0198 | w    | 0×00000007     | Internal clock select and divide register38 |
| CRU CLKSEL CON39 | 0x019c | w    | 0x0000003      | Internal clock select and divide register39 |
| CRU CLKSEL CON40 | 0x01a0 | w    | 0x0000003      | Internal clock select and divide register40 |
| CRU CLKSEL CON41 | 0x01a4 | W    | 0x0000003      | Internal clock select and divide register41 |
| CRU CLKSEL CON42 | 0x01a8 | w    | 0x00004004     | Internal clock select and divide register42 |
| CRU CLKSEL CON43 | 0x01ac | w    | 0x00008017     | Internal clock select and divide register43 |
| CRU CLKSEL CON44 | 0x01b0 | w    | 0x000009d      | Internal clock select and divide register44 |
| CRU CLKSEL CON45 | 0x01b4 | w    | 0x00000909     | Internal clock select and divide register45 |
| CRU CLKSEL CON46 | 0x01b8 | W    | 0x0000000f     | Internal clock select and divide register46 |

| Name             | Offset | Size | Reset<br>Value | Description                                 |
|------------------|--------|------|----------------|---------------------------------------------|
| CRU CLKSEL CON47 | 0x01bc | W    | 0x00000000     | Internal clock select and divide register47 |
| CRU_CLKSEL_CON48 | 0x01c0 | W    | 0x0000009      | Internal clock select and divide register48 |
| CRU CLKSEL CON49 | 0x01c4 | w    | 0x0000000      | Internal clock select and divide register49 |
| CRU CLKSEL CON50 | 0x01c8 | w    | 0x0000003      | Internal clock select and divide register50 |
| CRU CLKSEL CON51 | 0x01cc | w    | 0x00000000     | Internal clock select and divide register51 |
| CRU_CLKSEL_CON52 | 0x01d0 | W    | 0x00000111     | Internal clock select and divide register52 |
| CRU CLKSEL CON53 | 0x01d4 | w    | 0x00000000     | Internal clock select and divide register53 |
| CRU CLKSEL CON54 | 0x01d8 | w    | 0x0000013      | Internal clock select and divide register54 |
| CRU CLKSEL CON55 | 0x01dc | W    | 0x00000000     | Internal clock select and divide register55 |
| CRU CLKSEL CON56 | 0x01e0 | w    | 0x00000111     | Internal clock select and divide register56 |
| CRU CLKSEL CON57 | 0x01e4 | w    | 0x0000000      | Internal clock select and divide register57 |
| CRU CLKSEL CON58 | 0x01e8 | W    | 0x00000013     | Internal clock select and divide register58 |
| CRU CLKSEL CON59 | 0x01ec | W    | 0x00000000     | Internal clock select and divide register59 |
| CRU CLKSEL CON60 | 0x01f0 | w    | 0x00000111     | Internal clock select and divide register60 |
| CRU CLKSEL CON61 | 0x01f4 | W    | 0x00000000     | Internal clock select and divide register61 |
| CRU CLKSEL CON62 | 0x01f8 | W    | 0x00000013     | Internal clock select and divide register62 |
| CRU CLKSEL CON63 | 0x01fc | W    | 0x00000000     | Internal clock select and divide register63 |
| CRU CLKSEL CON64 | 0x0200 | w    | 0x00000111     | Internal clock select and divide register64 |
| CRU CLKSEL CON65 | 0x0204 | W    | 0x00000000     | Internal clock select and divide register65 |
| CRU CLKSEL CON66 | 0x0208 | w    | 0x00000013     | Internal clock select and divide register66 |
| CRU CLKSEL CON67 | 0x020c | W    | 0x00000000     | Internal clock select and divide register67 |

| Name              | Offset | Size | Reset<br>Value | Description                                 |
|-------------------|--------|------|----------------|---------------------------------------------|
| CRU CLKSEL CON68  | 0x0210 | w    | 0x0000013      | Internal clock select and divide register68 |
| CRU_CLKSEL_CON69  | 0x0214 | w    | 0x0000000      | Internal clock select and divide register69 |
| CRU CLKSEL CON70  | 0x0218 | w    | 0x00000013     | Internal clock select and divide register70 |
| CRU CLKSEL CON71  | 0x021c | w    | 0x00000000     | Internal clock select and divide register71 |
| CRU CLKSEL CON72  | 0x0220 | w    | 0x0000031      | Internal clock select and divide register72 |
| CRU_CLKSEL_CON73  | 0x0224 | w    | 0x0000001f     | Internal clock select and divide register73 |
| CRU CLKGATE CONO  | 0x0300 | W    | 0x0000000      | Internal clock gating register0             |
| CRU_CLKGATE_CON1  | 0x0304 | W    | 0x00000000     | Internal clock gating register1             |
| CRU CLKGATE CON2  | 0x0308 | W    | 0x00000000     | Internal clock gating register2             |
| CRU_CLKGATE_CON3  | 0x030c | W    | 0x00000000     | Internal clock gating register3             |
| CRU_CLKGATE_CON4  | 0x0310 | W    | 0x00000000     | Internal clock gating register4             |
| CRU CLKGATE CON5  | 0x0314 | W    | 0x00000000     | Internal clock gating register5             |
| CRU_CLKGATE_CON6  | 0x0318 | W    |                | Internal clock gating register6             |
| CRU CLKGATE CON7  | 0x031c | W    | 0x00000000     | Internal clock gating register7             |
| CRU CLKGATE CON8  | 0x0320 | W    | 0x00000000     | Internal clock gating register8             |
| CRU_CLKGATE_CON9  | 0x0324 | W    | 0x00000000     | Internal clock gating register9             |
| CRU CLKGATE CON10 | 0x0328 | W    | 0x00000000     | Internal clock gating register10            |
| CRU_CLKGATE_CON11 | 0x032c | W    | 0x00000000     | Internal clock gating register11            |
| CRU_CLKGATE_CON12 | 0x0330 | W    | 0x00000000     | Internal clock gating register12            |
| CRU CLKGATE CON13 | 0x0334 | W    | 0x00000000     | Internal clock gating register13            |
| CRU_CLKGATE_CON14 | 0x0338 | W    |                | Internal clock gating register14            |
| CRU_SSCGTBL0_3    | 0x0380 | w    | 0×00000000     | SSCG external wave table register0          |
| CRU_SSCGTBL4_7    | 0x0384 | w    | 0×00000000     | SSCG external wave table register1          |
| CRU_SSCGTBL8_11   | 0x0388 | w    | 0×00000000     | SSCG external wave table register2          |
| CRU SSCGTBL12 15  | 0x038c | w    | 0x00000000     | SSCG external wave table register3          |
| CRU SSCGTBL16 19  | 0x0390 | W    | 0x00000000     | SSCG external wave table register4          |
| CRU_SSCGTBL20_23  | 0x0394 | w    | 0x00000000     | SSCG external wave table<br>register5       |
| CRU_SSCGTBL24_27  | 0x0398 | w    | 0×00000000     | SSCG external wave table<br>register6       |
| CRU_SSCGTBL28_31  | 0x039c | w    | 0×00000000     | SSCG external wave table<br>register7       |

| Name               | Offset | Size | Reset<br>Value | Description                         |
|--------------------|--------|------|----------------|-------------------------------------|
| CRU SSCGTBL32 35   | 0x03a0 | w    | 0×00000000     | SSCG external wave table register8  |
| CRU_SSCGTBL36_39   | 0x03a4 | w    | 0×00000000     | SSCG external wave table register9  |
| CRU SSCGTBL40 43   | 0x03a8 | w    | 0×00000000     | SSCG external wave table register10 |
| CRU SSCGTBL44 47   | 0x03ac | W    | 0×00000000     | SSCG external wave table register11 |
| CRU SSCGTBL48 51   | 0x03b0 | W    | 0×00000000     | SSCG external wave table register12 |
| CRU_SSCGTBL52_55   | 0x03b4 | w    | 0×00000000     | SSCG external wave table register13 |
| CRU SSCGTBL56 59   | 0x03b8 | w    | 0x00000000     | SSCG external wave table register14 |
| CRU SSCGTBL60 63   | 0x03bc | w    | 0x00000000     | SSCG external wave table register15 |
| CRU SSCGTBL64 67   | 0x03c0 | w    | 0×00000000     | SSCG external wave table register16 |
| CRU SSCGTBL68 71   | 0x03c4 | w    | 0x00000000     | SSCG external wave table register17 |
| CRU SSCGTBL72 75   | 0x03c8 | w    | 0x00000000     | SSCG external wave table register18 |
| CRU SSCGTBL76 79   | 0x03cc | w    | 0x00000000     | SSCG external wave table register19 |
| CRU SSCGTBL80 83   | 0x03d0 | w    | 0x00000000     | SSCG external wave table register20 |
| CRU SSCGTBL84 87   | 0x03d4 | w    | 0x00000000     | SSCG external wave table register21 |
| CRU SSCGTBL88 91   | 0x03d8 | w    | 0x00000000     | SSCG external wave table register22 |
| CRU SSCGTBL92 95   | 0x03dc | w    | 0x00000000     | SSCG external wave table register23 |
| CRU_SSCGTBL96_99   | 0x03e0 | w    | 0x00000000     | SSCG external wave table register24 |
| CRU SSCGTBL100 103 | 0x03e4 | w    | 0x00000000     | SSCG external wave table register25 |
| CRU SSCGTBL104 107 | 0x03e8 | w    | 0x00000000     | SSCG external wave table register26 |
| CRU SSCGTBL108 111 | 0x03ec | w    | 0x00000000     | SSCG external wave table register27 |
| CRU SSCGTBL112 115 | 0x03f0 | w    | 0x00000000     | SSCG external wave table register28 |

| Name               | Offset | Size | Reset<br>Value | Description                                  |
|--------------------|--------|------|----------------|----------------------------------------------|
| CRU SSCGTBL116 119 | 0x03f4 | w    | 0x00000000     | SSCG external wave table register29          |
| CRU_SSCGTBL120_123 | 0x03f8 | W    | 0x00000000     | SSCG external wave table register30          |
| CRU SSCGTBL124 127 | 0x03fc | w    | 0x00000000     | SSCG external wave table register31          |
| CRU SOFTRST CONO   | 0x0400 | w    | 0x00000000     | Internal software reset control<br>register0 |
| CRU SOFTRST CON1   | 0x0404 | w    | 0x00000000     | Internal software reset control<br>register1 |
| CRU_SOFTRST_CON2   | 0x0408 | w    | 0x00000000     | Internal software reset control<br>register2 |
| CRU SOFTRST CON3   | 0x040c | w    | 0x00000000     | Internal software reset control<br>register3 |
| CRU SOFTRST CON4   | 0x0410 | w    | 0x00000000     | Internal software reset control register4    |
| CRU SOFTRST CON5   | 0x0414 | w    | 0x00000000     | Internal software reset control<br>register5 |
| CRU SOFTRST CON6   | 0x0418 | W    | 0x00000000     | Internal software reset control<br>register6 |
| CRU SOFTRST CON7   | 0x041c | w    | 0x00000000     | Internal software reset control<br>register7 |
| CRU SOFTRST CON8   | 0x0420 | w    | 0x00000000     | Internal software reset control<br>register8 |
| CRU SOFTRST CON9   | 0x0424 | w    | 0x00000000     | Internal software reset control<br>register9 |
| CRU_SDMMC_CON0     | 0x0480 | W    | 0x0000004      | SDMMC control register0                      |
| CRU_SDMMC_CON1     | 0x0484 | W    | 0x00000000     | SDMMC control register1                      |
| CRU SDIO CONO      | 0x0488 | W    | 0x0000004      | SDIO control register0                       |
| CRU_SDIO_CON1      | 0x048c | W    | 0x0000000      | SDIO control register1                       |
| CRU EMMC CONO      | 0x0490 | W    | 0x0000004      | EMMC control register0                       |
| CRU EMMC CON1      | 0x0494 | W    | 0x00000000     | EMMC control register1                       |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

#### 2.4.2 Detail Register Description CRU APLL CON0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | RW   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | bypass                                                       |
| 1 5   |      | 0.40               | REF is bypassed to FOUTPOSTDIV                               |
| 15    | RW   | 0x0                | 1'b0: no bypass                                              |
|       |      |                    | 1'b1: bypass                                                 |
|       |      |                    | postdiv1                                                     |
| 14:12 | RW   | 0x3                | PLL post divide 1 setting, 1-7 is valid                      |
|       |      |                    | postdiv1 should be greater than or equal to postdiv2         |
|       |      |                    | fbdiv                                                        |
|       |      |                    | PLL feedback divide value:                                   |
| 11:0  | RW   | 0x064              | 16-3200 is valid in integer mode                             |
|       |      |                    | 20-320 is valid in fractional mode                           |
|       |      |                    | Tips: no plus one operation                                  |

### CRU APLL CON1

Address: Operational Base + offset (0x0004)

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
|       |      |                    | write_mask                                                      |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit       |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit    |
|       |      |                    | pllpdsel                                                        |
| 15    | RW   | 0x0                | 1'b0: PLL is power down when any one of refdiv/fbdiv/fracdiv is |
| 13    |      | 0.00               | changed or pllpd0 is asserted                                   |
|       |      |                    | 1'b1: PLL can be power down only by pllpd1                      |
|       |      |                    | pllpd1                                                          |
| 14    | RW   | 0x0                | PLL power down 1 setting, it's valid when pllpdsel=1'b1         |
| 14    | L AN | 0.00               | 1'b0: no power down                                             |
|       |      |                    | 1'b1: power down                                                |
|       |      |                    | pllpd0                                                          |
| 13    | RW   | 0x0                | PLL power down 0 setting, it's valid when pllpdsel=1'b0         |
| 15    | 1    | 0.0                | 1'b0: no power down                                             |
|       |      |                    | 1'b1: power down                                                |
|       |      |                    | dsmpd                                                           |
| 12    | RW   | 0x1                | Power down delta-sigma modulator                                |
| 12    |      | 0.71               | 1'b0: no power down, PLL is fractional mode                     |
|       |      |                    | 1'b1: power down, PLL is integer mode                           |
| 11    | RO   | 0x0                | reserved                                                        |
|       |      |                    | pll_lock                                                        |
| 10    | RO   | 0x0                | 1'b0: unlock                                                    |
|       |      |                    | 1'b1: lock                                                      |
| 9     | RO   | 0x0                | reserved                                                        |

| Bit | Attr | <b>Reset Value</b> | Description                                         |  |  |  |
|-----|------|--------------------|-----------------------------------------------------|--|--|--|
| 8:6 | RW   | 0x1                | postdiv2<br>PLL post divide 2 setting, 1-7 is valid |  |  |  |
| 5:0 | RW   | 0x01               | refdiv<br>Reference divide value, 1-63 is valid     |  |  |  |

### CRU\_APLL\_CON2

Address: Operational Base + offset (0x0008)

| Bit   | Attr  | <b>Reset Value</b> | Description                                 |                     |
|-------|-------|--------------------|---------------------------------------------|---------------------|
| 31:28 | RO    | 0x0                | reserved                                    |                     |
|       |       |                    | fout4phasepd                                |                     |
| 27    | RW    | 0x0                | Power down of 4 phase clock generator       |                     |
| 27    |       | 0.00               | 1'b0: no power down                         |                     |
|       |       |                    | 1'b1: power down                            |                     |
|       |       |                    | foutvcopd                                   |                     |
| 26    | RW    | 0x0                | VCO rate output clock power down            |                     |
| 20    |       |                    | 0.00                                        | 1'b0: no power down |
|       |       |                    | 1'b1: power down                            |                     |
|       |       |                    | foutpostdivpd                               |                     |
| 25    | RW    | 0x0                | Post divide power down                      |                     |
| 25    |       | 0.00               | 1'b0: no power down                         |                     |
|       |       |                    | 1'b1: power down                            |                     |
|       |       |                    | dacpd                                       |                     |
| 24    | RW    | 0x0                | Power down noise canceling DAC in FRAC mode |                     |
| 24    | RVV   |                    | 1'b0: no power down                         |                     |
|       |       |                    | 1'b1: power down                            |                     |
| 23:0  | RW    | 0x000001           | fracdiv                                     |                     |
| 23.0  | :0 RW |                    | Fractional portion of feedback divide value |                     |

#### CRU\_APLL\_CON3

Address: Operational Base + offset (0x000c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                     |
|       |      | 0.00               | ssmod_spread                                                 |
|       |      |                    | Set modulation depth(spread percentage) of SSMOD             |
|       |      |                    | 5'h0: 0%                                                     |
| 12:8  | wo   |                    | 5'h1: 0.1%                                                   |
| 12:0  | WU   | 0x00               | 5'h2: 0.2%                                                   |
|       |      |                    |                                                              |
|       |      |                    | 5'h1e: 3%                                                    |
|       |      |                    | 5'h1f: 3.1%                                                  |

| Bit | Attr   | <b>Reset Value</b> | Description                                                 |
|-----|--------|--------------------|-------------------------------------------------------------|
| 7:4 | WO 0x0 | 0.20               | ssmod_divval                                                |
| 7:4 | WO     | 0.00               | Divider of SSMOD required to set the modulation frequency   |
|     |        |                    | ssmod_downspread                                            |
| 3   | wo     | 0.40               | Select center spread or down spread of SSMOD                |
| 2   | 000    | 0x0                | 1'b0: down spread                                           |
|     |        |                    | 1'b1: center spread                                         |
|     |        |                    | ssmod_reset                                                 |
| 2   | wo     | VO 0×1             | SSMOD reset                                                 |
| Z   | 000    |                    | 1'b0: no reset                                              |
|     |        |                    | 1'b1: reset                                                 |
|     |        |                    | ssmod_disable_sscg                                          |
|     |        |                    | Disable sperad spectrum clock generation of SSMOD, SSMOD is |
| 1   | WO     | 0x1                | bypass when disable.                                        |
|     |        |                    | 1'b0: Enable                                                |
|     |        |                    | 1'b1: Disable                                               |
|     |        |                    | ssmod_bp                                                    |
| 0   | wo     | WO 0x1             | SSMOD bypass                                                |
| 0   | 100    |                    | 1'b0: no bypass                                             |
|     |        |                    | 1'b1: bypass                                                |

### CRU\_APLL\_CON4

Address: Operational Base + offset (0x0010)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:8  | wo   | O 0x7f             | ssmod_ext_maxaddr                                            |
| 15:0  | wo   |                    | SSMOD maximum address of external wave table, 0-255 is valid |
| 7:1   | RO   | 0x0                | reserved                                                     |
|       |      |                    | ssmod_sel_ext_wave                                           |
| 0     | wo   | /O 0x0             | SSMOD select external wave table                             |
| 0     | VVO  |                    | 1'b0: Don't select                                           |
|       |      |                    | 1'b1: Select                                                 |

### CRU\_DPLL\_CON0

Address: Operational Base + offset (0x0020)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | bypass                                                       |
| 1 5   |      | 0.40               | REF is bypassed to FOUTPOSTDIV                               |
| 15    | RW   | 0x0                | 1'b0: no bypass                                              |
|       |      |                    | 1'b1: bypass                                                 |
|       |      |                    | postdiv1                                                     |
| 14:12 | RW   | 0x2                | PLL post divide 1 setting, 1-7 is valid                      |
|       |      |                    | postdiv1 should be greater than or equal to postdiv2         |
|       |      |                    | fbdiv                                                        |
|       |      |                    | PLL feedback divide value:                                   |
| 11:0  | RW   | 0x064              | 16-3200 is valid in integer mode                             |
|       |      |                    | 20-320 is valid in fractional mode                           |
|       |      |                    | Tips: no plus one operation                                  |

### CRU DPLL CON1

Address: Operational Base + offset (0x0024)

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
|       |      |                    | write_mask                                                      |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit       |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit    |
|       |      | 0×0                | pllpdsel                                                        |
| 15    | RW   |                    | 1'b0: PLL is power down when any one of refdiv/fbdiv/fracdiv is |
| 13    |      |                    | changed or pllpd0 is asserted                                   |
|       |      |                    | 1'b1: PLL can be power down only by pllpd1                      |
|       |      | 0x0                | pllpd1                                                          |
| 14    | RW   |                    | PLL power down 1 setting, it's valid when pllpdsel=1'b1         |
| 14    | RVV  |                    | 1'b0: no power down                                             |
|       |      |                    | 1'b1: power down                                                |
|       | RW   | 0×0                | pllpd0                                                          |
| 13    |      |                    | PLL power down 0 setting, it's valid when pllpdsel=1'b0         |
| 15    |      |                    | 1'b0: no power down                                             |
|       |      |                    | 1'b1: power down                                                |
|       | RW   | V 0x1              | dsmpd                                                           |
| 12    |      |                    | Power down delta-sigma modulator                                |
| 12    |      |                    | 1'b0: no power down, PLL is fractional mode                     |
|       |      |                    | 1'b1: power down, PLL is integer mode                           |
| 11    | RO   | 0x0                | reserved                                                        |
|       |      |                    | pll_lock                                                        |
| 10    | RO   | 0x0                | 1'b0: unlock                                                    |
|       |      |                    | 1'b1: lock                                                      |
| 9     | RO   | 0x0                | reserved                                                        |

| Bit | Attr | <b>Reset Value</b> | Description                                         |
|-----|------|--------------------|-----------------------------------------------------|
| 8:6 | RW   | 0x1                | postdiv2<br>PLL post divide 2 setting, 1-7 is valid |
| 5:0 | RW   | 0x01               | refdiv<br>Reference divide value, 1-63 is valid     |

#### CRU\_DPLL\_CON2

Address: Operational Base + offset (0x0028)

| Bit   | Attr | <b>Reset Value</b> | Description                                 |
|-------|------|--------------------|---------------------------------------------|
| 31:28 | RO   | 0x0                | reserved                                    |
|       | RW   | 0x0                | fout4phasepd                                |
| 27    |      |                    | Power down of 4 phase clock generator       |
| 27    |      |                    | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
|       |      | 0×0                | foutvcopd                                   |
| 26    | RW   |                    | VCO rate output clock power down            |
| 20    | RW   |                    | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
|       | RW   |                    | foutpostdivpd                               |
| 25    |      |                    | Post divide power down                      |
| 25    |      |                    | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
|       | RW   | 0×0                | dacpd                                       |
| 24    |      |                    | Power down noise canceling DAC in FRAC mode |
| 24    |      |                    | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
| 23:0  | RW   | N 10x000001        | fracdiv                                     |
| 25.0  |      |                    | Fractional portion of feedback divide value |

#### CRU\_DPLL\_CON3

Address: Operational Base + offset (0x002c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | write_mask                                                   |
|       |      |                    | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                     |
|       | wo   | 0×00               | ssmod_spread                                                 |
|       |      |                    | Set modulation depth(spread percentage) of SSMOD             |
|       |      |                    | 5'h0: 0%                                                     |
| 12:8  |      |                    | 5'h1: 0.1%                                                   |
| 12:0  |      |                    | 5'h2: 0.2%                                                   |
|       |      |                    |                                                              |
|       |      |                    | 5'h1e: 3%                                                    |
|       |      |                    | 5'h1f: 3.1%                                                  |

| Bit | Attr | <b>Reset Value</b> | Description                                                 |
|-----|------|--------------------|-------------------------------------------------------------|
| 7:4 | wo   | 0x0                | ssmod_divval                                                |
| 7:4 | 000  |                    | Divider of SSMOD required to set the modulation frequency   |
|     |      | 0x0                | ssmod_downspread                                            |
| 3   | wo   |                    | Select center spread or down spread of SSMOD                |
| 5   | 000  |                    | 1'b0: down spread                                           |
|     |      |                    | 1'b1: center spread                                         |
|     |      | 0×1                | ssmod_reset                                                 |
| 2   | wo   |                    | SSMOD reset                                                 |
| Z   | 000  |                    | 1'b0: no reset                                              |
|     |      |                    | 1'b1: reset                                                 |
|     |      | /O 0x1             | ssmod_disable_sscg                                          |
|     |      |                    | Disable sperad spectrum clock generation of SSMOD, SSMOD is |
| 1   | WO   |                    | bypass when disable.                                        |
|     |      |                    | 1'b0: Enable                                                |
|     |      |                    | 1'b1: Disable                                               |
|     | wo   | O 0x1              | ssmod_bp                                                    |
| 0   |      |                    | SSMOD bypass                                                |
| 0   | VVU  |                    | 1'b0: no bypass                                             |
|     |      |                    | 1'b1: bypass                                                |

### CRU\_DPLL\_CON4

Address: Operational Base + offset (0x0030)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       | wo   | 0x0000             | write_mask                                                   |
| 31:16 |      |                    | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:8  | WO   | 0x7f               | ssmod_ext_maxaddr                                            |
| 15:8  |      |                    | SSMOD maximum address of external wave table, 0-255 is valid |
| 7:1   | RO   | 0x0                | reserved                                                     |
|       | wo   | 0x0                | ssmod_sel_ext_wave                                           |
| 0     |      |                    | SSMOD select external wave table                             |
| 0     |      |                    | 1'b0: Don't select                                           |
|       |      |                    | 1'b1: Select                                                 |

### CRU\_VPLL0\_CON0

Address: Operational Base + offset (0x0040)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | bypass                                                       |
| 1 5   |      | 0.40               | REF is bypassed to FOUTPOSTDIV                               |
| 15    | RW   | 0×0                | 1'b0: no bypass                                              |
|       |      |                    | 1'b1: bypass                                                 |
|       |      | W 0x1              | postdiv1                                                     |
| 14:12 | RW   |                    | PLL post divide 1 setting, 1-7 is valid                      |
|       |      |                    | postdiv1 should be greater than or equal to postdiv2         |
|       |      |                    | fbdiv                                                        |
|       |      |                    | PLL feedback divide value:                                   |
| 11:0  | RW   | W 0x028            | 16-3200 is valid in integer mode                             |
|       |      |                    | 20-320 is valid in fractional mode                           |
|       |      |                    | Tips: no plus one operation                                  |

## CRU\_VPLL0\_CON1

Address: Operational Base + offset (0x0044)

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
|       |      |                    | write_mask                                                      |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit       |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit    |
|       |      |                    | pllpdsel                                                        |
| 15    | RW   | 0x0                | 1'b0: PLL is power down when any one of refdiv/fbdiv/fracdiv is |
| 15    | ĸvv  | 0.00               | changed or pllpd0 is asserted                                   |
|       |      |                    | 1'b1: PLL can be power down only by pllpd1                      |
|       |      |                    | pllpd1                                                          |
| 14    | RW   | 0x0                | PLL power down 1 setting, it's valid when pllpdsel=1'b1         |
| 14    | ĸvv  | UXU                | 1'b0: no power down                                             |
|       |      |                    | 1'b1: power down                                                |
|       |      | 0x0                | pllpd0                                                          |
| 13    | RW   |                    | PLL power down 0 setting, it's valid when pllpdsel=1'b0         |
| 13    |      |                    | 1'b0: no power down                                             |
|       |      |                    | 1'b1: power down                                                |
|       |      |                    | dsmpd                                                           |
| 12    | RW   | 0x0                | Power down delta-sigma modulator                                |
| 12    | r vv |                    | 1'b0: no power down, PLL is fractional mode                     |
|       |      |                    | 1'b1: power down, PLL is integer mode                           |
| 11    | RO   | 0x0                | reserved                                                        |
|       |      |                    | pll_lock                                                        |
| 10    | RO   | 0x0                | 1'b0: unlock                                                    |
|       |      |                    | 1'b1: lock                                                      |
| 9     | RO   | 0x0                | reserved                                                        |

| Bit | Attr | <b>Reset Value</b> | Description                                         |
|-----|------|--------------------|-----------------------------------------------------|
| 8:6 | RW   | 0x1                | postdiv2<br>PLL post divide 2 setting, 1-7 is valid |
| 5:0 | RW   | 0x01               | refdiv<br>Reference divide value, 1-63 is valid     |

#### CRU\_VPLL0\_CON2

Address: Operational Base + offset (0x0048)

| Bit   | Attr | <b>Reset Value</b> | Description                                 |
|-------|------|--------------------|---------------------------------------------|
| 31:28 | RO   | 0x0                | reserved                                    |
|       |      |                    | fout4phasepd                                |
| 27    | RW   | 0x0                | Power down of 4 phase clock generator       |
| 27    | L AA | 0.00               | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
|       |      |                    | foutvcopd                                   |
| 26    | RW   | 0x0                | VCO rate output clock power down            |
| 20    |      | 0x0                | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
|       |      | 0×0                | foutpostdivpd                               |
| 25    | RW   |                    | Post divide power down                      |
| 23    | L AN |                    | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
|       |      |                    | dacpd                                       |
| 24    | RW   | W 0×0              | Power down noise canceling DAC in FRAC mode |
| 24    | L AA |                    | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
| 23:0  | RW   | 0vf5c28f           | fracdiv                                     |
| 25.0  | r vv | 0xf5c28f           | Fractional portion of feedback divide value |

#### CRU\_VPLL0\_CON3

Address: Operational Base + offset (0x004c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
| 31:16 |      |                    | write_mask                                                   |
|       | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                     |
|       |      | 0×00               | ssmod_spread                                                 |
|       | wo   |                    | Set modulation depth(spread percentage) of SSMOD             |
|       |      |                    | 5'h0: 0%                                                     |
| 12:8  |      |                    | 5'h1: 0.1%                                                   |
| 12:0  |      |                    | 5'h2: 0.2%                                                   |
|       |      |                    |                                                              |
|       |      |                    | 5'h1e: 3%                                                    |
|       |      |                    | 5'h1f: 3.1%                                                  |

| Bit | Attr | <b>Reset Value</b> | Description                                                 |
|-----|------|--------------------|-------------------------------------------------------------|
| 7:4 | wo   | 0x0                | ssmod_divval                                                |
| 7:4 | WU   | 0x0                | Divider of SSMOD required to set the modulation frequency   |
|     |      |                    | ssmod_downspread                                            |
| 3   | wo   | 0x0                | Select center spread or down spread of SSMOD                |
| 5   | 000  | 0.00               | 1'b0: down spread                                           |
|     |      |                    | 1'b1: center spread                                         |
|     |      |                    | ssmod_reset                                                 |
| 2   | wo   | 0x1                | SSMOD reset                                                 |
| Z   | 000  |                    | 1'b0: no reset                                              |
|     |      |                    | 1'b1: reset                                                 |
|     |      | 0×1                | ssmod_disable_sscg                                          |
|     |      |                    | Disable sperad spectrum clock generation of SSMOD, SSMOD is |
| 1   | WO   |                    | bypass when disable.                                        |
|     |      |                    | 1'b0: Enable                                                |
|     |      |                    | 1'b1: Disable                                               |
|     |      | 'O 0x1             | ssmod_bp                                                    |
| 0   | wo   |                    | SSMOD bypass                                                |
| 0   | VVU  |                    | 1'b0: no bypass                                             |
|     |      |                    | 1'b1: bypass                                                |

CRU VPLLO CON4 Address: Operational Base + offset (0x0050)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 1     | wo   | 0x7f               | ssmod_ext_maxaddr                                            |
| 15:8  |      |                    | SSMOD maximum address of external wave table, 0-255 is valid |
| 7:1   | RO   | 0x0                | reserved                                                     |
|       |      | VO 0x0             | ssmod_sel_ext_wave                                           |
| 0     | wo   |                    | SSMOD select external wave table                             |
| 0     | 000  |                    | 1'b0: Don't select                                           |
|       |      |                    | 1'b1: Select                                                 |

### CRU VPLL1 CON0

Address: Operational Base + offset (0x0060)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | bypass                                                       |
| 1 5   |      | 0.40               | REF is bypassed to FOUTPOSTDIV                               |
| 15    | RW   | 0×0                | 1'b0: no bypass                                              |
|       |      |                    | 1'b1: bypass                                                 |
|       |      |                    | postdiv1                                                     |
| 14:12 | RW   | 0x1                | PLL post divide 1 setting, 1-7 is valid                      |
|       |      |                    | postdiv1 should be greater than or equal to postdiv2         |
|       |      |                    | fbdiv                                                        |
|       |      |                    | PLL feedback divide value:                                   |
| 11:0  | RW   | W 0x021            | 16-3200 is valid in integer mode                             |
|       |      |                    | 20-320 is valid in fractional mode                           |
|       |      |                    | Tips: no plus one operation                                  |

## CRU\_VPLL1\_CON1

Address: Operational Base + offset (0x0064)

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
|       |      |                    | write_mask                                                      |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit       |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit    |
|       |      |                    | pllpdsel                                                        |
| 15    | RW   | 0x0                | 1'b0: PLL is power down when any one of refdiv/fbdiv/fracdiv is |
| 12    | r vv | 0.00               | changed or pllpd0 is asserted                                   |
|       |      |                    | 1'b1: PLL can be power down only by pllpd1                      |
|       |      |                    | pllpd1                                                          |
| 14    | RW   | 0x0                | PLL power down 1 setting, it's valid when pllpdsel=1'b1         |
| 14    | r vv | 0x0                | 1'b0: no power down                                             |
|       |      |                    | 1'b1: power down                                                |
|       |      | 0×0                | pllpd0                                                          |
| 13    | RW   |                    | PLL power down 0 setting, it's valid when pllpdsel=1'b0         |
| 15    |      |                    | 1'b0: no power down                                             |
|       |      |                    | 1'b1: power down                                                |
|       |      |                    | dsmpd                                                           |
| 12    | RW   | 0x0                | Power down delta-sigma modulator                                |
| 12    |      | 0.00               | 1'b0: no power down, PLL is fractional mode                     |
|       |      |                    | 1'b1: power down, PLL is integer mode                           |
| 11    | RO   | 0x0                | reserved                                                        |
|       |      |                    | pll_lock                                                        |
| 10    | RO   | 0x0                | 1'b0: unlock                                                    |
|       |      |                    | 1'b1: lock                                                      |
| 9     | RO   | 0x0                | reserved                                                        |

| Bit | Attr | <b>Reset Value</b> | Description                                         |
|-----|------|--------------------|-----------------------------------------------------|
| 8:6 | RW   | 0x1                | postdiv2<br>PLL post divide 2 setting, 1-7 is valid |
| 5:0 | RW   | 0x01               | refdiv<br>Reference divide value, 1-63 is valid     |

### CRU\_VPLL1\_CON2

Address: Operational Base + offset (0x0068)

| Bit   | Attr | <b>Reset Value</b> | Description                                 |
|-------|------|--------------------|---------------------------------------------|
| 31:28 | RO   | 0x0                | reserved                                    |
|       |      |                    | fout4phasepd                                |
| 27    | RW   | 0x0                | Power down of 4 phase clock generator       |
| 27    |      | 0.00               | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
|       |      |                    | foutvcopd                                   |
| 26    | RW   | 0x0                | VCO rate output clock power down            |
| 20    |      | 0.00               | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
|       |      | 0x0                | foutpostdivpd                               |
| 25    | RW   |                    | Post divide power down                      |
| 23    |      |                    | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
|       |      |                    | dacpd                                       |
| 24    | RW   | W 0×0              | Power down noise canceling DAC in FRAC mode |
| 24    |      |                    | 1'b0: no power down                         |
|       |      |                    | 1'b1: power down                            |
| 23:0  | RW   | 0xde69ad           | fracdiv                                     |
| 25.0  | КW   | UNUEUJau           | Fractional portion of feedback divide value |

#### CRU\_VPLL1\_CON3

Address: Operational Base + offset (0x006c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
| 31:16 |      |                    | write_mask                                                   |
|       | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                     |
|       | WO   | 0×00               | ssmod_spread                                                 |
|       |      |                    | Set modulation depth(spread percentage) of SSMOD             |
|       |      |                    | 5'h0: 0%                                                     |
| 12:8  |      |                    | 5'h1: 0.1%                                                   |
| 12:0  |      |                    | 5'h2: 0.2%                                                   |
|       |      |                    |                                                              |
|       |      |                    | 5'h1e: 3%                                                    |
|       |      |                    | 5'h1f: 3.1%                                                  |

| Bit | Attr | <b>Reset Value</b> | Description                                                 |
|-----|------|--------------------|-------------------------------------------------------------|
| 7:4 | wo   | 00                 | ssmod_divval                                                |
| 7:4 | WU   | 0x0                | Divider of SSMOD required to set the modulation frequency   |
|     |      |                    | ssmod_downspread                                            |
| 3   | wo   | 0x0                | Select center spread or down spread of SSMOD                |
| 5   | 000  | 0.00               | 1'b0: down spread                                           |
|     |      |                    | 1'b1: center spread                                         |
|     |      |                    | ssmod_reset                                                 |
| 2   | wo   | 0x1                | SSMOD reset                                                 |
| Z   | 000  |                    | 1'b0: no reset                                              |
|     |      |                    | 1'b1: reset                                                 |
|     |      | 0 0x1              | ssmod_disable_sscg                                          |
|     |      |                    | Disable sperad spectrum clock generation of SSMOD, SSMOD is |
| 1   | WO   |                    | bypass when disable.                                        |
|     |      |                    | 1'b0: Enable                                                |
|     |      |                    | 1'b1: Disable                                               |
|     |      | O 0x1              | ssmod_bp                                                    |
| 0   | wo   |                    | SSMOD bypass                                                |
| 0   | VVU  |                    | 1'b0: no bypass                                             |
|     |      |                    | 1'b1: bypass                                                |

## CRU VPLL1 CON4

Address: Operational Base + offset (0x0070)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 1     | wo   | 0x7f               | ssmod_ext_maxaddr                                            |
| 15:8  |      |                    | SSMOD maximum address of external wave table, 0-255 is valid |
| 7:1   | RO   | 0x0                | reserved                                                     |
|       |      | VO 0x0             | ssmod_sel_ext_wave                                           |
| 0     |      |                    | SSMOD select external wave table                             |
| 0     | 000  |                    | 1'b0: Don't select                                           |
|       |      |                    | 1'b1: Select                                                 |

#### CRU\_MODE

Address: Operational Base + offset (0x00a0)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |  |  |
|-------|------|--------------------|--------------------------------------------------------------|--|--|
|       |      |                    | write_mask                                                   |  |  |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |  |  |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |  |  |
| 15:14 | RO   | 0x0                | reserved                                                     |  |  |

| Bit | Attr  | <b>Reset Value</b> | Description                                |
|-----|-------|--------------------|--------------------------------------------|
|     |       |                    | vpll1_clk_sel                              |
| 10  |       |                    | VPLL1 clock source select                  |
| 13  | RW    | 0x0                | 1'b0: PLL clock output with level shift    |
|     |       |                    | 1'b1: PLL clock output without level shift |
|     |       |                    | vpll0_clk_sel                              |
| 12  | RW    | 0x0                | VPLL0 clock source select                  |
| 12  | RW    | UXU                | 1'b0: PLL clock output with level shift    |
|     |       |                    | 1'b1: PLL clock output without level shift |
|     |       |                    | dpll_clk_sel                               |
| 11  | RW    | 0x0                | DPLL clock source select                   |
| L T | K VV  | 0.00               | 1'b0: PLL clock output with level shift    |
|     |       |                    | 1'b1: PLL clock output without level shift |
|     |       |                    | apll_clk_sel                               |
| 10  | RW    | 0x0                | APLL clock source select                   |
| 10  | K VV  | 0.00               | 1'b0: PLL clock output with level shift    |
|     |       |                    | 1'b1: PLL clock output without level shift |
|     |       |                    | usbphy480m_work_mode                       |
|     |       |                    | usbphy480m work mode select                |
| 9:8 | RW    | 0x0                | 2'b00: clock from xin_osc0_func_div        |
| 9.0 | L A A | UXU                | 2'b01: clock from PLL                      |
|     |       |                    | 2'b10: clock from clk_rtc_32k              |
|     |       |                    | 2'b11: reserved                            |
|     |       |                    | vpll1_work_mode                            |
|     |       |                    | VPLL1 work mode select                     |
| 7:6 | RW    | N 0x0              | 2'b00: clock from xin_osc0_func_div        |
| /.0 |       |                    | 2'b01: clock from PLL                      |
|     |       |                    | 2'b10: clock from clk_rtc_32k              |
|     |       |                    | 2'b11: reserved                            |
|     |       |                    | vpll0_work_mode                            |
|     |       |                    | VPLL0 work mode select                     |
| 5:4 | RW    | 0x0                | 2'b00: clock from xin_osc0_func_div        |
| 5   |       |                    | 2'b01: clock from PLL                      |
|     |       |                    | 2'b10: clock from clk_rtc_32k              |
|     |       |                    | 2'b11: reserved                            |
|     |       |                    | dpll_work_mode                             |
|     |       |                    | DPLL work mode select                      |
| 3:2 | RW    | 0x0                | 2'b00: clock from xin_osc0_func_div        |
|     |       |                    | 2'b01: clock from PLL                      |
|     |       |                    | 2'b10: clock from clk_rtc_32k              |
|     |       |                    | 2'b11: reserved                            |

| Bit | Attr | <b>Reset Value</b> | Description                         |
|-----|------|--------------------|-------------------------------------|
|     | RW   | 0×0                | apll_work_mode                      |
|     |      |                    | APLL work mode select               |
| 1:0 |      |                    | 2'b00: clock from xin_osc0_func_div |
| 1.0 |      |                    | 2'b01: clock from PLL               |
|     |      |                    | 2'b10: clock from clk_rtc_32k       |
|     |      |                    | 2'b11: reserved                     |

## CRU MISC

Address: Operational Base + offset (0x00a4)

| Bit   | Attr | <b>Reset Value</b> | Description                                                      |
|-------|------|--------------------|------------------------------------------------------------------|
|       |      |                    | write_mask                                                       |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit        |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit     |
|       |      |                    | core_high_freq_rst_en                                            |
| 15:12 | RW   | 0x0                | 1'b0: disable high frequency reset function                      |
| 10112 |      |                    | 1'b1: enable high frequency reset function                       |
|       |      |                    | Each bit for each core, eg. bit0 for core0                       |
| 11:5  | RO   | 0x0                | reserved                                                         |
|       |      |                    | corepo_wrst_wfien                                                |
|       |      |                    | 1'b0: core0/1/2/3 power on reset is asserted immediately after   |
| 4     | RW   | 0x0                | warm reset request, it has no relation to STANDBYWFI status      |
| •     |      |                    | 1'b1: core0/1/2/3 power on reset is not asserted immediately     |
|       |      |                    | after warm reset request, it will wait until after entering      |
|       |      |                    | STANDBYWFI                                                       |
|       |      |                    | corepo_srst_wfien                                                |
|       |      | 0x0                | 1'b0: core0/1/2/3 power on reset is asserted immediately after   |
| 3     | RW   |                    | software reset request, it has no relation to STANDBYWFI status  |
|       |      |                    | 1'b1: core0/1/2/3 power on reset is not asserted immediately     |
|       |      |                    | after software reset request, it will wait until after entering  |
|       |      |                    | STANDBYWFI                                                       |
|       |      |                    | core_wrst_wfien                                                  |
| _     |      |                    | 1'b0: core0/1/2/3 reset is asserted immediately after warm reset |
| 2     | RW   | N 0x0              | request, it has no relation to STANDBYWFI status                 |
|       |      |                    | 1'b1: core0/1/2/3 reset is not asserted immediately after warm   |
|       |      |                    | reset request, it will wait until after entering STANDBYWFI      |
|       |      |                    | core_srst_wfien                                                  |
|       |      |                    | 1'b0: core0/1/2/3 reset is asserted immediately after software   |
| 1     | RW   | 0x0                | reset request, it has no relation to STANDBYWFI status           |
|       |      |                    | 1'b1: core0/1/2/3 reset is not asserted immediately after        |
|       |      |                    | software reset request, it will wait until after entering        |
|       |      |                    | STANDBYWFI                                                       |
| 0     |      |                    | warmrst_en                                                       |
| 0     | RW   | 0x0                | 1'b0: disable cpu warm reset                                     |
|       |      |                    | 1'b1: enable cpu warm reset                                      |

## CRU GLB CNT\_TH

Address: Operational Base + offset (0x00b0)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
|      |      |                    | global_reset_counter_threshold                                 |
| 31:0 | RW   | 0x00000000         | Global soft reset, wdt reset or tsadc_shut reset asserted time |
|      |      |                    | counter threshold. Measured in OSC clock cycles                |

#### CRU\_GLB\_RST\_ST

Address: Operational Base + offset (0x00b4)

| Bit   | Attr | <b>Reset Value</b> | Description                                                             |
|-------|------|--------------------|-------------------------------------------------------------------------|
| 31:24 | RO   | 0x0                | reserved                                                                |
| 23:20 | PO   | 0x0                | resetn_corepo_src_st                                                    |
| 23.20 | ĸŬ   | 0.00               | corepo resetn source status of core $0 \sim 3$ . Each bit for each core |
| 19:16 | RW   | 0x0                | resetn_core_src_st                                                      |
| 19.10 | 1    | 0.00               | core resetn source status of core0~3. Each bit for each core            |
| 15:6  | RO   | 0x0                | reserved                                                                |
|       | W1   |                    | snd_glb_tsadc_rst_st                                                    |
| 5     | C    | 0x0                | 1'b0: last hot reset is not sencond global TSADC triggered reset        |
|       | C    |                    | 1'b1: last hot reset is sencond global TSADC triggered reset            |
|       | W1   | 0x0                | fst_glb_tsadc_rst_st                                                    |
| 4     | C    |                    | 1'b0: last hot reset is not first global TSADC triggered reset          |
|       | C    |                    | 1'b1: last hot reset is first global TSADC triggered reset              |
|       | W1   | 0x0                | snd_glb_wdt_rst_st                                                      |
| 3     | C    |                    | 1'b0: last hot reset is not sencond global WDT triggered reset          |
|       | C    |                    | 1'b1: last hot reset is sencond global WDT triggered reset              |
|       | W1   | /1 0×0             | fst_glb_wdt_rst_st                                                      |
| 2     | C    |                    | 1'b0: last hot reset is not first global WDT triggered reset            |
|       | C    |                    | 1'b1: last hot reset is first global WDT triggered reset                |
|       | W1   |                    | snd_glb_rst_st                                                          |
| 1     | C    | 0x0                | 1'b0: last hot reset is not sencond global reset                        |
|       | C    |                    | 1'b1: last hot reset is sencond global reset                            |
|       | W1   |                    | fst_glb_rst_st                                                          |
| 0     | C    | 0x0                | 1'b0: last hot reset is not first global reset                          |
|       |      |                    | 1'b1: last hot reset is first global reset                              |

#### CRU GLB SRST FST

Address: Operational Base + offset (0x00b8)

| Bit   | Attr | <b>Reset Value</b> | Description                                  |
|-------|------|--------------------|----------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                     |
| 15:0  | RW   | 0x0000             | GLB_SRST_FST                                 |
| 15.0  | RVV  | 00000              | The first global software reset config value |

### CRU GLB SRST SND

Address: Operational Base + offset (0x00bc)

| Bit   | Attr | <b>Reset Value</b> | Description                                   |
|-------|------|--------------------|-----------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                      |
| 15.0  | RW   | N 10x0000          | GLB_SRST_SND                                  |
| 15:0  |      |                    | The second global software reset config value |

## CRU GLB RST CON

Address: Operational Base + offset (0x00c0)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
| 31:9 | RO   | 0x0                | reserved                                                       |
|      |      |                    | chiprstn_pd_sel                                                |
| 8    | RW   | 0x0                | 1'b0: chiprstn to power domain can be triggered by npor and    |
| 8    | RW   | UXU                | global soft reset                                              |
|      |      |                    | 1'b1: chiprstn to power domain can be triggered by npor only   |
|      |      |                    | wdt_reset_ext_en                                               |
| 7    | RW   | 0.40               | 1'b0: disable wdt reset extend                                 |
| /    | RVV  | 0x0                | 1'b1: enable wdt reset extend, reset extend time depend on     |
|      |      |                    | bit15~0 of GLB_CNT_TH                                          |
|      |      |                    | tsadc_shut_reset_ext_en                                        |
| 6    | RW   | 0x0                | 1'b0: disable tsadc_shut reset extend                          |
| 0    | r vv | UXU                | 1'b1: enable tsadc_shut reset extend, reset extend time depend |
|      |      |                    | on bit15~0 of GLB_CNT_TH                                       |
| 5    | RO   | 0x0                | reserved                                                       |
|      |      | 0×0                | pmu_srst_wdt_en                                                |
| 4    | RW   |                    | 1'b0: enable wdt reset as pmu reset source                     |
|      |      |                    | 1'b1: disable wdt reset as pmu reset source                    |
|      |      | 0x0                | pmu_srst_glb_rst_en                                            |
| 3    | RW   |                    | 1'b0: enable first or second global reset as pmu reset source  |
|      |      |                    | 1'b1: disable first or second global reset as pmu reset source |
|      |      |                    | pmu_srst_ctrl                                                  |
| 2    | RW   | W 0x0              | 1'b0: first global reset trigger pmu reset                     |
|      |      |                    | 1'b1: second global reset trigger pmu reset                    |
|      |      |                    | wdt_glb_srst_ctrl                                              |
| 1    | RW   | 0x0                | 1'b0: wdt trigger second global reset                          |
|      |      |                    | 1'b1: wdt trigger first global reset                           |
|      |      |                    | tsadc_glb_srst_ctrl                                            |
| 0    | RW   | 0x0                | 1'b0: tsadc trigger second global reset                        |
|      |      |                    | 1'b1: tsadc trigger first global reset                         |

## CRU\_GLB\_PLL\_LOCK

Address: Operational Base + offset (0x00c4)

| Bit   | Attr | <b>Reset Value</b> | Description                                    |
|-------|------|--------------------|------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                       |
| 15:0  | RW   | 0x3a98             | pll_lockperiod<br>Measured in OSC clock cycles |

#### **CRU HWFFC CON0**

Address: Operational Base + offset (0x00e0)

| Bit   | Attr | <b>Reset Value</b> | Description                                                   |
|-------|------|--------------------|---------------------------------------------------------------|
|       |      |                    | write_mask                                                    |
| 31:16 | RW   | 0x0000             | When every bit HIGH, enable the writing corresponding bit     |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit  |
| 15:10 | RO   | 0x0                | reserved                                                      |
|       |      |                    | hwffc_mode                                                    |
|       |      |                    | 1'b0: hwffc mode disable. Use APLL_CON0 and APLL_CON1 as      |
| 9     | RW   | 0x0                | APLL configurations                                           |
|       |      |                    | 1'b1: hwffc mode enable. Use APLL_CON0_S and APLL_CON1_S      |
|       |      |                    | as APLL configurations                                        |
|       |      | N 0x0              | hwffc_req                                                     |
| 8     | RW   |                    | 1'b0: indicate hwffc is done                                  |
| 0     |      |                    | 1'b1: set hwffc request or hwffc is on going, user should set |
|       |      |                    | hwffc_mode=1 first                                            |
|       |      | .W 0x0             | backuppll_sel                                                 |
|       |      |                    | 2'b00: reserved                                               |
| 7:6   | RW   |                    | 2'b01: select VPLL0 as backup pll for HWFFC                   |
|       |      |                    | 2'b10: select VPLL1 as backup pll for HWFFC                   |
|       |      |                    | 2'b11: reserved                                               |
| 5:4   | RO   | 0x0                | reserved                                                      |
| 3:0   | RW   | 0x0                | clk_core_div_con                                              |
| 5.0   | K VV | 0.00               | clk_core=pll_clk_src/(div_con+1)                              |

#### CRU\_HWFFC\_TH

Address: Operational Base + offset (0x00e8)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | RW   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 1     | RW   | W 0x03             | switch_th                                                    |
| 15:8  |      |                    | clock switch threshold cycle. Unit is pclk                   |
| 7.0   | RW   |                    | pll_pd_extend_th                                             |
| 7:0   |      |                    | pll pd extend time threshold cycle. Unit is pclk             |

## **CRU HWFFC INTSTS**

Address: Operational Base + offset (0x00ec)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | RW   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:9  | RO   | 0x0                | reserved                                                     |

| Bit | Attr | <b>Reset Value</b> | Description                              |  |                                      |
|-----|------|--------------------|------------------------------------------|--|--------------------------------------|
|     |      |                    | hwffc_done_inten                         |  |                                      |
| 8   | RW   | 0x0                | 1'b0: disable hwffc_done interrupt       |  |                                      |
|     |      |                    | 1'b1: enable hwffc_done interrupt        |  |                                      |
| 7   | RO   | 0x0                | reserved                                 |  |                                      |
|     |      |                    | hwffc_state                              |  |                                      |
|     |      |                    | 3'h0: hwffc_idle state                   |  |                                      |
|     |      | .W 0x0             | 3'h1: hwffc_2_backup_pll_mux state       |  |                                      |
|     |      |                    | 3'h2: hwffc_2_backup_pll_div state       |  |                                      |
| 6:4 | RW   |                    | 3'h3: hwffc_cfg_apll state               |  |                                      |
|     |      |                    | 3'h4: hwffc_back_apll_mux state          |  |                                      |
|     |      |                    | 3'h5: hwffc_back_apll_div_state          |  |                                      |
|     |      |                    | 3'h6: hwffc_done state                   |  |                                      |
|     |      |                    | others: reserved                         |  |                                      |
| 3:1 | RO   | 0x0                | reserved                                 |  |                                      |
|     | \A/1 |                    | hwffc_done                               |  |                                      |
| 0   | W1   | 0x0                | 1'b0: hwffc done interrupt not generated |  |                                      |
|     | C    | C                  | С                                        |  | 1'b1: hwffc done interrupt generated |

CRU APLL CONO S Address: Operational Base + offset (0x00f0)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                  |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                                                                                                     |
| 15    | RO   | 0×0                | bypass<br>REF is bypassed to FOUTPOSTDIV<br>1'b0: no bypass<br>1'b1: bypass                                                                  |
| 14:12 | RO   |                    | postdiv1<br>PLL post divide 1 setting, 1-7 is valid<br>postdiv1 should be greater than or equal to postdiv2                                  |
| 11:0  | RO   | 0x064              | fbdiv<br>PLL feedback divide value:<br>16-3200 is valid in integer mode<br>20-320 is valid in fractional mode<br>Tips: no plus one operation |

### CRU APLL CON1 S

Address: Operational Base + offset (0x00f4)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                                                                                                                   |
| 15    | RO   | 0x0                | pllpdsel<br>1'b0: PLL is power down when any one of refdiv/fbdiv/fracdiv is<br>changed or pllpd0 is asserted<br>1'b1: PLL can be power down only by pllpd1 |

| Bit | Attr | Reset Value | Description                                             |                                       |
|-----|------|-------------|---------------------------------------------------------|---------------------------------------|
|     |      |             | pllpd1                                                  |                                       |
| 14  | RO   | 0x0         | PLL power down 1 setting, it's valid when pllpdsel=1'b1 |                                       |
| 14  | ĸŪ   | 0.00        | 1'b0: no power down                                     |                                       |
|     |      |             | 1'b1: power down                                        |                                       |
|     |      |             | pllpd0                                                  |                                       |
| 13  | RO   | 0x0         | PLL power down 0 setting, it's valid when pllpdsel=1'b0 |                                       |
| 13  | κυ   | 0.00        | 1'b0: no power down                                     |                                       |
|     |      |             | 1'b1: power down                                        |                                       |
|     |      | 0x1         | dsmpd                                                   |                                       |
| 12  | RO   |             | Power down delta-sigma modulator                        |                                       |
| 12  | κυ   |             | 1'b0: no power down, PLL is fractional mode             |                                       |
|     |      |             | 1'b1: power down, PLL is integer mode                   |                                       |
| 11  | RO   | 0x0         | reserved                                                |                                       |
|     |      |             | pll_lock                                                |                                       |
| 10  | RO   | 0x0         | 1'b0: unlock                                            |                                       |
|     |      |             | 1'b1: lock                                              |                                       |
| 9   | RO   | 0x0         | reserved                                                |                                       |
| 8:6 | RO   | 0.1         | postdiv2                                                |                                       |
| 0:0 | ĸŪ   | 0x1         | PLL post divide 2 setting, 1-7 is valid                 |                                       |
| E.0 |      | 0×01        | refdiv                                                  |                                       |
| 5:0 | KU   | RO          | 0x01                                                    | Reference divide value, 1-63 is valid |

Address: Operational Base + offset (0x00f8)

| Bit   | Attr | <b>Reset Value</b> | Description                    |    |    |       |                                  |
|-------|------|--------------------|--------------------------------|----|----|-------|----------------------------------|
| 31:15 | RO   | 0x0                | reserved                       |    |    |       |                                  |
| 14:12 |      | 0.41               | aclk_core_div_con              |    |    |       |                                  |
| 14:12 | ĸŪ   | 0x1                | aclk_core=clk_core/(div_con+1) |    |    |       |                                  |
| 11:8  | RO   | 0x3                | core_dbg_div_con               |    |    |       |                                  |
| 11.0  | ĸŬ   | 0X3                | pclk_dbg=clk_core/(div_con+1)  |    |    |       |                                  |
|       |      |                    | core_clk_pll_sel               |    |    |       |                                  |
|       | RO   | 0×0                | 2'b00: APLL                    |    |    |       |                                  |
| 7:6   |      |                    | 2'b01: VPLL0                   |    |    |       |                                  |
|       |      |                    | 2'b10: VPLL1                   |    |    |       |                                  |
|       |      |                    | 2'b11: reserved                |    |    |       |                                  |
| 5:4   | RO   | 0x0                | reserved                       |    |    |       |                                  |
| 2.0   |      |                    | clk_core_div_con               |    |    |       |                                  |
| 3:0   | κU   | кU                 | кO                             | кU | RO | O 0x0 | clk_core=pll_clk_src/(div_con+1) |

## CRU CLKSEL CONO

Address: Operational Base + offset (0x0100)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                             |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000             | write_mask<br>When every bit HIGH, enable the writing corresponding bit<br>When every bit LOW, don't care the writing corresponding bit |
| 15    | RO   | 0x0                | reserved                                                                                                                                |
| 14:12 | RW   | 0x1                | aclk_core_div_con<br>aclk_core=clk_core/(div_con+1)                                                                                     |
| 11:8  | RW   | 0x3                | core_dbg_div_con<br>pclk_dbg=clk_core/(div_con+1)                                                                                       |
| 7:6   | RW   | 0×0                | core_clk_pll_sel<br>2'b00: APLL<br>2'b01: VPLL0<br>2'b10: VPLL1<br>2'b11: reserved                                                      |
| 5:4   | RO   | 0x0                | reserved                                                                                                                                |
| 3:0   | RW   | 0x0                | clk_core_div_con<br>clk_core=pll_clk_src/(div_con+1)                                                                                    |

Address: Operational Base + offset (0x0104)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:9  | RO   | 0x0                | reserved                                                     |
|       |      |                    | ddr_stdby_clk_sel                                            |
| 8     | RW   | 0x0                | 1'b0: select ddrphy_dfi_clk1x_out as clk_ddr_stdby clock     |
|       |      |                    | 1'b1: select ddr_phy_dfi_clk4x_div4 as clk_ddr_stdby clock   |
|       |      |                    | ddrphy_dfi_clk4x_pll_clk_sel                                 |
|       |      |                    | 2'b00: DPLL                                                  |
| 7:6   | RW   | 0x2                | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: VPLL1                                                 |
|       |      |                    | 2'b11: reserved                                              |
| 5:3   | RO   | 0x0                | reserved                                                     |
| 2.0   |      | 0×0                | ddrphy_dfi_clk4x_div_con                                     |
| 2:0   | RW   | 0x0                | ddrphy_dfi_clk4x=pll_clk_src/(div_con+1)                     |

## CRU\_CLKSEL\_CON2

Address: Operational Base + offset (0x0108)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:11 | RO   | 0x0                | reserved                                                     |

| Bit | Attr | <b>Reset Value</b> | Description                  |    |    |    |    |    |          |                                             |
|-----|------|--------------------|------------------------------|----|----|----|----|----|----------|---------------------------------------------|
|     |      |                    | clk_32k_pll_sel              |    |    |    |    |    |          |                                             |
| 10  | RW   | 0x0                | 1'b0: VPLL0                  |    |    |    |    |    |          |                                             |
|     |      |                    | 1'b1: VPLL1                  |    |    |    |    |    |          |                                             |
|     |      |                    | clk_32k_sel                  |    |    |    |    |    |          |                                             |
|     |      |                    | 2'b00: clk_32k_from_io       |    |    |    |    |    |          |                                             |
| 9:8 | RW   | 0x3                | 2'b01: clk_32k_from_pmu_pvtm |    |    |    |    |    |          |                                             |
|     |      |                    | 2'b10: clk_32k_frac_div      |    |    |    |    |    |          |                                             |
|     |      |                    | 2'b11: clk_32k_div           |    |    |    |    |    |          |                                             |
| 7:5 | RO   | 0x0                | reserved                     |    |    |    |    |    |          |                                             |
| 4.0 |      |                    | func_24m_div_con             |    |    |    |    |    |          |                                             |
| 4:0 | KVV  | KW                 | ΚW                           | КW | кw | КW | RW | RW | RW 10x00 | xin_osc0_func_div=xin_osc0_func/(div_con+1) |

Address: Operational Base + offset (0x010c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                |
|------|------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_32k_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is xin_osc0 |

#### CRU\_CLKSEL\_CON4

Address: Operational Base + offset (0x0110)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       | wo   | 0x0000             | write_mask                                                   |
| 31:16 |      |                    | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15.0  |      | 0                  | clk_32k_div_con                                              |
| 15:0  | RW   | W 0x7530           | clk_32k_div=clk_32k_src/(div_con+1)                          |

### CRU\_CLKSEL\_CON5

Address: Operational Base + offset (0x0114)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:8  | RO   | 0x0                | reserved                                                     |
|       |      |                    | aclk_hclk_pclk_bus_pll_sel                                   |
|       |      | / 0x0              | 2'b00: DPLL                                                  |
| 7:6   | RW   |                    | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: VPLL1                                                 |
|       |      |                    | 2'b11: reserved                                              |
| 5     | RO   | 0x0                | reserved                                                     |
| 4:0   | RW   | 0x05               | aclk_bus_div_con                                             |
| 4:0   | ĸw   | UXUS               | aclk_bus=pll_clk_src/(div_con+1)                             |

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                     |
| 12:8  |      | V 10x0b            | pclk_bus_div_con                                             |
| 12:0  | RW   |                    | pclk_bus=pll_clk_src/(div_con+1)                             |
| 7:5   | RO   | 0x0                | reserved                                                     |
| 4:0   |      |                    | hclk_bus_div_con                                             |
| 4:0   | RW   | 0x0b               | hclk_bus=pll_clk_src/(div_con+1)                             |

Address: Operational Base + offset (0x0118)

## CRU CLKSEL CON7

Address: Operational Base + offset (0x011c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_crypto_apk_sel                                           |
|       |      |                    | 2'b00: DPLL                                                  |
| 15:14 | RW   | 0x0                | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: VPLL1                                                 |
|       |      |                    | 2'b11: reserved                                              |
| 13    | RO   | 0x0                | reserved                                                     |
| 12:8  |      | 002                | clk_crypto_apk_div_con                                       |
| 12.0  | RW   | 0x03               | clk_crypto_apk=pll_clk_src/(div_con+1)                       |
|       |      |                    | clk_crypto_pll_sel                                           |
|       |      |                    | 2'b00: DPLL                                                  |
| 7:6   | RW   | 0x0                | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: VPLL1                                                 |
|       |      |                    | 2'b11: reserved                                              |
| 5     | RO   | 0x0                | reserved                                                     |
| 1.0   |      | 0.405              | clk_crypto_div_con                                           |
| 4:0   | RW   | 0x05               | clk_crypto=pll_clk_src/(div_con+1)                           |

#### CRU\_CLKSEL\_CON8

Address: Operational Base + offset (0x0120)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |

| Bit   | Attr | <b>Reset Value</b> | Description                      |
|-------|------|--------------------|----------------------------------|
|       |      |                    | dclk_vop_sel                     |
|       |      |                    | 2'b00: select dclk_vop           |
| 15:14 | RW   | 0x0                | 2'b01: select dclk_vop_frac_out  |
|       |      |                    | 2'b10: select xin_osc0           |
|       |      |                    | 2'b11: reserved                  |
| 13:12 | RO   | 0x0                | reserved                         |
|       |      |                    | dclk_vop_pll_sel                 |
|       | RW   | RW 0×0             | 2'b00: DPLL                      |
| 11:10 |      |                    | 2'b01: VPLL0                     |
|       |      |                    | 2'b10: VPLL1                     |
|       |      |                    | 2'b11: reserved                  |
| 9:8   | RO   | 0x0                | reserved                         |
| 7:0   | RW   | 0x07               | dclk_vop_div_con                 |
| 7.0   | K VV | 0.07               | dclk_vop=pll_clk_src/(div_con+1) |

Address: Operational Base + offset (0x0124)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                  |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   |                    | dclk_vop_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is dclk_vops |

#### CRU CLKSEL CON10

Address: Operational Base + offset (0x0128)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_uart0_pll_sel                                            |
|       |      |                    | 3'b000: DPLL                                                 |
|       |      |                    | 3'b001: VPLL0                                                |
| 15:13 | RW   | 0x0                | 3'b010: VPLL1                                                |
|       |      |                    | 3'b011: usbphy480m                                           |
|       |      |                    | 3'b100: xin_osc0                                             |
|       |      |                    | others: reserved                                             |
| 12:5  | RO   | 0x0                | reserved                                                     |
| 4.0   |      | Ovob               | clk_uart0_div_con                                            |
| 4:0   | RW   | 0x0b               | clk_uart0=pll_clk_src/(div_con+1)                            |

### CRU CLKSEL CON11

Address: Operational Base + offset (0x012c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_uart0_sel                                                |
|       |      |                    | 2'b00: select clk_uart0                                      |
| 15:14 | RW   | 0x0                | 2'b01: select clk_uart0_np5                                  |
|       |      |                    | 2'b10: select clk_uart0_frac_out                             |
|       |      |                    | 2'b11: reserved                                              |
| 13:5  | RO   | 0x0                | reserved                                                     |
| 4.0   |      | 0.40h              | clk_uart0_divnp5_div_con                                     |
| 4:0   | RW   | 0x0b               | clk_uart0_np5=2*clk_uart0/(2*div_con+3)                      |

Address: Operational Base + offset (0x0130)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                   |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_uart0_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_uart0 |

#### CRU CLKSEL CON13

Address: Operational Base + offset (0x0134)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_uart1_pll_sel                                            |
|       |      | 0×0                | 3'b000: DPLL                                                 |
|       |      |                    | 3'b001: VPLL0                                                |
| 15:13 | RW   |                    | 3'b010: VPLL1                                                |
|       |      |                    | 3'b011: usbphy480m                                           |
|       |      |                    | 3'b100: xin_osc0                                             |
|       |      |                    | others: reserved                                             |
| 12:5  | RO   | 0x0                | reserved                                                     |
| 4.0   |      | 004                | clk_uart1_div_con                                            |
| 4:0   | RW   | 0x0b               | clk_uart1=pll_clk_src/(div_con+1)                            |

## CRU\_CLKSEL\_CON14

Address: Operational Base + offset (0x0138)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |                                         |
|-------|------|--------------------|--------------------------------------------------------------|-----------------------------------------|
|       |      |                    | write_mask                                                   |                                         |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |                                         |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |                                         |
|       |      |                    | clk_uart1_sel                                                |                                         |
|       |      |                    | 2'b00: select clk_uart1                                      |                                         |
| 15:14 | RW   | 0x0                | 2'b01: select clk_uart1_np5                                  |                                         |
|       |      |                    | 2'b10: select clk_uart1_frac_out                             |                                         |
|       |      |                    | 2'b11: reserved                                              |                                         |
| 13:5  | RO   | 0x0                | reserved                                                     |                                         |
| 4.0   |      | 0.40h              | clk_uart1_divnp5_div_con                                     |                                         |
| 4:0   | KW   | RW                 | RW 0x0b                                                      | clk_uart1_np5=2*clk_uart1/(2*div_con+3) |

Address: Operational Base + offset (0x013c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                   |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_uart1_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_uart1 |

#### CRU CLKSEL CON16

Address: Operational Base + offset (0x0140)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_uart2_pll_sel                                            |
|       |      |                    | 3'b000: DPLL                                                 |
|       |      |                    | 3'b001: VPLL0                                                |
| 15:13 | RW   | 0x0                | 3'b010: VPLL1                                                |
|       |      |                    | 3'b011: usbphy480m                                           |
|       |      |                    | 3'b100: xin_osc0                                             |
|       |      |                    | others: reserved                                             |
| 12:5  | RO   | 0x0                | reserved                                                     |
| 1.0   |      | 001-               | clk_uart2_div_con                                            |
| 4:0   | RW   | 0x0b               | clk_uart2=pll_clk_src/(div_con+1)                            |

## CRU\_CLKSEL\_CON17

Address: Operational Base + offset (0x0144)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_uart2_sel                                                |
|       |      |                    | 2'b00: select clk_uart2                                      |
| 15:14 | RW   | 0x0                | 2'b01: select clk_uart2_np5                                  |
|       |      |                    | 2'b10: select clk_uart2_frac_out                             |
|       |      |                    | 2'b11: reserved                                              |
| 13:5  | RO   | 0x0                | reserved                                                     |
| 4:0   |      | 0.40h              | clk_uart2_divnp5_div_con                                     |
|       | KW   | RW                 | RW 0x0b                                                      |

Address: Operational Base + offset (0x0148)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                   |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_uart2_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_uart2 |

#### CRU CLKSEL CON19

Address: Operational Base + offset (0x014c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |                                   |
|-------|------|--------------------|--------------------------------------------------------------|-----------------------------------|
|       |      |                    | write_mask                                                   |                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |                                   |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |                                   |
|       |      |                    | clk_uart3_pll_sel                                            |                                   |
|       |      | W 0×0              | 3'b000: DPLL                                                 |                                   |
|       |      |                    | 3'b001: VPLL0                                                |                                   |
| 15:13 | RW   |                    | 3'b010: VPLL1                                                |                                   |
|       |      |                    | 3'b011: usbphy480m                                           |                                   |
|       |      |                    | 3'b100: xin_osc0                                             |                                   |
|       |      |                    | others: reserved                                             |                                   |
| 12:5  | RO   | 0x0                | reserved                                                     |                                   |
| 4.0   |      | 004                | clk_uart3_div_con                                            |                                   |
| 4:0   | KW   | RW                 | 0x0b                                                         | clk_uart3=pll_clk_src/(div_con+1) |

## CRU CLKSEL CON20

Address: Operational Base + offset (0x0150)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_uart3_sel                                                |
|       |      |                    | 2'b00: select clk_uart3                                      |
| 15:14 | RW   | 0x0                | 2'b01: select clk_uart3_np5                                  |
|       |      |                    | 2'b10: select clk_uart3_frac_out                             |
|       |      |                    | 2'b11: reserved                                              |
| 13:5  | RO   | 0x0                | reserved                                                     |
| 1.0   |      | 0.40h              | clk_uart3_divnp5_div_con                                     |
| 4:0   | RW   | 0x0b               | clk_uart3_np5=2*clk_uart3/(2*div_con+3)                      |

Address: Operational Base + offset (0x0154)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                   |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_uart3_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_uart3 |

#### CRU CLKSEL CON22

Address: Operational Base + offset (0x0158)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |                                   |
|-------|------|--------------------|--------------------------------------------------------------|-----------------------------------|
|       |      |                    | write_mask                                                   |                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |                                   |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |                                   |
|       |      |                    | clk_uart4_pll_sel                                            |                                   |
|       |      | W 0×0              | 3'b000: DPLL                                                 |                                   |
|       |      |                    | 3'b001: VPLL0                                                |                                   |
| 15:13 | RW   |                    | 3'b010: VPLL1                                                |                                   |
|       |      |                    | 3'b011: usbphy480m                                           |                                   |
|       |      |                    | 3'b100: xin_osc0                                             |                                   |
|       |      |                    | others: reserved                                             |                                   |
| 12:5  | RO   | 0x0                | reserved                                                     |                                   |
| 4.0   |      | 004                | clk_uart4_div_con                                            |                                   |
| 4:0   | КW   | RW                 | 0x0b                                                         | clk_uart4=pll_clk_src/(div_con+1) |

## CRU\_CLKSEL\_CON23

Address: Operational Base + offset (0x015c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_uart4_sel                                                |
|       |      |                    | 2'b00: select clk_uart4                                      |
| 15:14 | RW   | 0x0                | 2'b01: select clk_uart4_np5                                  |
|       |      |                    | 2'b10: select clk_uart4_frac_out                             |
|       |      |                    | 2'b11: reserved                                              |
| 13:5  | RO   | 0x0                | reserved                                                     |
| 4:0   |      | 0.40h              | clk_uart4_divnp5_div_con                                     |
|       | RW   | RW 0x0b            | clk_uart4_np5=2*clk_uart4/(2*div_con+3)                      |

Address: Operational Base + offset (0x0160)

| Bit  | Attr | Reset Value | Description                                                                                                   |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | clk_uart4_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_uart4 |

#### CRU CLKSEL CON25

Address: Operational Base + offset (0x0164)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_i2c0_pll_sel                                             |
|       |      |                    | 2'b00: DPLL                                                  |
| 15:14 | RW   | 0x0                | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 13:7  | RO   | 0x0                | reserved                                                     |
| 6.0   |      | 0.405              | clk_i2c0_div_con                                             |
| 6:0   | RW   | 0x05               | clk_i2c0=pll_clk_src/(div_con+1)                             |

#### CRU CLKSEL CON26

Address: Operational Base + offset (0x0168)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |

| Bit                 | Attr | <b>Reset Value</b> | Description                      |
|---------------------|------|--------------------|----------------------------------|
|                     |      | 0×0                | clk_i2c1_pll_sel                 |
|                     | RW   |                    | 2'b00: DPLL                      |
| 15:14               |      |                    | 2'b01: VPLL0                     |
|                     |      |                    | 2'b10: xin_osc0                  |
|                     |      |                    | 2'b11: reserved                  |
| 13:7                | RO   | 0x0                | reserved                         |
| <b>C</b> • <b>O</b> |      | W 10x05            | clk_i2c1_div_con                 |
| 6:0                 | RW   |                    | clk_i2c1=pll_clk_src/(div_con+1) |

Address: Operational Base + offset (0x016c)

| Bit                 | Attr | <b>Reset Value</b> | Description                                                  |
|---------------------|------|--------------------|--------------------------------------------------------------|
|                     |      |                    | write_mask                                                   |
| 31:16               | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|                     |      |                    | When every bit LOW, don't care the writing corresponding bit |
|                     |      | 0×0                | clk_i2c2_pll_sel                                             |
|                     |      |                    | 2'b00: DPLL                                                  |
| 15:14               | RW   |                    | 2'b01: VPLL0                                                 |
|                     |      |                    | 2'b10: xin_osc0                                              |
|                     |      |                    | 2'b11: reserved                                              |
| 13:7                | RO   | 0x0                | reserved                                                     |
| <b>C</b> · <b>O</b> |      | RW 0x05            | clk_i2c2_div_con                                             |
| 6:0                 | KVV  |                    | clk_i2c2=pll_clk_src/(div_con+1)                             |

#### **CRU CLKSEL CON28**

Address: Operational Base + offset (0x0170)

| Bit      | Attr | <b>Reset Value</b> | Description                                                  |
|----------|------|--------------------|--------------------------------------------------------------|
|          |      |                    | write_mask                                                   |
| 31:16    | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|          |      |                    | When every bit LOW, don't care the writing corresponding bit |
|          |      |                    | clk_i2c3_pll_sel                                             |
|          |      |                    | 2'b00: DPLL                                                  |
| 15:14    | RW   | 0x0                | 2'b01: VPLL0                                                 |
|          |      |                    | 2'b10: xin_osc0                                              |
|          |      |                    | 2'b11: reserved                                              |
| 13:7     | RO   | 0x0                | reserved                                                     |
| <u> </u> | RW   |                    | clk_i2c3_div_con                                             |
| 6:0      | κvv  | 0x05               | clk_i2c3=pll_clk_src/(div_con+1)                             |

#### CRU CLKSEL CON29

Address: Operational Base + offset (0x0174)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_pwm_pll_sel                                              |
|       |      | 0x0                | 2'b00: DPLL                                                  |
| 15:14 | RW   |                    | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 13:7  | RO   | 0x0                | reserved                                                     |
|       |      |                    | clk_pwm_div_con                                              |
| 6:0   | RW   | 0x0b               | clk_pwm=pll_clk_src/(div_con+1)                              |

Address: Operational Base + offset (0x0178)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_spi0_pll_sel                                             |
|       |      |                    | 2'b00: DPLL                                                  |
| 15:14 | RW   | 0x0                | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 13:7  | RO   | 0x0                | reserved                                                     |
| 6:0   | RW   |                    | clk_spi0_div_con                                             |
| 0.0   | ĸvv  | 0x0b               | clk_spi0=pll_clk_src/(div_con+1)                             |

#### CRU CLKSEL CON31

Address: Operational Base + offset (0x017c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_spi1_pll_sel                                             |
|       |      |                    | 2'b00: DPLL                                                  |
| 15:14 | RW   | 0x0                | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 13:7  | RO   | 0x0                | reserved                                                     |
| 6:0   | RW   | 0x0b               | clk_spi1_div_con                                             |
| 0.0   | ĸvv  | UXUD               | clk_spi1=pll_clk_src/(div_con+1)                             |

## CRU CLKSEL CON32

Address: Operational Base + offset (0x0180)

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_spi2_pll_sel                                             |
|       |      |                    | 2'b00: DPLL                                                  |
| 15:14 | RW   | 0x0                | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 13:7  | RO   | 0x0                | reserved                                                     |
| c.0   |      |                    | clk_spi2_div_con                                             |
| 6:0   | RW   | 0x0b               | clk_spi2=pll_clk_src/(div_con+1)                             |

Address: Operational Base + offset (0x0184)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:11 | RO   | 0x0                | reserved                                                     |
| 10.0  | RW   | 2W 10x001          | clk_tsadc_div_con                                            |
| 10:0  |      |                    | clk_tsadc=xin_osc0/(div_con+1)                               |

#### CRU\_CLKSEL\_CON34

Address: Operational Base + offset (0x0188)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:11 | RO   | 0x0                | reserved                                                     |
| 10:0  | RW   | 2W 10x017          | clk_saradc_div_con                                           |
|       |      |                    | clk_saradc=xin_osc0/(div_con+1)                              |

CRU\_CLKSEL\_CON35 Address: Operational Base + offset (0x018c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:6  | RO   | 0x0                | reserved                                                     |
| 5:4   | RW   | W 10x1             | clk_otp_usr_div_con                                          |
| 5:4   |      |                    | clk_otp_usr=clk_otp/(div_con+1)                              |
| 3:0   | RW   | W IOXO             | clk_otp_div_con                                              |
|       |      |                    | clk_otp=xin_osc0/(div_con+1)                                 |

Address: Operational Base + offset (0x0190)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:8  | RO   | 0x0                | reserved                                                     |
|       |      |                    | aclk_hclk_pclk_peri_pll_sel                                  |
|       |      |                    | 2'b00: DPLL                                                  |
| 7:6   | RW   | 0x0                | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: VPLL1                                                 |
|       |      |                    | 2'b11: reserved                                              |
| 5     | RO   | 0x0                | reserved                                                     |
| 1.0   |      |                    | aclk_peri_div_con                                            |
| 4:0   | RW   | W 0x05             | aclk_peri=pll_clk_src/(div_con+1)                            |

#### CRU CLKSEL CON37

Address: Operational Base + offset (0x0194)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                     |
| 12:8  | RW   | / 0x0b             | pclk_peri_div_con                                            |
| 12:8  | RW   |                    | pclk_peri=pll_clk_src/(div_con+1)                            |
| 7:5   | RO   | 0x0                | reserved                                                     |
| 4:0   |      | W IOXOD            | hclk_peri_div_con                                            |
| 4:0   | KW   |                    | hclk_peri=pll_clk_src/(div_con+1)                            |

#### CRU CLKSEL CON38

Address: Operational Base + offset (0x0198)

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
|       |      |                    | write_mask                                                      |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit       |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit    |
|       |      |                    | clk_nandc_sel50                                                 |
| 1 5   | RW   | 0x0                | 1'b0: The duty ratio of clk_nandc is 50% only when div_con+1 is |
| 15    |      |                    | even                                                            |
|       |      |                    | 1'b1: The duty ratio of clk_nandc is always 50%                 |
| 14:8  | RO   | 0x0                | reserved                                                        |
|       |      | RW 0x0             | clk_nandc_pll_sel                                               |
|       |      |                    | 2'b00: DPLL                                                     |
| 7:6   | RW   |                    | 2'b01: VPLL0                                                    |
|       |      |                    | 2'b10: VPLL1                                                    |
|       |      |                    | 2'b11: reserved                                                 |

| Bit | Attr | <b>Reset Value</b> | Description                       |
|-----|------|--------------------|-----------------------------------|
| 5   | RO   | 0x0                | reserved                          |
| 4:0 | RW   | 0x0/               | clk_nandc_div_con                 |
| 4:0 |      |                    | clk_nandc=pll_clk_src/(div_con+1) |

Address: Operational Base + offset (0x019c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_sdmmc_sel50                                              |
| 15    | עע   | 0.20               | 1'b0: The duty ratio of clk_sdmmc is 50% only when div_con+1 |
| 12    | RW   | 0x0                | is even                                                      |
|       |      |                    | 1'b1: The duty ratio of clk_sdmmc is always 50%              |
| 14:10 | RO   | 0x0                | reserved                                                     |
|       |      | V 0x0              | clk_sdmmc_pll_sel                                            |
|       |      |                    | 2'b00: DPLL                                                  |
| 9:8   | RW   |                    | 2'b01: VPLL0                                                 |
|       |      |                    | 2'b10: VPLL1                                                 |
|       |      |                    | 2'b11: xin_osc0                                              |
| 7:0   | RW   | 0,403              | clk_sdmmc_div_con                                            |
| 7.0   | K VV | W 0x03             | clk_sdmmc=pll_clk_src/(div_con+1)                            |

## CRU CLKSEL CON40

Address: Operational Base + offset (0x01a0)

| Bit   | Attr | <b>Reset Value</b> | Description                                                    |
|-------|------|--------------------|----------------------------------------------------------------|
|       |      |                    | write_mask                                                     |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit      |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit   |
|       |      |                    | clk_sdio_sel50                                                 |
| 1 5   |      | 0.40               | 1'b0: The duty ratio of clk_sdio is 50% only when div_con+1 is |
| 15    | RW   | 0×0                | even                                                           |
|       |      |                    | 1'b1: The duty ratio of clk_sdio is always 50%                 |
| 14:10 | RO   | 0x0                | reserved                                                       |
|       |      |                    | clk_sdio_pll_sel                                               |
|       |      |                    | 2'b00: DPLL                                                    |
| 9:8   | RW   |                    | 2'b01: VPLL0                                                   |
|       |      |                    | 2'b10: VPLL1                                                   |
|       |      |                    | 2'b11: xin_osc0                                                |
| 7:0   | RW   | 0.203              | clk_sdio_div_con                                               |
| 7.0   | r vv | V 0x03             | clk_sdio=pll_clk_src/(div_con+1)                               |

#### CRU CLKSEL CON41

Address: Operational Base + offset (0x01a4)

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

| Bit   | Attr | <b>Reset Value</b> | Description                                                    |
|-------|------|--------------------|----------------------------------------------------------------|
|       |      |                    | write_mask                                                     |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit      |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit   |
|       |      |                    | clk_emmc_sel50                                                 |
| 1 5   |      | 0.40               | 1'b0: The duty ratio of clk_emmc is 50% only when div_con+1 is |
| 15    | RW   | 0×0                | even                                                           |
|       |      |                    | 1'b1: The duty ratio of clk_emmc is always 50%                 |
| 14:10 | RO   | 0x0                | reserved                                                       |
|       |      | V 0×0              | clk_emmc_pll_sel                                               |
|       |      |                    | 2'b00: DPLL                                                    |
| 9:8   | RW   |                    | 2'b01: VPLL0                                                   |
|       |      |                    | 2'b10: VPLL1                                                   |
|       |      |                    | 2'b11: xin_osc0                                                |
| 7.0   |      | 0,40,2             | clk_emmc_div_con                                               |
| 7:0   | RW   | 0x03               | clk_emmc=pll_clk_src/(div_con+1)                               |

Address: Operational Base + offset (0x01a8)

| Bit                 | Attr | <b>Reset Value</b> | Description                                                  |
|---------------------|------|--------------------|--------------------------------------------------------------|
|                     |      |                    | write_mask                                                   |
| 31:16               | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|                     |      |                    | When every bit LOW, don't care the writing corresponding bit |
|                     |      | .W 0x1             | clk_sfc_pll_sel                                              |
| 15.14               | RW   |                    | 2'b00:DPLL                                                   |
| 15:14               |      |                    | 2'b01:VPLL0                                                  |
|                     |      |                    | 2'b10:VPLL1                                                  |
| 13:7                | RO   | 0x0                | reserved                                                     |
| <b>C</b> • <b>O</b> |      | 2W 10x04           | clk_sfc_div_con                                              |
| 6:0                 | KW   |                    | clk_sfc=pll_clk_src/(div_con+1)                              |

## CRU CLKSEL CON43

Address: Operational Base + offset (0x01ac)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | rmii_clk_sel                                                 |
| 15    | RW   | 0x1                | 1'b0: 10M                                                    |
|       |      |                    | 1'b1: 100M                                                   |
|       |      |                    | rmii_extclksrc_sel                                           |
| 14    | RW   | 0x0                | 1'b0: select clk_mac as the clock of mac                     |
|       |      |                    | 1'b1: select external phy clock as the clock of mac          |
| 13:8  | RO   | 0x0                | reserved                                                     |

| Bit | Attr | Reset Value | Description                     |
|-----|------|-------------|---------------------------------|
|     |      | 0x0         | clk_mac_pll_sel                 |
|     |      |             | 2'b00: DPLL                     |
| 7:6 | RW   |             | 2'b01: VPLL0                    |
|     |      |             | 2'b10: VPLL1                    |
|     |      |             | 2'b11: reserved                 |
| 5   | RO   | 0x0         | reserved                        |
| 4.0 |      | V  0x1/     | clk_mac_div_con                 |
| 4:0 | RW   |             | clk_mac=pll_clk_src/(div_con+1) |

Address: Operational Base + offset (0x01b0)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:8  | RO   | 0x0                | reserved                                                     |
|       |      |                    | clk_wifi_sel                                                 |
| 7     | RW   | 0x1                | 1'b0: select xin_osc0 as clk_wifi_out                        |
|       |      |                    | 1'b1: select clk_wifi_div as clk_wifi_out                    |
|       |      |                    | clk_wifi_pll_sel                                             |
| 6     | RW   | 0x0                | 1'b0: DPLL                                                   |
|       |      |                    | 1'b1: VPLLO                                                  |
| E.0   |      | 01.d               | clk_wifi_div_con                                             |
| 5:0   | RW   | 0x1d               | clk_wifi_div=pll_clk_src/(div_con+1)                         |

### CRU CLKSEL CON45

Address: Operational Base + offset (0x01b4)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                     |
| 17.0  |      | 0x09               | pclk_audio_div_con                                           |
| 12:8  | RW   |                    | pclk_audio=pll_clk_src/(div_con+1)                           |
|       |      |                    | hclk_pclk_audio_pll_sel                                      |
| 7:6   | RW   | 0x0                | 2'b00: VPLL0                                                 |
|       |      |                    | 2'b01: VPLL1                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 5     | RO   | 0x0                | reserved                                                     |
| 4:0   |      | 0,400              | hclk_audio_div_con                                           |
| 4:0   | RW   | W 0x09             | hclk_audio=pll_clk_src/(div_con+1)                           |

#### CRU CLKSEL CON46

Copyright 2018  $\odot$  FuZhou Rockchip Electronics Co., Ltd.

| Address: Operationa | l Base + offset ( | (0x01b8) | ) |
|---------------------|-------------------|----------|---|
|---------------------|-------------------|----------|---|

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_pdm_sel                                                  |
| 15    | RW   | 0x0                | 1'b0: select clk_pdm                                         |
|       |      |                    | 1'b1: select clk_pdm_frac_out                                |
| 14:10 | RO   | 0x0                | reserved                                                     |
|       |      |                    | clk_pdm_pll_sel                                              |
|       |      |                    | 2'b00: VPLL0                                                 |
| 9:8   | RW   | 0x0                | 2'b01: VPLL1                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 7     | RO   | 0x0                | reserved                                                     |
| c.0   |      | 0.405              | clk_pdm_div_con                                              |
| 6:0   | RW   | V 0x0f             | clk_pdm=pll_clk_src/(div_con+1)                              |

Address: Operational Base + offset (0x01bc)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                               |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_pdm_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_pdm |

#### CRU CLKSEL CON48

Address: Operational Base + offset (0x01c0)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
|       |      |                    | write_mask                                                        |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit         |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit      |
|       |      |                    | clk_spdiftx_sel                                                   |
| 1 1 4 |      | 0×0                | 2'b00: select clk_spdiftx                                         |
| 15:14 | ĸw   |                    | 2'b01: select clk_spdiftx_frac_out                                |
|       |      |                    | 2'b10: select mclk_from_io                                        |
| 13    | RO   | 0x0                | reserved                                                          |
|       |      | V 0×0              | clk_spdiftx_sel50                                                 |
| 10    |      |                    | 1'b0: The duty ratio of clk_spdiftx is 50% only when div_con+1 is |
| 12    | RW   |                    | even                                                              |
|       |      |                    | 1'b1: The duty ratio of clk_spdiftx is always 50%                 |
| 11:10 | RO   | 0x0                | reserved                                                          |

| Bit                 | Attr | <b>Reset Value</b> | Description                         |
|---------------------|------|--------------------|-------------------------------------|
|                     |      | 0×0                | clk_spdiftx_pll_sel                 |
|                     |      |                    | 2'b00: VPLL0                        |
| 9:8                 | RW   |                    | 2'b01: VPLL1                        |
|                     |      |                    | 2'b10: xin_osc0                     |
|                     |      |                    | 2'b11: reserved                     |
| 7                   | RO   | 0x0                | reserved                            |
| <b>C</b> • <b>O</b> |      |                    | clk_spdiftx_div_con                 |
| 6:0                 | ĸw   |                    | clk_spdiftx=pll_clk_src/(div_con+1) |

Address: Operational Base + offset (0x01c4)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                       |
|------|------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_spdiftx_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_spdiftx |

### **CRU CLKSEL CON50**

Address: Operational Base + offset (0x01c8)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                         |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | write_mask<br>When every bit HIGH, enable the writing corresponding bit<br>When every bit LOW, don't care the writing corresponding bit             |
| 15    | RW   | 0x0                | clk_spdifrx_sel<br>1'b0: select clk_spdifrx<br>1'b1: select clk_spdifrx_frac_out                                                                    |
| 14    | RW   | 0×0                | clk_spdifrx_sel50<br>1'b0: The duty ratio of clk_spdifrx is 50% only when div_con+1 is<br>even<br>1'b1: The duty ratio of clk_spdifrx is always 50% |
| 13:10 | RO   | 0x0                | reserved                                                                                                                                            |
| 9:8   | RW   | 0x0                | clk_spdifrx_pll_sel<br>2'b00: VPLL0<br>2'b01: VPLL1<br>2'b10: xin_osc0<br>2'b11: reserved                                                           |
| 7     | RO   | 0x0                | reserved                                                                                                                                            |
| 6:0   | RW   | 0x03               | clk_spdifrx_div_con<br>clk_spdifrx=pll_clk_src/(div_con+1)                                                                                          |

#### CRU CLKSEL CON51

Address: Operational Base + offset (0x01cc)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                       |
|------|------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_spdifrx_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_spdifrx |

Address: Operational Base + offset (0x01d0)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_i2s0_8ch_tx_out_mclk_sel                                 |
| 15    | RW   | 0x0                | 1'b0: select selected clock by clk_i2s0_8ch_tx_rx_clk_sel    |
|       |      |                    | 1'b1: select xin_osc0_half                                   |
| 14:13 | RO   | 0x0                | reserved                                                     |
|       |      |                    | clk_i2s0_8ch_tx_rx_clk_sel                                   |
| 12    | RW   | 0x0                | 1'b0: select clk_i2s0_8ch_tx_clk                             |
|       |      |                    | 1'b1: select clk_i2s0_8ch_rx_clk                             |
|       |      | W 0x0              | clk_i2s0_8ch_tx_sel                                          |
|       |      |                    | 2'b00: select clk_i2s0_8ch_tx                                |
| 11:10 | RW   |                    | 2'b01: select clk_i2s0_8ch_tx_frac_out                       |
|       |      |                    | 2'b10: select mclk_i2s0_8ch_tx_in                            |
|       |      |                    | 2'b11: reserved                                              |
|       |      |                    | clk_i2s0_8ch_tx_pll_sel                                      |
|       |      |                    | 2'b00: VPLL0                                                 |
| 9:8   | RW   | 0x1                | 2'b01: VPLL1                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 7     | RO   | 0x0                | reserved                                                     |
| 6:0   | RW   | 0x11               | clk_i2s0_8ch_tx_div_con                                      |
| 0.0   | K VV | 0711               | clk_i2s0_8ch_tx=pll_clk_src/(div_con+1)                      |

#### CRU\_CLKSEL\_CON53

Address: Operational Base + offset (0x01d4)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
|      |      |                    | clk_i2s0_8ch_tx_frac_div_con                                 |
| 31:0 | RW   | 0x00000000         | High 16-bit for numerator, Low 16-bit for denominator, clock |
|      |      |                    | source is clk_i2s0_8ch_tx                                    |

#### CRU CLKSEL CON54

Address: Operational Base + offset (0x01d8)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                     |
|       |      |                    | clk_i2s0_8ch_rx_tx_clk_sel                                   |
| 12    | RW   | 0x0                | 1'b0: select clk_i2s0_8ch_rx_clk                             |
|       |      |                    | 1'b1: select clk_i2s0_8ch_tx_clk                             |
|       |      |                    | clk_i2s0_8ch_rx_sel                                          |
|       |      |                    | 2'b00: select clk_i2s0_8ch_rx                                |
| 11:10 | RW   | 0x0                | 2'b01: select clk_i2s0_8ch_rx_frac_out                       |
|       |      |                    | 2'b10: select mclk_i2s0_8ch_rx_in                            |
|       |      |                    | 2'b11: reserved                                              |
|       |      |                    | clk_i2s0_8ch_rx_pll_sel                                      |
|       |      |                    | 2'b00: VPLL0                                                 |
| 9:8   | RW   | 0x0                | 2'b01: VPLL1                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 7     | RO   | 0x0                | reserved                                                     |
| 6:0   | RW   | 0x13               | clk_i2s0_8ch_rx_div_con                                      |
| 0.0   | K VV | 0X13               | clk_i2s0_8ch_rx=pll_clk_src/(div_con+1)                      |

CRU CLKSEL CON55 Address: Operational Base + offset (0x01dc)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                               |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_i2s0_8ch_rx_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk i2s0 8ch rx |

#### CRU CLKSEL CON56

Address: Operational Base + offset (0x01e0)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_i2s1_8ch_tx_out_mclk_sel                                 |
| 15    | RW   | 0x0                | 1'b0: select selected clock by clk_i2s1_8ch_tx_rx_clk_sel    |
|       |      |                    | 1'b1: select xin_osc0_half                                   |
| 14:13 | RO   | 0x0                | reserved                                                     |
|       |      |                    | clk_i2s1_8ch_tx_rx_clk_sel                                   |
| 12    | RW   | 0x0                | 1'b0: select clk_i2s1_8ch_tx_clk                             |
|       |      |                    | 1'b1: select clk_i2s1_8ch_rx_clk                             |

| Bit                 | Attr | Reset Value | Description                             |
|---------------------|------|-------------|-----------------------------------------|
|                     |      |             | clk_i2s1_8ch_tx_sel                     |
|                     |      |             | 2'b00: select clk_i2s1_8ch_tx           |
| 11:10               | RW   | 0×0         | 2'b01: select clk_i2s1_8ch_tx_frac_out  |
|                     |      |             | 2'b10: select mclk_i2s1_8ch_tx_in       |
|                     |      |             | 2'b11: reserved                         |
|                     | RW   | W 0x1       | clk_i2s1_8ch_tx_pll_sel                 |
|                     |      |             | 2'b00: VPLL0                            |
| 9:8                 |      |             | 2'b01: VPLL1                            |
|                     |      |             | 2'b10: xin_osc0                         |
|                     |      |             | 2'b11: reserved                         |
| 7                   | RO   | 0x0         | reserved                                |
| <b>C</b> • <b>O</b> |      | 0.44        | clk_i2s1_8ch_tx_div_con                 |
| 6:0                 | RW   | 0x11        | clk_i2s1_8ch_tx=pll_clk_src/(div_con+1) |

Address: Operational Base + offset (0x01e4)

| clk_i2s1_8ch_tx_frac_div_con | Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------------------------------|------|------|--------------------|--------------------------------------------------------------|
| source is clk i2s1 8ch tx    | 31:0 | RW   | 0x00000000         | High 16-bit for numerator, Low 16-bit for denominator, clock |

#### CRU CLKSEL CON58

Address: Operational Base + offset (0x01e8)

| Bit                 | Attr | <b>Reset Value</b> | Description                                                  |
|---------------------|------|--------------------|--------------------------------------------------------------|
|                     |      |                    | write_mask                                                   |
| 31:16               | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|                     |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13               | RO   | 0x0                | reserved                                                     |
|                     |      |                    | clk_i2s1_8ch_rx_tx_clk_sel                                   |
| 12                  | RW   | 0x0                | 1'b1: select clk_i2s1_8ch_rx_clk                             |
|                     |      |                    | 1'b1: select clk_i2s1_8ch_tx_clk                             |
|                     |      | 0×0                | clk_i2s1_8ch_rx_sel                                          |
|                     |      |                    | 2'b00: select clk_i2s1_8ch_rx                                |
| 11:10               | RW   |                    | 2'b01: select clk_i2s1_8ch_rx_frac_out                       |
|                     |      |                    | 2'b10: select mclk_i2s1_8ch_rx_in                            |
|                     |      |                    | 2'b11: reserved                                              |
|                     |      |                    | clk_i2s1_8ch_rx_pll_sel                                      |
|                     |      |                    | 2'b00: VPLL0                                                 |
| 9:8                 | RW   | 0x0                | 2'b01: VPLL1                                                 |
|                     |      |                    | 2'b10: xin_osc0                                              |
|                     |      |                    | 2'b11: reserved                                              |
| 7                   | RO   | 0x0                | reserved                                                     |
| <b>C</b> · <b>O</b> |      | 0.10               | clk_i2s1_8ch_rx_div_con                                      |
| 6:0                 | RW   | 0x13               | clk_i2s1_8ch_rx=pll_clk_src/(div_con+1)                      |

Address: Operational Base + offset (0x01ec)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                               |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_i2s1_8ch_rx_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk i2s1 8ch rx |

#### **CRU CLKSEL CON60**

Address: Operational Base + offset (0x01f0)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_i2s2_8ch_tx_out_mclk_sel                                 |
| 15    | RW   | 0x0                | 1'b0: select selected clock by clk_i2s2_8ch_tx_rx_clk_sel    |
|       |      |                    | 1'b1: select xin_osc0_half                                   |
| 14:13 | RO   | 0x0                | reserved                                                     |
|       |      |                    | clk_i2s2_8ch_tx_rx_clk_sel                                   |
| 12    | RW   | 0x0                | 1'b0: select clk_i2s2_8ch_tx_clk                             |
|       |      |                    | 1'b1: select clk_i2s2_8ch_rx_clk                             |
|       |      | 0×0                | clk_i2s2_8ch_tx_sel                                          |
|       |      |                    | 2'b00: select clk_i2s2_8ch_tx                                |
| 11:10 | RW   |                    | 2'b01: select clk_i2s2_8ch_tx_frac_out                       |
|       |      |                    | 2'b10: select mclk_i2s2_8ch_tx_in                            |
|       |      |                    | 2'b11: reserved                                              |
|       |      |                    | clk_i2s2_8ch_tx_pll_sel                                      |
|       |      |                    | 2'b00: VPLL0                                                 |
| 9:8   | RW   | 0x1                | 2'b01: VPLL1                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 7     | RO   | 0x0                | reserved                                                     |
| 6:0   | D\// | 0x11               | clk_i2s2_8ch_tx_div_con                                      |
| 0:0   | RW   | UXII               | clk_i2s2_8ch_tx=pll_clk_src/(div_con+1)                      |

#### CRU CLKSEL CON61

Address: Operational Base + offset (0x01f4)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
|      |      |                    | clk_i2s2_8ch_tx_frac_div_con                                 |
| 31:0 | RW   | 0x00000000         | High 16-bit for numerator, Low 16-bit for denominator, clock |
|      |      |                    | source is clk_i2s2_8ch_tx                                    |

#### CRU CLKSEL CON62

Address: Operational Base + offset (0x01f8)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                     |
|       |      |                    | clk_i2s2_8ch_rx_tx_clk_sel                                   |
| 12    | RW   | 0x0                | 1'b0: select clk_i2s2_8ch_rx_clk                             |
|       |      |                    | 1'b1: select clk_i2s2_8ch_tx_clk                             |
|       |      |                    | clk_i2s2_8ch_rx_sel                                          |
|       |      |                    | 2'b00: select clk_i2s2_8ch_rx                                |
| 11:10 | RW   | 0x0                | 2'b01: select clk_i2s2_8ch_rx_frac_out                       |
|       |      |                    | 2'b10: select mclk_i2s2_8ch_rx_in                            |
|       |      |                    | 2'b11: reserved                                              |
|       |      |                    | clk_i2s2_8ch_rx_pll_sel                                      |
|       |      |                    | 2'b00: VPLL0                                                 |
| 9:8   | RW   | 0x0                | 2'b01: VPLL1                                                 |
|       |      |                    | 2'b10: xin_osc0                                              |
|       |      |                    | 2'b11: reserved                                              |
| 7     | RO   | 0x0                | reserved                                                     |
| 6.0   |      | 0.10               | clk_i2s2_8ch_rx_div_con                                      |
| 6:0   | RW   | 0x13               | clk_i2s2_8ch_rx=pll_clk_src/(div_con+1)                      |

#### Address: Operational Base + offset (0x01fc)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                               |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_i2s2_8ch_rx_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_i2s2_8ch_rx |

#### **CRU CLKSEL CON64**

Address: Operational Base + offset (0x0200)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
|       |      |                    | clk_i2s3_8ch_tx_out_mclk_sel                                 |
| 15    | RW   | 0x0                | 1'b0: select selected clock by clk_i2s3_8ch_tx_rx_clk_sel    |
|       |      |                    | 1'b1: select xin_osc0_half                                   |
| 14:13 | RO   | 0x0                | reserved                                                     |
|       |      |                    | clk_i2s3_8ch_tx_rx_clk_sel                                   |
| 12    | RW   | 0x0                | 1'b0: select clk_i2s3_8ch_tx_clk                             |
|       |      |                    | 1'b1: select clk_i2s3_8ch_rx_clk                             |

| Bit                 | Attr | Reset Value | Description                            |      |                                         |
|---------------------|------|-------------|----------------------------------------|------|-----------------------------------------|
|                     |      |             | clk_i2s3_8ch_tx_sel                    |      |                                         |
|                     |      |             | 2'b00: select clk_i2s3_8ch_tx          |      |                                         |
| 11:10               | RW   | 0x0         | 2'b01: select clk_i2s3_8ch_tx_frac_out |      |                                         |
|                     |      |             | 2'b10: select mclk_i2s3_8ch_tx_in      |      |                                         |
|                     |      |             | 2'b11: reserved                        |      |                                         |
|                     |      |             | clk_i2s3_8ch_tx_pll_sel                |      |                                         |
|                     | RW   | W 0×1       | 2'b00: VPLL0                           |      |                                         |
| 9:8                 |      |             | 2'b01: VPLL1                           |      |                                         |
|                     |      |             | 2'b10: xin_osc0                        |      |                                         |
|                     |      |             | 2'b11: reserved                        |      |                                         |
| 7                   | RO   | 0x0         | reserved                               |      |                                         |
| <b>C</b> • <b>O</b> |      | 01.1        | clk_i2s3_8ch_tx_div_con                |      |                                         |
| 6:0                 | KW   | RW          | RW                                     | 0x11 | clk_i2s3_8ch_tx=pll_clk_src/(div_con+1) |

Address: Operational Base + offset (0x0204)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                               |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_i2s3_8ch_tx_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_i2s3_8ch_tx |

### CRU CLKSEL CON66

Address: Operational Base + offset (0x0208)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |                                         |
|-------|------|--------------------|--------------------------------------------------------------|-----------------------------------------|
|       |      |                    | write_mask                                                   |                                         |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |                                         |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |                                         |
| 15:13 | RO   | 0x0                | reserved                                                     |                                         |
|       |      |                    | clk_i2s3_8ch_rx_tx_clk_sel                                   |                                         |
| 12    | RW   | 0x0                | 1'b0: select clk_i2s3_8ch_rx_clk                             |                                         |
|       |      |                    | 1'b1: select clk_i2s3_8ch_tx_clk                             |                                         |
|       |      |                    | clk_i2s3_8ch_rx_sel                                          |                                         |
|       |      | 0×0                | 2'b00: select clk_i2s3_8ch_rx                                |                                         |
| 11:10 | RW   |                    | 2'b01: select clk_i2s3_8ch_rx_frac_out                       |                                         |
|       |      |                    | 2'b10: select mclk_i2s3_8ch_rx_in                            |                                         |
|       |      |                    | 2'b11: reserved                                              |                                         |
|       |      |                    | clk_i2s3_8ch_rx_pll_sel                                      |                                         |
|       |      |                    | 2'b00: VPLL0                                                 |                                         |
| 9:8   | RW   | 0x0                | 2'b01: VPLL1                                                 |                                         |
|       |      |                    | 2'b10: xin_osc0                                              |                                         |
|       |      |                    | 2'b11: reserved                                              |                                         |
| 7     | RO   | 0x0                | reserved                                                     |                                         |
| 6:0   |      | 0x13               | clk_i2s3_8ch_rx_div_con                                      |                                         |
| 0.0   | RW   | KW                 | 0110                                                         | clk_i2s3_8ch_rx=pll_clk_src/(div_con+1) |

Address: Operational Base + offset (0x020c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                               |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_i2s3_8ch_rx_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_i2s3_8ch_rx |

#### **CRU CLKSEL CON68**

Address: Operational Base + offset (0x0210)

| Bit   | Attr  | <b>Reset Value</b> | Description                                                  |
|-------|-------|--------------------|--------------------------------------------------------------|
|       |       |                    | write_mask                                                   |
| 31:16 | WO    | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |       |                    | When every bit LOW, don't care the writing corresponding bit |
|       |       |                    | clk_i2s0_2ch_out_mclk_sel                                    |
| 15    | RW    | 0x0                | 1'b0: select selected clock by clk_i2s0_2ch_sel              |
|       |       |                    | 1'b1: select xin_osc0_half                                   |
| 14:12 | RO    | 0x0                | reserved                                                     |
|       |       |                    | clk_i2s0_2ch_sel                                             |
|       |       |                    | 2'b00: select clk_i2s0_2ch                                   |
| 11:10 | RW    | 0x0                | 2'b01: select clk_i2s0_2ch_frac_out                          |
|       |       |                    | 2'b10: select mclk_i2s0_2ch_in                               |
|       |       |                    | 2'b11: reserved                                              |
|       |       |                    | clk_i2s0_2ch_pll_sel                                         |
|       |       |                    | 2'b00: VPLL0                                                 |
| 9:8   | RW    | 0x0                | 2'b01: VPLL1                                                 |
|       |       |                    | 2'b10: xin_osc0                                              |
|       |       |                    | 2'b11: reserved                                              |
| 7     | RO    | 0x0                | reserved                                                     |
| 6:0   | RW    | 0x13               | clk_i2s0_2ch_div_con                                         |
| 0.0   | K V V | C170               | clk_i2s0_2ch=pll_clk_src/(div_con+1)                         |

### **CRU CLKSEL CON69**

Address: Operational Base + offset (0x0214)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
|      |      |                    | clk_i2s0_2ch_frac_div_con                                    |
| 31:0 | RW   | 0x00000000         | High 16-bit for numerator, Low 16-bit for denominator, clock |
|      |      |                    | source is clk_i2s0_2ch                                       |

#### CRU CLKSEL CON70

Address: Operational Base + offset (0x0218)

| Bit   | Attr    | <b>Reset Value</b> | Description                                                  |
|-------|---------|--------------------|--------------------------------------------------------------|
|       |         |                    | write_mask                                                   |
| 31:16 | WO      | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |         |                    | When every bit LOW, don't care the writing corresponding bit |
|       |         |                    | clk_i2s1_2ch_out_mclk_sel                                    |
| 15    | RW      | 0x0                | 1'b0: select selected clock by clk_i2s1_2ch_sel              |
|       |         |                    | 1'b1: select xin_osc0_half                                   |
| 14:12 | RO      | 0x0                | reserved                                                     |
|       |         |                    | clk_i2s1_2ch_sel                                             |
|       |         |                    | 2'b00: select clk_i2s1_2ch                                   |
| 11:10 | RW      | 0x0                | 2'b01: select clk_i2s1_2ch_frac_out                          |
|       |         |                    | 2'b10: select mclk_i2s1_2ch_in                               |
|       |         |                    | 2'b11: reserved                                              |
|       |         |                    | clk_i2s1_2ch_pll_sel                                         |
|       |         |                    | 2'b00: VPLL0                                                 |
| 9:8   | RW      | 0x0                | 2'b01: VPLL1                                                 |
|       |         |                    | 2'b10: xin_osc0                                              |
|       |         |                    | 2'b11: reserved                                              |
| 7     | RO      | 0x0                | reserved                                                     |
| 6:0   | RW      | 0x13               | clk_i2s1_2ch_div_con                                         |
| 0.0   | F\$ V V | 0712               | clk_i2s1_2ch=pll_clk_src/(div_con+1)                         |

Address: Operational Base + offset (0x021c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                         |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | clk_i2s1_2ch_frac_div_con<br>High 16-bit for numerator, Low 16-bit for denominator, clock<br>source is clk_i2s1_2ch |

#### CRU CLKSEL CON72

Address: Operational Base + offset (0x0220)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:8  | RO   | 0x0                | reserved                                                     |
|       |      |                    | usbphy_ref_sel                                               |
| 7     | RW   | 0x0                | 1'b0: select xin_osc0 as usbphy reference clock              |
|       |      |                    | 1'b1: select clk_ref24m as usbphy reference clock            |
|       |      |                    | clk_ref24m_pll_sel                                           |
| 6     | RW   | 0x0                | 1'b0: DPLL                                                   |
|       |      |                    | 1'b1: VPLLO                                                  |
| E.0   |      | 0.21               | clk_ref24m_div_con                                           |
| 5:0   | RW   | 0x31               | clk_ref24m=pll_clk_src/(div_con+1)                           |

Address: Operational Base + offset (0x0224)

| Bit   |    | Reset Value | + offset (0x0224) Description                                |
|-------|----|-------------|--------------------------------------------------------------|
|       |    |             | write_mask                                                   |
| 31:16 | WO | 0x0000      | When every bit HIGH, enable the writing corresponding bit    |
|       |    |             | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO | 0x0         | reserved                                                     |
|       |    |             | testclk_sel                                                  |
|       |    |             | 5'h00: xin_osc0                                              |
|       |    |             | 5'h01: clk_core                                              |
|       |    |             | 5'h02: clk_ddrphy4x                                          |
|       |    |             | 5'h03: clk_ddrphy1x                                          |
|       |    |             | 5'h04: aclk_peri                                             |
|       |    |             | 5'h05: hclk_peri                                             |
|       |    |             | 5'h06: clk_nandc                                             |
|       |    |             | 5'h07: clk_sdmmc                                             |
|       |    |             | 5'h08: clk_sdio                                              |
|       |    |             | 5'h09: clk_emmc                                              |
|       |    |             | 5'h0a: clk_sfc                                               |
|       |    |             | 5'h0b: clk_mac_ref                                           |
|       |    |             | 5'h0c: aclk_bus                                              |
|       |    |             | 5'h0d: hclk_bus                                              |
|       |    | 0x00        | 5'h0e: clk_crypto                                            |
| 12:8  | RW |             | 5'h0f: clk_crypto_apk                                        |
|       |    |             | 5'h10: dclk_vop                                              |
|       |    |             | 5'h11: clk_uart0                                             |
|       |    |             | 5'h12: clk_i2c0                                              |
|       |    |             | 5'h13: clk_spi0                                              |
|       |    |             | 5'h14: clk_tsadc                                             |
|       |    |             | 5'h15: clk_saradc                                            |
|       |    |             | 5'h16: clk_otp                                               |
|       |    |             | 5'h17: hclk_audio                                            |
|       |    |             | 5'h18: clk_pdm<br>5'h19: clk_spdifrx                         |
|       |    |             | 5'h1a: clk_i2s0_8ch_tx                                       |
|       |    |             | $5'h1b: clk_i2s0_8ch_rx$                                     |
|       |    |             | 5'h1c: clk_i2s0_2ch                                          |
|       |    |             | 5'h1d: clk_rtc32k                                            |
|       |    |             | 5'h1e: clk_usbphy_ref24m                                     |
|       |    |             | 5'h1f: otp_isp_osc_out                                       |
| 7:5   | RO | 0x0         | reserved                                                     |
| /.5   |    |             | test_div_con                                                 |
| 4:0   | RW | 0x1f        | clk_test_out=test_clk_src/(div_con+1)                        |
|       |    |             |                                                              |

#### CRU\_CLKGATE\_CON0

Address: Operational Base + offset (0x0300)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                             |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | write_mask<br>When every bit HIGH, enable the writing corresponding bit<br>When every bit LOW, don't care the writing corresponding bit |
| 15:14 | RO   | 0x0                | reserved                                                                                                                                |
| 13    | RW   | 0x0                | ddr_phy_dfi_clk4x_div4_clk_en<br>When HIGH, disable clock                                                                               |
| 12    | RW   | 0×0                | ddr_monitor_timer_clk_en<br>When HIGH, disable clock                                                                                    |
| 11    | RW   | 0×0                | ddr_phy_dfi_clk4x_en<br>When HIGH, disable clock                                                                                        |
| 10    | RW   | 0×0                | ddr_phy_pll_clk_en<br>When HIGH, disable clock                                                                                          |
| 9     | RW   | 0x0                | pclk_core_grf_clk_en<br>When HIGH, disable clock                                                                                        |
| 8     | RW   | 0x0                | aclk_core_perf_clk_en<br>When HIGH, disable clock                                                                                       |
| 7     | RW   | 0x0                | pclk_core_dbg_daplite_clk_en<br>When HIGH, disable clock                                                                                |
| 6     | RW   | 0x0                | pclk_core_dbg_niu_clk_en<br>When HIGH, disable clock                                                                                    |
| 5     | RW   | 0x0                | aclk_core_niu_clk_en<br>When HIGH, disable clock                                                                                        |
| 4     | RW   | 0x0                | clk_core_pvtm_clk_en<br>When HIGH, disable clock                                                                                        |
| 3     | RW   | 0x0                | clk_jtag_core_clk_en<br>When HIGH, disable clock                                                                                        |
| 2     | RW   | 0x0                | pclk_core_dbg_src_clk_en<br>When HIGH, disable clock                                                                                    |
| 1     | RW   | 0x0                | aclk_core_src_clk_en<br>When HIGH, disable clock                                                                                        |
| 0     | RW   | 0x0                | core_pll_clk_en<br>When HIGH, disable clock                                                                                             |

CRU\_CLKGATE\_CON1 Address: Operational Base + offset (0x0304)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 1 5   |      | 1 0.0              | clk_uart1_divfrac_clk_en                                     |
| 15    | RW   | 0x0                | When HIGH, disable clock                                     |
| 14    | RW   | M/ 00              | clk_uart1_divnp5_clk_en                                      |
| 14    |      | 0x0                | When HIGH, disable clock                                     |

| Bit | Attr | <b>Reset Value</b> | Description                                           |
|-----|------|--------------------|-------------------------------------------------------|
| 13  | RW   | 0x0                | clk_uart1_pll_clk_en<br>When HIGH, disable clock      |
| 12  | RW   | 0x0                | clk_uart0_clk_en<br>When HIGH, disable clock          |
| 11  | RW   | 0x0                | clk_uart0_divfrac_clk_en<br>When HIGH, disable clock  |
| 10  | RW   | 0x0                | clk_uart0_divnp5_clk_en<br>When HIGH, disable clock   |
| 9   | RW   | 0x0                | clk_uart0_pll_clk_en<br>When HIGH, disable clock      |
| 8   | RW   | 0x0                | dclkvop_clk_en<br>When HIGH, disable clock            |
| 7   | RW   | 0x0                | dclkvop_fracdiv_clk_en<br>When HIGH, disable clock    |
| 6   | RW   | 0x0                | dclkvop_pll_clk_en<br>When HIGH, disable clock        |
| 5   | RW   | 0x0                | clk_crypto_apk_pll_clk_en<br>When HIGH, disable clock |
| 4   | RW   | 0x0                | clk_crypto_pll_clk_en<br>When HIGH, disable clock     |
| 3   | RW   | 0x0                | pclk_bus_clk_en<br>When HIGH, disable clock           |
| 2   | RW   | 0x0                | hclk_bus_clk_en<br>When HIGH, disable clock           |
| 1   | RW   | 0x0                | aclk_bus_clk_en<br>When HIGH, disable clock           |
| 0   | RW   | 0x0                | logic_bus_pll_clk_en<br>When HIGH, disable clock      |

# CRU CLKGATE CON2

Address: Operational Base + offset (0x0308)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15    |      | V 0×0              | clk_i2c2_pll_clk_en                                          |
| 15    | RW   |                    | When HIGH, disable clock                                     |
| 14    | RW   | W 0×0              | clk_i2c1_pll_clk_en                                          |
| 14    | RVV  |                    | When HIGH, disable clock                                     |
| 13    | RW   | W/ 00              | clk_i2c0_pll_clk_en                                          |
| 13    | RVV  | 0x0                | When HIGH, disable clock                                     |
| 10    | DW   | V ()x()            | clk_uart4_clk_en                                             |
| 12    | RW   |                    | When HIGH, disable clock                                     |

| Bit      | Attr | Reset Value | Description              |  |  |
|----------|------|-------------|--------------------------|--|--|
| 11       | RW   | 0x0         | clk_uart4_divfrac_clk_en |  |  |
|          |      | 0.00        | When HIGH, disable clock |  |  |
| 10       | RW   | 0x0         | clk_uart4_divnp5_clk_en  |  |  |
| 10       |      | 0.00        | When HIGH, disable clock |  |  |
| 9        | RW   | 0x0         | clk_uart4_pll_clk_en     |  |  |
| 5        |      | 0.00        | When HIGH, disable clock |  |  |
| 8        | RW   | 0x0         | clk_uart3_clk_en         |  |  |
| 0        |      | 0,0         | When HIGH, disable clock |  |  |
| 7        | RW   | 0x0         | clk_uart3_divfrac_clk_en |  |  |
| <i>'</i> |      | 0.00        | When HIGH, disable clock |  |  |
| 6        | RW   | 0×0         | clk_uart3_divnp5_clk_en  |  |  |
| Ŭ        |      |             | When HIGH, disable clock |  |  |
| 5        | RW   | W 0×0       | clk_uart3_pll_clk_en     |  |  |
| 5        |      |             | When HIGH, disable clock |  |  |
| 4        | RW   | 0x0         | clk_uart2_clk_en         |  |  |
| •        |      | 1           |                          |  |  |
| 3        | RW   | 0x0         | clk_uart2_divfrac_clk_en |  |  |
| -        |      |             | When HIGH, disable clock |  |  |
| 2        | RW   | 0x0         | clk_uart2_divnp5_clk_en  |  |  |
| _        |      |             | When HIGH, disable clock |  |  |
| 1        | RW   | 0x0         | clk_uart2_pll_clk_en     |  |  |
|          |      |             | When HIGH, disable clock |  |  |
| 0        | RW   | W 0×0       | clk_uart1_clk_en         |  |  |
| -        |      |             | When HIGH, disable clock |  |  |

**<u>CRU\_CLKGATE\_CON3</u>** Address: Operational Base + offset (0x030c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15    | RW   | 0x0                | clk_timer5_en                                                |
| 15    | ĸw   | 0.00               | When HIGH, disable clock                                     |
| 14    | RW   | 0x0                | clk_timer4_en                                                |
| 14    | ĸw   |                    | When HIGH, disable clock                                     |
| 13    |      | 0×0                | clk_timer3_en                                                |
| 13    | RW   |                    | When HIGH, disable clock                                     |
| 12    | RW   | W 0×0              | clk_timer2_en                                                |
| 12    |      |                    | When HIGH, disable clock                                     |
| 11    |      | 0.20               | clk_timer1_en                                                |
| 11    | RW   | 0x0                | When HIGH, disable clock                                     |
| 10    | RW   | 0.20               | clk_timer0_en                                                |
| 10    | KVV  | RW 0x0             | When HIGH, disable clock                                     |

| Bit | Attr | <b>Reset Value</b> | Description                                       |
|-----|------|--------------------|---------------------------------------------------|
| 9   | RW   | 0x0                | clk_cpu_boost_clk_en<br>When HIGH, disable clock  |
| 8   | RW   | 0x0                | clk_otp_usr_clk_en<br>When HIGH, disable clock    |
| 7   | RW   | 0x0                | clk_otp_pll_clk_en<br>When HIGH, disable clock    |
| 6   | RW   | 0x0                | clk_saradc_pll_clk_en<br>When HIGH, disable clock |
| 5   | RW   | 0x0                | clk_tsadc_pll_clk_en<br>When HIGH, disable clock  |
| 4   | RW   | 0x0                | clk_spi2_pll_clk_en<br>When HIGH, disable clock   |
| 3   | RW   | 0x0                | clk_spi1_pll_clk_en<br>When HIGH, disable clock   |
| 2   | RW   | 0x0                | clk_spi0_pll_clk_en<br>When HIGH, disable clock   |
| 1   | RW   | 0x0                | clk_pwm_pll_clk_en<br>When HIGH, disable clock    |
| 0   | RW   | 0x0                | clk_i2c3_pll_clk_en<br>When HIGH, disable clock   |

# CRU CLKGATE CON4

Address: Operational Base + offset (0x0310)

| Bit   | Attr | <b>Reset Value</b> | Description                                                    |
|-------|------|--------------------|----------------------------------------------------------------|
|       |      |                    | write_mask                                                     |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit      |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit   |
| 15    | RO   | 0x0                | reserved                                                       |
| 14    | אום  | 0.40               | clk_ddr_stdby_en                                               |
| 14    | RW   | 0x0                | When HIGH, disable clock                                       |
| 13    | RW   | 0.20               | clk_ddr_msch_peri_en                                           |
| 13    | K VV | 0x0                | When HIGH, disable clock, and cannot access the peripheral bus |
| 12    |      | 0x0                | clk_ddr_msch_en                                                |
| 12    | RW   |                    | When HIGH, disable clock                                       |
| 11    | RW   | / 0x0              | clk_ddr_upctrl_en                                              |
| 11    | RW   |                    | When HIGH, disable clock                                       |
| 10    |      | W 0x0              | clk_ddr_mon_en                                                 |
| 10    |      |                    | When HIGH, disable clock                                       |
| 9     | RW   | 0x0                | testclk_en                                                     |
| 9     | ĸw   | 0.00               | When HIGH, disable clock                                       |
| 8     | אים  | 0.40               | usbphy_ref24m_clk_en                                           |
| 0     | RW   | 0x0                | When HIGH, disable clock                                       |
| 7     |      | 0.20               | clk_ref24m_pll_clk_en                                          |
| 7     | RW   | RW 0x0             | When HIGH, disable clock                                       |

| Bit | Attr | Reset Value | Description                                            |
|-----|------|-------------|--------------------------------------------------------|
| 6   | RW   | 0x0         | clk_pmu_clk_en<br>When HIGH, disable clock             |
| 5   | RW   | 0x0         | pclk_pmu_clk_en<br>When HIGH, disable clock            |
| 4   | RW   | 0x0         | clk_pmu_pvtm_clk_en<br>When HIGH, disable clock        |
| 3   | RW   | 0x0         | clk_div32k_frac_out_clk_en<br>When HIGH, disable clock |
| 2   | RW   | 0x0         | clk_div32k_out_clk_en<br>When HIGH, disable clock      |
| 1   | RW   | 0x0         | clk_wifi_clk_en<br>When HIGH, disable clock            |
| 0   | RW   | 0x0         | clk_wifi_pll_clk_en<br>When HIGH, disable clock        |

CRU CLKGATE CON5 Address: Operational Base + offset (0x0314)

| Bit   | Attr | Reset Value | Description                                                  |
|-------|------|-------------|--------------------------------------------------------------|
|       |      |             | write_mask                                                   |
| 31:16 | WO   | 0x0000      | When every bit HIGH, enable the writing corresponding bit    |
|       |      |             | When every bit LOW, don't care the writing corresponding bit |
| 15    | RW   | 0x0         | pclk_i2c0_en                                                 |
| 15    | RW   | 0x0         | When HIGH, disable clock                                     |
| 14    | RW   | 0x0         | pclk_uart4_en                                                |
| 14    | ĸw   | 0.00        | When HIGH, disable clock                                     |
| 13    | RW   | 0x0         | pclk_uart3_en                                                |
| 13    |      | 0.00        | When HIGH, disable clock                                     |
| 12    | RW   | 0x0         | pclk_uart2_en                                                |
| 12    | ĸw   | 0.00        | When HIGH, disable clock                                     |
| 11    | RW   | 0×0         | pclk_uart1_en                                                |
| 11    |      |             | When HIGH, disable clock                                     |
| 10    | RW   | 0×0         | pclk_uart0_en                                                |
| 10    |      |             | When HIGH, disable clock                                     |
| 9     | RW   | V 0×0       | pclk_bus_niu_en                                              |
| 9     | 1    |             | When HIGH, disable clock                                     |
| 8     | RW   | 0x0         | hclk_vop_en                                                  |
| 0     | 1    |             | When HIGH, disable clock                                     |
| 7     | RW   | 0x0         | hclk_crypto_en                                               |
| /     | 1    | 0.00        | When HIGH, disable clock                                     |
| 6     | RW   | 0x0         | hclk_rom_en                                                  |
| 0     | 1    |             | When HIGH, disable clock                                     |
| 5     | RW   | 0x0         | hclk_bus_niu_en                                              |
| J     |      |             | When HIGH, disable clock                                     |

| Bit | Attr | <b>Reset Value</b> | Description              |
|-----|------|--------------------|--------------------------|
| 4   | RW   | / 0x0              | aclk_gic_en              |
| 4   |      | 0.00               | When HIGH, disable clock |
| 3   | RW   | 0.20               | aclk_vop_en              |
| 2   | RVV  | 0x0                | When HIGH, disable clock |
| 2   |      | XW 0x0             | aclk_crypto_en           |
| Z   | RW   |                    | When HIGH, disable clock |
| 1   |      | RW 0x0             | aclk_intmem_en           |
| 1   | RW   |                    | When HIGH, disable clock |
| 0   |      | W 0.0              | aclk_bus_niu_en          |
| U   | RW   | 0x0                | When HIGH, disable clock |

CRU CLKGATE CON6 Address: Operational Base + offset (0x0318)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                             |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | write_mask<br>When every bit HIGH, enable the writing corresponding bit<br>When every bit LOW, don't care the writing corresponding bit |
| 15    | RW   | 0x0                | pclk_gpio3_en<br>When HIGH, disable clock                                                                                               |
| 14    | RW   | 0x0                | pclk_gpio2_en<br>When HIGH, disable clock                                                                                               |
| 13    | RW   | 0×0                | pclk_gpio1_en<br>When HIGH, disable clock                                                                                               |
| 12    | RW   | 0×0                | pclk_gpio0_en<br>When HIGH, disable clock                                                                                               |
| 11    | RO   | 0x0                | reserved                                                                                                                                |
| 10    | RW   | 0×0                | pclk_otp_ns_en<br>When HIGH, disable clock                                                                                              |
| 9     | RW   | 0x0                | pclk_timer_en<br>When HIGH, disable clock                                                                                               |
| 8     | RW   | 0x0                | pclk_tsadc_en<br>When HIGH, disable clock                                                                                               |
| 7     | RW   | 0x0                | pclk_saradc_en<br>When HIGH, disable clock                                                                                              |
| 6     | RW   | 0x0                | pclk_spi2_en<br>When HIGH, disable clock                                                                                                |
| 5     | RW   | 0x0                | pclk_spi1_en<br>When HIGH, disable clock                                                                                                |
| 4     | RW   | 0x0                | pclk_spi0_en<br>When HIGH, disable clock                                                                                                |
| 3     | RW   | 0x0                | pclk_pwm_en<br>When HIGH, disable clock                                                                                                 |
| 2     | RW   | 0x0                | pclk_i2c3_en<br>When HIGH, disable clock                                                                                                |

| Bit | Attr | <b>Reset Value</b> | Description                              |
|-----|------|--------------------|------------------------------------------|
| 1   | RW   | ()x()              | pclk_i2c2_en<br>When HIGH, disable clock |
| 0   | RW   | 0x0                | pclk_i2c1_en<br>When HIGH, disable clock |

### CRU CLKGATE CON7

Address: Operational Base + offset (0x031c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:12 | RO   | 0x0                | reserved                                                     |
| 11    | RW   | 0x0                | pclk_cpu_boost_en                                            |
| 11    | ĸw   | 0.00               | When HIGH, disable clock                                     |
| 10    | RW   | 0x0                | pclk_otp_phy_en                                              |
| 10    | ĸw   | 0.00               | When HIGH, disable clock                                     |
| 9     | RW   | 0x0                | pclk_cru_en                                                  |
| 9     | RVV  | UXU                | When HIGH, disable clock                                     |
| 8     | RW   | 0.40               | pclk_usbgrf_en                                               |
| 0     | RW   | 0x0                | When HIGH, disable clock                                     |
| 7     | RW   | 0x0                | pclk_ddr_stdby_en                                            |
| /     | ĸw   |                    | When HIGH, disable clock                                     |
| 6     | RW   | 0x0                | pclk_ddr_phy_en                                              |
| 0     | r vv |                    | When HIGH, disable clock                                     |
| 5     | RW   | 0x0                | pclk_ddr_mon_en                                              |
| 5     | r vv | 0.00               | When HIGH, disable clock                                     |
| 4     | RW   | 0×0                | pclk_ddr_upctrl_en                                           |
| 4     |      |                    | When HIGH, disable clock                                     |
| 3     | RW   | 0x0                | pclk_usbsdmmc_det_en                                         |
| 5     | r vv | 0.00               | When HIGH, disable clock                                     |
| 2     | RW   | 0x0                | pclk_grf_en                                                  |
| 2     |      | 0.00               | When HIGH, disable clock                                     |
| 1     | RW   | 0x0                | pclk_sgrf_en                                                 |
| 1     | r vv | 0.00               | When HIGH, disable clock                                     |
| 0     | RW   | 0~0                | pclk_gpio4_en                                                |
| 0     | 1    | 0x0                | When HIGH, disable clock                                     |

### CRU CLKGATE CON8

Address: Operational Base + offset (0x0320)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15    | RO   | 0x0                | reserved                                                     |

| Bit | Attr | <b>Reset Value</b> | Description                                       |
|-----|------|--------------------|---------------------------------------------------|
| 14  | RW   | 0x0                | clk_mac_pll_clk_en<br>When HIGH, disable clock    |
| 13  | RW   | 0×0                | clk_otg_adp_clk_en<br>When HIGH, disable clock    |
| 12  | RW   | 0x0                | clk_sfc_pll_clk_en<br>When HIGH, disable clock    |
| 11  | RW   | 0x0                | clk_emmc_clk_en<br>When HIGH, disable clock       |
| 10  | RW   | 0x0                | clk_emmc_pll_clk_en<br>When HIGH, disable clock   |
| 9   | RW   | 0x0                | clk_sdio_clk_en<br>When HIGH, disable clock       |
| 8   | RW   | 0x0                | clk_sdio_pll_clk_en<br>When HIGH, disable clock   |
| 7   | RW   | 0x0                | clk_sdmmc_clk_en<br>When HIGH, disable clock      |
| 6   | RW   | 0x0                | clk_sdmmc_pll_clk_en<br>When HIGH, disable clock  |
| 5   | RW   | 0x0                | clk_nandc_clk_en<br>When HIGH, disable clock      |
| 4   | RW   | 0x0                | clk_nandc_pll_clk_en<br>When HIGH, disable clock  |
| 3   | RW   | 0x0                | pclk_peri_clk_en<br>When HIGH, disable clock      |
| 2   | RW   | 0x0                | hclk_peri_clk_en<br>When HIGH, disable clock      |
| 1   | RW   | 0x0                | aclk_peri_clk_en<br>When HIGH, disable clock      |
| 0   | RW   | 0×0                | logic_peri_pll_clk_en<br>When HIGH, disable clock |

# CRU CLKGATE CON9

Address: Operational Base + offset (0x0324)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15    | RW   | 0×0                | pclk_mac_en                                                  |
| 15    | RVV  |                    | When HIGH, disable clock                                     |
| 14    |      |                    | pclk_peri_niu_en                                             |
| 14    | RW   | 0x0                | When HIGH, disable clock                                     |
| 1 2   |      |                    | hclk_host_arb_en                                             |
| 13    | RW   | 0x0                | When HIGH, disable clock                                     |

| Bit | Attr | Reset Value | Description                                     |
|-----|------|-------------|-------------------------------------------------|
| 12  | RW   | 0x0         | hclk_host_en<br>When HIGH, disable clock        |
| 11  | RW   | 0x0         | hclk_otg_en<br>When HIGH, disable clock         |
| 10  | RW   | 0x0         | hclk_sfc_en<br>When HIGH, disable clock         |
| 9   | RW   | 0×0         | hclk_emmc_en<br>When HIGH, disable clock        |
| 8   | RW   | 0x0         | hclk_sdio_en<br>When HIGH, disable clock        |
| 7   | RW   | 0x0         | hclk_sdmmc_en<br>When HIGH, disable clock       |
| 6   | RW   | 0x0         | hclk_nanc_en<br>When HIGH, disable clock        |
| 5   | RW   | 0x0         | hclk_peri_niu_en<br>When HIGH, disable clock    |
| 4   | RW   | 0x0         | aclk_mac_en<br>When HIGH, disable clock         |
| 3   | RW   | 0x0         | aclk_peribus_niu_en<br>When HIGH, disable clock |
| 2   | RW   | 0x0         | aclk_peri_niu_en<br>When HIGH, disable clock    |
| 1   | RW   | 0x0         | clk_mac_ref_en<br>When HIGH, disable clock      |
| 0   | RW   | 0x0         | clk_mac_txrx_en<br>When HIGH, disable clock     |

CRU CLKGATE CON10 Address: Operational Base + offset (0x0328)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |                          |
|-------|------|--------------------|--------------------------------------------------------------|--------------------------|
|       |      |                    | write_mask                                                   |                          |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |                          |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |                          |
| 15    | RW   | 0x0                | clk_i2s0_8ch_tx_out_clk_en                                   |                          |
| 13    |      | 0x0                | When HIGH, disable clock                                     |                          |
| 14    |      | 0x0                | clk_i2s0_8ch_tx_clk_en                                       |                          |
| 14    | RW   |                    | When HIGH, disable clock                                     |                          |
| 13    | RW   | N 0.0              | clk_i2s0_8ch_tx_divfrac_clk_en                               |                          |
| 13    | RW   | 0x0                | When HIGH, disable clock                                     |                          |
| 12    |      | RW 0x0             | clk_i2s0_8ch_tx_pll_clk_en                                   |                          |
|       | RVV  |                    | When HIGH, disable clock                                     |                          |
| 1 1   |      | 0x0                | clk_spdifrx_clk_en                                           |                          |
| 11    | KVV  | RW                 | UXU                                                          | When HIGH, disable clock |

| Bit | Attr | <b>Reset Value</b> | Description                                            |
|-----|------|--------------------|--------------------------------------------------------|
| 10  | RW   | 0x0                | clk_spdifrx_divfrac_clk_en<br>When HIGH, disable clock |
| 9   | RW   | 0x0                | clk_spdifrx_pll_clk_en<br>When HIGH, disable clock     |
| 8   | RW   | 0x0                | clk_spdiftx_clk_en<br>When HIGH, disable clock         |
| 7   | RW   | 0x0                | clk_spdiftx_divfrac_clk_en<br>When HIGH, disable clock |
| 6   | RW   | 0x0                | clk_spdiftx_pll_clk_en<br>When HIGH, disable clock     |
| 5   | RW   | 0x0                | clk_pdm_clk_en<br>When HIGH, disable clock             |
| 4   | RW   | 0x0                | clk_pdm_divfrac_clk_en<br>When HIGH, disable clock     |
| 3   | RW   | 0x0                | clk_pdm_pll_clk_en<br>When HIGH, disable clock         |
| 2   | RW   | 0x0                | pclk_audio_clk_en<br>When HIGH, disable clock          |
| 1   | RW   | 0x0                | hclk_audio_clk_en<br>When HIGH, disable clock          |
| 0   | RW   | 0x0                | logic_audio_pll_clk_en<br>When HIGH, disable clock     |

# CRU\_CLKGATE\_CON11

Address: Operational Base + offset (0x032c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15    | RW   | 0x0                | clk_i2s2_8ch_tx_out_clk_en                                   |
| 15    | RVV  | 0.00               | When HIGH, disable clock                                     |
| 14    |      | 0.40               | clk_i2s2_8ch_tx_clk_en                                       |
| 14    | RW   | 0x0                | When HIGH, disable clock                                     |
| 13    | RW   | 0x0                | clk_i2s2_8ch_tx_divfrac_clk_en                               |
| 12    | ĸw   |                    | When HIGH, disable clock                                     |
| 12    |      | W 0x0              | clk_i2s2_8ch_tx_pll_clk_en                                   |
| 12    | RW   |                    | When HIGH, disable clock                                     |
| 11    |      | M 0.0              | clk_i2s1_8ch_rx_out_clk_en                                   |
| 11    | RW   | 0x0                | When HIGH, disable clock                                     |
| 10    | RW   | 0.40               | clk_i2s1_8ch_rx_clk_en                                       |
| 10    | RW   | 0x0                | When HIGH, disable clock                                     |
| 9     | RW   | 0.20               | clk_i2s1_8ch_rx_divfrac_clk_en                               |
| 9     | ĸw   | 0x0                | When HIGH, disable clock                                     |

| Bit | Attr | <b>Reset Value</b> | Description                    |  |                          |
|-----|------|--------------------|--------------------------------|--|--------------------------|
| 8   | RW   | 0x0                | clk_i2s1_8ch_rx_pll_clk_en     |  |                          |
| 0   | ĸw   | 0.00               | When HIGH, disable clock       |  |                          |
| 7   | RW   | 0x0                | clk_i2s1_8ch_tx_out_clk_en     |  |                          |
| /   | RW   | 0.00               | When HIGH, disable clock       |  |                          |
| 6   | RW   | 0x0                | clk_i2s1_8ch_tx_clk_en         |  |                          |
| 0   | RW   | 0.00               | When HIGH, disable clock       |  |                          |
| 5   |      | N 0x0              | clk_i2s1_8ch_tx_divfrac_clk_en |  |                          |
| 5   | RW   |                    | When HIGH, disable clock       |  |                          |
| 4   | RW   | 0×0                | clk_i2s1_8ch_tx_pll_clk_en     |  |                          |
| 4   | ĸw   |                    | When HIGH, disable clock       |  |                          |
| 3   | RW   | 0x0                | clk_i2s0_8ch_rx_out_clk_en     |  |                          |
| 5   | RVV  | r vv               |                                |  | When HIGH, disable clock |
| 2   | RW   | 0x0                | clk_i2s0_8ch_rx_clk_en         |  |                          |
| Z   | ĸw   | 0.00               | When HIGH, disable clock       |  |                          |
| 1   | RW   | 0x0                | clk_i2s0_8ch_rx_divfrac_clk_en |  |                          |
| T   | ĸw   | 0.00               | When HIGH, disable clock       |  |                          |
| 0   | DW/  | 0x0                | clk_i2s0_8ch_rx_pll_clk_en     |  |                          |
| 0   | RW   |                    | When HIGH, disable clock       |  |                          |

# CRU CLKGATE CON12

Address: Operational Base + offset (0x0330)

| Bit   | Attr  | <b>Reset Value</b> | Description                                                  |
|-------|-------|--------------------|--------------------------------------------------------------|
|       |       |                    | write_mask                                                   |
| 31:16 | WO    | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |       |                    | When every bit LOW, don't care the writing corresponding bit |
| 15    | RW    | 0x0                | clk_i2s0_2ch_out_clk_en                                      |
| 13    | r vv  | 0.00               | When HIGH, disable clock                                     |
| 14    | RW    | 0x0                | clk_i2s0_2ch_clk_en                                          |
| 14    | K VV  | 0.00               | When HIGH, disable clock                                     |
| 13    | RW    | 0.20               | clk_i2s0_2ch_divfrac_clk_en                                  |
| 15    | K VV  | 0x0                | When HIGH, disable clock                                     |
| 12    | RW    | 0×0                | clk_i2s0_2ch_pll_clk_en                                      |
| 12    |       |                    | When HIGH, disable clock                                     |
| 11    | RW    | W 0×0              | clk_i2s3_8ch_rx_out_clk_en                                   |
| 11    | r vv  |                    | When HIGH, disable clock                                     |
| 10    | RW    | 0x0                | clk_i2s3_8ch_rx_clk_en                                       |
| 10    | RW    | 0.00               | When HIGH, disable clock                                     |
| 9     | RW    | 0x0                | clk_i2s3_8ch_rx_divfrac_clk_en                               |
| 9     | K VV  | 0.00               | When HIGH, disable clock                                     |
| 8     | RW    | 00                 | clk_i2s3_8ch_rx_pll_clk_en                                   |
| 0     | r. vv | 0x0                | When HIGH, disable clock                                     |
| 7     |       | 0x0                | clk_i2s3_8ch_tx_out_clk_en                                   |
| /     | RW    | 0.0                | When HIGH, disable clock                                     |

| Bit | Attr | Reset Value | Description                    |                          |                          |
|-----|------|-------------|--------------------------------|--------------------------|--------------------------|
| 6   | RW   | 0x0         | clk_i2s3_8ch_tx_clk_en         |                          |                          |
| 0   |      | 0.00        | When HIGH, disable clock       |                          |                          |
| 5   | RW   | 0x0         | clk_i2s3_8ch_tx_divfrac_clk_en |                          |                          |
| 5   | ĸw   | 0.00        | When HIGH, disable clock       |                          |                          |
| 4   |      | W 0x0       | clk_i2s3_8ch_tx_pll_clk_en     |                          |                          |
| 4   | ĸw   |             | When HIGH, disable clock       |                          |                          |
| 3   |      | W 0x0       | clk_i2s2_8ch_rx_out_clk_en     |                          |                          |
| 5   | RW   |             | When HIGH, disable clock       |                          |                          |
| 2   | RW   | W 0x0       | clk_i2s2_8ch_rx_clk_en         |                          |                          |
| Z   | RVV  | RW          | RVV                            |                          | When HIGH, disable clock |
| 1   |      |             | clk_i2s2_8ch_rx_divfrac_clk_en |                          |                          |
| 1   | RW   | 0x0         | When HIGH, disable clock       |                          |                          |
| 0   |      | 0.20        | clk_i2s2_8ch_rx_pll_clk_en     |                          |                          |
| 0   | RW   | RW          | 0x0                            | When HIGH, disable clock |                          |

**<u>CRU</u>** CLKGATE CON13 Address: Operational Base + offset (0x0334)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | wo   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:9  | RO   | 0x0                | reserved                                                     |
|       |      |                    | clk_i2s0_2ch_out_ioe                                         |
| 8     | RW   | 0x0                | 1'b0: enable clk_i2s0_2ch_out to PAD MCLK                    |
|       |      |                    | 1'b1: disable clk_i2s0_2ch_out to PAD MCLK                   |
|       |      |                    | clk_i2s1_8ch_rx_out_ioe                                      |
| 7     | RW   | 0x0                | 1'b0: enable clk_i2s1_8ch_rx_out to PAD MCLK                 |
|       |      |                    | 1'b1: disable clk_i2s1_8ch_rx_out to PAD MCLK                |
|       |      |                    | clk_i2s1_8ch_tx_out_ioe                                      |
| 6     | RW   | 0x0                | 1'b0: enable clk_i2s1_8ch_tx_out to PAD MCLK                 |
|       |      |                    | 1'b1: disable clk_i2s1_8ch_tx_out to PAD MCLK                |
|       |      |                    | clk_i2s0_8ch_rx_out_ioe                                      |
| 5     | RW   | 0x0                | 1'b0: enable clk_i2s0_8ch_rx_out to PAD MCLK                 |
|       |      |                    | 1'b1: disable clk_i2s0_8ch_rx_out to PAD MCLK                |
|       |      |                    | clk_i2s0_8ch_tx_out_ioe                                      |
| 4     | RW   | 0x0                | 1'b0: enable clk_i2s0_8ch_tx_out to PAD MCLK                 |
|       |      |                    | 1'b1: disable clk_i2s0_8ch_tx_out to PAD MCLK                |
| 3     | RW   | 0x0                | clk_i2s1_2ch_out_clk_en                                      |
| 5     |      | 0.00               | When HIGH, disable clock                                     |
| 2     | RW   | 0x0                | clk_i2s1_2ch_clk_en                                          |
| ۷     |      | 0.0                | When HIGH, disable clock                                     |
| 1     | RW   | 0x0                | clk_i2s1_2ch_divfrac_clk_en                                  |
| Ŧ     |      | 0.0                | When HIGH, disable clock                                     |

| Bit | Attr | <b>Reset Value</b> | Description                                         |
|-----|------|--------------------|-----------------------------------------------------|
| 0   | RW   | ()X()              | clk_i2s1_2ch_pll_clk_en<br>When HIGH, disable clock |

#### CRU CLKGATE CON14

Address: Operational Base + offset (0x0338)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                             |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000             | write_mask<br>When every bit HIGH, enable the writing corresponding bit<br>When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                                                                                                |
| 12    | RW   | 0×0                | pclk_acodec_en<br>When HIGH, disable clock                                                                                              |
| 11    | RW   | 0×0                | pclk_audio_niu_en<br>When HIGH, disable clock                                                                                           |
| 10    | RW   | 0x0                | hclk_vad_en<br>When HIGH, disable clock                                                                                                 |
| 9     | RW   | 0x0                | hclk_i2s1_2ch_en<br>When HIGH, disable clock                                                                                            |
| 8     | RW   | 0x0                | hclk_i2s0_2ch_en<br>When HIGH, disable clock                                                                                            |
| 7     | RW   | 0x0                | hclk_i2s3_8ch_en<br>When HIGH, disable clock                                                                                            |
| 6     | RW   | 0x0                | hclk_i2s2_8ch_en<br>When HIGH, disable clock                                                                                            |
| 5     | RW   | 0x0                | hclk_i2s1_8ch_en<br>When HIGH, disable clock                                                                                            |
| 4     | RW   | 0x0                | hclk_i2s0_8ch_en<br>When HIGH, disable clock                                                                                            |
| 3     | RW   | 0x0                | hclk_spdifrx_en<br>When HIGH, disable clock                                                                                             |
| 2     | RW   | 0x0                | hclk_spdiftx_en<br>When HIGH, disable clock                                                                                             |
| 1     | RW   | 0x0                | hclk_pdm_en<br>When HIGH, disable clock                                                                                                 |
| 0     | RW   | 0×0                | hclk_audio_niu_en<br>When HIGH, disable clock                                                                                           |

# CRU\_SSCGTBL0\_3

Address: Operational Base + offset (0x0380)

| Bit  | Attr | <b>Reset Value</b> | Description   |
|------|------|--------------------|---------------|
|      |      |                    | sscgtbl0_3    |
|      |      |                    | 7-0: table0   |
| 31:0 | WO   | 0x00000000         | 15-8: table1  |
|      |      |                    | 23-16: table2 |
|      |      |                    | 31-24: table3 |

### CRU\_SSCGTBL4\_7

Address: Operational Base + offset (0x0384)

| Bit  | Attr | <b>Reset Value</b> | Description   |
|------|------|--------------------|---------------|
|      |      |                    | sscgtbl4_7    |
|      |      |                    | 7-0: table4   |
| 31:0 | WO   | 0x00000000         | 15-8: table5  |
|      |      |                    | 23-16: table6 |
|      |      |                    | 31-24: table7 |

### CRU\_SSCGTBL8\_11

Address: Operational Base + offset (0x0388)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl8_11    |
|      |      |                    | 7-0: table8    |
| 31:0 | WO   | 0x00000000         | 15-8: table9   |
|      |      |                    | 23-16: table10 |
|      |      |                    | 31-24: table11 |

# CRU SSCGTBL12 15

|      | Address: Operational Base + offset (0x038c) |                    |                                  |  |  |
|------|---------------------------------------------|--------------------|----------------------------------|--|--|
|      | T                                           | <b>Reset Value</b> | Description                      |  |  |
|      |                                             |                    | sscgtbl12_15<br>7-0: table12     |  |  |
| 31:0 | WO                                          | 0x00000000         | 15-8: table13                    |  |  |
|      |                                             |                    | 23-16: table14<br>31-24: table15 |  |  |

### CRU\_SSCGTBL16\_19

Address: Operational Base + offset (0x0390)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl16_19   |
|      |      |                    | 7-0: table16   |
| 31:0 | WO   | 0x00000000         | 15-8: table17  |
|      |      |                    | 23-16: table18 |
|      |      |                    | 31-24: table19 |

### CRU\_SSCGTBL20\_23

#### Address: Operational Base + offset (0x0394)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl20_23   |
|      |      |                    | 7-0: table20   |
| 31:0 | WO   | 0x00000000         | 15-8: table21  |
|      |      |                    | 23-16: table22 |
|      |      |                    | 31-24: table23 |

#### CRU SSCGTBL24 27

Address: Operational Base + offset (0x0398)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl24_27   |
|      |      |                    | 7-0: table24   |
| 31:0 | WO   | 0x00000000         | 15-8: table25  |
|      |      |                    | 23-16: table26 |
|      |      |                    | 31-24: table27 |

### CRU\_SSCGTBL28\_31

Address: Operational Base + offset (0x039c)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl28_31   |
|      |      |                    | 7-0: table28   |
| 31:0 | WO   | 0x00000000         | 15-8: table29  |
|      |      |                    | 23-16: table30 |
|      |      |                    | 31-24: table31 |

### CRU SSCGTBL32 35

Address: Operational Base + offset (0x03a0)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl32_35   |
|      |      |                    | 7-0: table32   |
| 31:0 | WO   | 0x00000000         | 15-8: table33  |
|      |      |                    | 23-16: table34 |
|      |      |                    | 31-24: table35 |

### CRU\_SSCGTBL36\_39

Address: Operational Base + offset (0x03a4)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl36_39   |
|      |      |                    | 7-0: table36   |
| 31:0 | WO   | 0x00000000         | 15-8: table37  |
|      |      |                    | 23-16: table38 |
|      |      |                    | 31-24: table39 |

### CRU\_SSCGTBL40\_43

Address: Operational Base + offset (0x03a8)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl40_43   |
|      |      |                    | 7-0: table40   |
| 31:0 | WO   | 0x00000000         | 15-8: table41  |
|      |      |                    | 23-16: table42 |
|      |      |                    | 31-24: table43 |

#### CRU SSCGTBL44 47

Address: Operational Base + offset (0x03ac)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      | wo   |                    | sscgtbl44_47   |
|      |      |                    | 7-0: table44   |
| 31:0 |      |                    | 15-8: table45  |
|      |      |                    | 23-16: table46 |
|      |      |                    | 31-24: table47 |

#### CRU SSCGTBL48 51

Address: Operational Base + offset (0x03b0)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl48_51   |
|      |      |                    | 7-0: table48   |
| 31:0 | WO   | 0x00000000         | 15-8: table49  |
|      |      |                    | 23-16: table50 |
|      |      |                    | 31-24: table51 |

#### CRU\_SSCGTBL52\_55

Address: Operational Base + offset (0x03b4)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl52_55   |
|      |      |                    | 7-0: table52   |
| 31:0 | WO   | 0x00000000         | 15-8: table53  |
|      |      |                    | 23-16: table54 |
|      |      |                    | 31-24: table55 |

#### CRU\_SSCGTBL56\_59

Address: Operational Base + offset (0x03b8)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl56_59   |
|      |      |                    | 7-0: table56   |
| 31:0 | WO   | 0x00000000         | 15-8: table57  |
|      |      |                    | 23-16: table58 |
|      |      |                    | 31-24: table59 |

### CRU\_SSCGTBL60\_63

Address: Operational Base + offset (0x03bc)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl60_63   |
|      |      |                    | 7-0: table60   |
| 31:0 | WO   | 0x00000000         | 15-8: table61  |
|      |      |                    | 23-16: table62 |
|      |      |                    | 31-24: table63 |

#### CRU SSCGTBL64 67

Address: Operational Base + offset (0x03c0)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl64_67   |
|      |      |                    | 7-0: table64   |
| 31:0 | WO   | 0x00000000         | 15-8: table65  |
|      |      |                    | 23-16: table66 |
|      |      |                    | 31-24: table67 |

#### CRU SSCGTBL68 71

Address: Operational Base + offset (0x03c4)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl68_71   |
|      |      |                    | 7-0: table68   |
| 31:0 | WO   | 0x00000000         | 15-8: table69  |
|      |      |                    | 23-16: table70 |
|      |      |                    | 31-24: table71 |

#### CRU\_SSCGTBL72\_75

Address: Operational Base + offset (0x03c8)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      | wo   | 0×00000000         | sscgtbl72_75   |
|      |      |                    | 7-0: table72   |
| 31:0 |      |                    | 15-8: table73  |
|      |      |                    | 23-16: table74 |
|      |      |                    | 31-24: table75 |

#### CRU\_SSCGTBL76\_79

Address: Operational Base + offset (0x03cc)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl76_79   |
|      |      |                    | 7-0: table76   |
| 31:0 | WO   | 0x00000000         | 15-8: table77  |
|      |      |                    | 23-16: table78 |
|      |      |                    | 31-24: table79 |

#### CRU SSCGTBL80 83

Address: Operational Base + offset (0x03d0)

| nuure | <u> </u> |                    |                |
|-------|----------|--------------------|----------------|
| Bit   | Attr     | <b>Reset Value</b> | Description    |
|       |          |                    | sscgtbl80_83   |
|       |          |                    | 7-0: table80   |
| 31:0  | WO       | 0x00000000         | 15-8: table81  |
|       |          |                    | 23-16: table82 |
|       |          |                    | 31-24: table83 |

#### CRU SSCGTBL84 87

Address: Operational Base + offset (0x03d4)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl84_87   |
|      |      |                    | 7-0: table84   |
| 31:0 | WO   | 0x00000000         | 15-8: table85  |
|      |      |                    | 23-16: table86 |
|      |      |                    | 31-24: table87 |

#### CRU SSCGTBL88 91

Address: Operational Base + offset (0x03d8)

| Bit  | Attr | <b>Reset Value</b> |                | Description |  |
|------|------|--------------------|----------------|-------------|--|
|      | wo   | 0×00000000         | sscgtbl88_91   |             |  |
|      |      |                    | 7-0: table88   |             |  |
| 31:0 |      |                    | 15-8: table89  |             |  |
|      |      |                    | 23-16: table90 |             |  |
|      |      |                    | 31-24: table91 |             |  |

#### CRU SSCGTBL92 95

Address: Operational Base + offset (0x03dc)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl92_95   |
|      |      |                    | 7-0: table92   |
| 31:0 | WO   | 0x00000000         | 15-8: table93  |
|      |      |                    | 23-16: table94 |
|      |      |                    | 31-24: table95 |

#### CRU SSCGTBL96 99

Address: Operational Base + offset (0x03e0)

| Bit  | Attr | <b>Reset Value</b> | Description    |
|------|------|--------------------|----------------|
|      |      |                    | sscgtbl96_99   |
|      |      |                    | 7-0: table96   |
| 31:0 | WO   | 0x00000000         | 15-8: table97  |
|      |      |                    | 23-16: table98 |
|      |      |                    | 31-24: table99 |

### CRU\_SSCGTBL100\_103

Address: Operational Base + offset (0x03e4)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | sscgtbl100_103  |
|      |      |                    | 7-0: table100   |
| 31:0 | WO   | 0x00000000         | 15-8: table101  |
|      |      |                    | 23-16: table102 |
|      |      |                    | 31-24: table103 |

### CRU\_SSCGTBL104\_107

Address: Operational Base + offset (0x03e8)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | sscgtbl104_107  |
|      |      |                    | 7-0: table104   |
| 31:0 | WO   | 0x00000000         | 15-8: table105  |
|      |      |                    | 23-16: table106 |
|      |      |                    | 31-24: table107 |

#### CRU\_SSCGTBL108\_111

|      | Address: Operational Base + offset (0x03ec) |             |                                                                                         |  |  |
|------|---------------------------------------------|-------------|-----------------------------------------------------------------------------------------|--|--|
|      |                                             | Reset Value | Description                                                                             |  |  |
| 31:0 | wo                                          | 0x00000000  | sscgtbl108_111<br>7-0: table108<br>15-8: table109<br>23-16: table110<br>31-24: table111 |  |  |

### CRU\_SSCGTBL112\_115

Address: Operational Base + offset (0x03f0)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | sscgtbl112_115  |
|      |      |                    | 7-0: table112   |
| 31:0 | WO   | 0x00000000         | 15-8: table113  |
|      |      |                    | 23-16: table114 |
|      |      |                    | 31-24: table115 |

### CRU\_SSCGTBL116\_119

#### Address: Operational Base + offset (0x03f4)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | sscgtbl116_119  |
|      |      |                    | 7-0: table116   |
| 31:0 | WO   | 0x00000000         | 15-8: table117  |
|      |      |                    | 23-16: table118 |
|      |      |                    | 31-24: table119 |

#### CRU SSCGTBL120 123

Address: Operational Base + offset (0x03f8)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | sscgtbl120_123  |
|      |      |                    | 7-0: table120   |
| 31:0 | WO   | 0x00000000         | 15-8: table121  |
|      |      |                    | 23-16: table122 |
|      |      |                    | 31-24: table123 |

### CRU\_SSCGTBL124\_127

Address: Operational Base + offset (0x03fc)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | sscgtbl124_127  |
|      |      |                    | 7-0: table124   |
| 31:0 | WO   | 0x00000000         | 15-8: table125  |
|      |      |                    | 23-16: table126 |
|      |      |                    | 31-24: table127 |

#### CRU SOFTRST CONO

#### Address: Operational Base + offset (0x0400)

| Bit   | Attr       | <b>Reset Value</b> | Description                                                     |
|-------|------------|--------------------|-----------------------------------------------------------------|
|       |            |                    | write_mask                                                      |
| 31:16 | WO         | 0x0000             | When every bit HIGH, enable the writing corresponding bit       |
|       |            |                    | When every bit LOW, don't care the writing corresponding bit    |
|       | R/W        |                    | resetn_l2_req                                                   |
| 15    | K/ W<br>SC | 0x0                | When HIGH, will assert core nL2RESET(Please refer to ARM        |
|       | 50         |                    | Cortex-A35 Processor Revision: r0p2 Technical Reference Manual) |
| 14    | R/W        | 0×0                | aresetn_bus_niu_req                                             |
| 14    | SC         |                    | When HIGH, reset relative logic                                 |
| 13    | R/W        | /W 0×0             | resetn_core_noc_req                                             |
| 13    | SC         | 0.00               | When HIGH, reset relative logic                                 |
|       |            |                    | resetn_topdbg_req                                               |
| 12    | RW         | 0x0                | When HIGH, will assert core nPRESETDBG(Please refer to ARM      |
|       |            |                    | Cortex-A35 Processor Revision: r0p2 Technical Reference Manual) |
| 11:8  | RO         | 0x0                | reserved                                                        |

| Bit | Attr      | <b>Reset Value</b> | Description                                                                                                                                                 |
|-----|-----------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RW        | 0×0                | resetn_core3_req<br>When HIGH, will assert core3 nCORERESET[3](Please refer to<br>ARM Cortex-A35 Processor Revision: r0p2 Technical Reference<br>Manual)    |
| 6   | RW        | 0x0                | resetn_core2_req<br>When HIGH, will assert core2 nCORERESET[2](Please refer to<br>ARM Cortex-A35 Processor Revision: r0p2 Technical Reference<br>Manual)    |
| 5   | RW        | 0x0                | resetn_core1_req<br>When HIGH, will assert core1 nCORERESET[1](Please refer to<br>ARM Cortex-A35 Processor Revision: r0p2 Technical Reference<br>Manual)    |
| 4   | R/W<br>SC | 0×0                | resetn_core0_req<br>When HIGH, will assert core0 nCORERESET[0](Please refer to<br>ARM Cortex-A35 Processor Revision: r0p2 Technical Reference<br>Manual)    |
| 3   | RW        | 0×0                | resetn_corepo3_req<br>When HIGH, will assert core3 nCPUPORESET[3](Please refer to<br>ARM Cortex-A35 Processor Revision: r0p2 Technical Reference<br>Manual) |
| 2   | RW        | 0x0                | resetn_corepo2_req<br>When HIGH, will assert core2 nCPUPORESET[2](Please refer to<br>ARM Cortex-A35 Processor Revision: r0p2 Technical Reference<br>Manual) |
| 1   | RW        | 0x0                | resetn_corepo1_req<br>When HIGH, will assert core1 nCPUPORESET[1](Please refer to<br>ARM Cortex-A35 Processor Revision: r0p2 Technical Reference<br>Manual) |
| 0   | R/W<br>SC | 0x0                | resetn_corepo0_req<br>When HIGH, will assert core0 nCPUPORESET[0](Please refer to<br>ARM Cortex-A35 Processor Revision: r0p2 Technical Reference<br>Manual) |

CRU\_SOFTRST\_CON1 Address: Operational Base + offset (0x0404)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15    | RO   | 0x0                | reserved                                                     |
| 1.4   | RW   | V 0×0              | presetn_ddrphy_req                                           |
| 14    |      |                    | When HIGH, reset relative logic                              |
| 10    | RW   | $W = 0 \times 0$   | resetn_ddrphy_clkdiv_req                                     |
| 13    |      |                    | When HIGH, reset relative logic                              |

| Bit | Attr  | <b>Reset Value</b> | Description                     |
|-----|-------|--------------------|---------------------------------|
| 12  | RW    | 0.20               | resetn_ddrphy_req               |
| 12  | RW    | 0x0                | When HIGH, reset relative logic |
| 11  | RW    | 0x0                | resetn_ddr_stdby_req            |
| 11  | R VV  | 0.00               | When HIGH, reset relative logic |
| 10  | RW    | 0x0                | presetn_ddr_stdby_req           |
| 10  |       | 0.00               | When HIGH, reset relative logic |
| 9   | RW    | 0x0                | presetn_ddr_monitor_req         |
| 9   |       | 0.00               | When HIGH, reset relative logic |
| 8   | RO    | 0x0                | reserved                        |
| 7   | RW    | 0x0                | resetn_msch_req                 |
| /   |       |                    | When HIGH, reset relative logic |
| 6   | RW    | 0x0                | presetn_ddrupctl_req            |
| 0   |       |                    | When HIGH, reset relative logic |
| 5   | RO    | 0x0                | reserved                        |
| 4   | RW    | 0x0                | resetn_ddrupctl_req             |
| -   |       | 0.00               | When HIGH, reset relative logic |
| 3   | RW    | 0x0                | presetn_core_grf_req            |
| 5   |       |                    | When HIGH, reset relative logic |
| 2   | RW    | 0x0                | aresetn_core_prf_req            |
| 2   | R VV  | 0.00               | When HIGH, reset relative logic |
| 1   | RW    | 0x0                | resetn_core_pvtm_req            |
| 1   | R VV  | 0.00               | When HIGH, reset relative logic |
| 0   | RW    | 0x0                | resetn_dap_req                  |
| 0   | L A A |                    | When HIGH, reset relative logic |

CRU\_SOFTRST\_CON2 Address: Operational Base + offset (0x0408)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15    |      | 0.40               | resetn_uart1_req                                             |
| 15    | RW   | 0x0                | When HIGH, reset relative logic                              |
| 14    | RW   | / 0×0              | presetn_uart1_req                                            |
| 14    | ĸw   |                    | When HIGH, reset relative logic                              |
| 13    | RW   | 0x0                | resetn_uart0_req                                             |
| 13    | ĸw   |                    | When HIGH, reset relative logic                              |
| 12    | RW   | W 0x0              | presetn_uart0_req                                            |
| 12    |      |                    | When HIGH, reset relative logic                              |
| 11    |      | RW 0x0             | hresetn_rom_req                                              |
| 11    | ĸw   |                    | When HIGH, reset relative logic                              |
| 10    | RW   | 0.20               | aresetn_gic_req                                              |
| 10    | κw   | RW 0x0             | When HIGH, reset relative logic                              |

| Bit      | Attr | <b>Reset Value</b> | Description                     |
|----------|------|--------------------|---------------------------------|
| 9        | RW   | 0x0                | aresetn_intmem_req              |
| 5        |      |                    | When HIGH, reset relative logic |
| 8        | RW   | 0x0                | dresetn_vop_req                 |
| 0        |      | 0.00               | When HIGH, reset relative logic |
| 7        | RW   | 0x0                | hresetn_vop_req                 |
| <i>'</i> |      | 0.00               | When HIGH, reset relative logic |
| 6        | RW   | 0x0                | aresetn_vop_req                 |
| 0        |      | 0.00               | When HIGH, reset relative logic |
| 5        | RW   | 0x0                | resetn_crypto_apk_req           |
| 5        |      | 0.0                | When HIGH, reset relative logic |
| 4        | RW   | 0×0                | resetn_crypto_core_req          |
| •        |      |                    | When HIGH, reset relative logic |
| 3        | RW   | W 0x0              | hresetn_crypto_req              |
| 5        |      |                    | When HIGH, reset relative logic |
| 2        | RW   | 0x0                | aresetn_crypto_req              |
| 2        |      |                    | When HIGH, reset relative logic |
| 1        | RW   | 0x0                | presetn_bus_niu_req             |
| -        |      |                    | When HIGH, reset relative logic |
| 0        | RW   | 0x0                | hresetn_bus_niu_req             |
| Ĭ        |      |                    | When HIGH, reset relative logic |

CRU\_SOFTRST\_CON3 Address: Operational Base + offset (0x040c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                             |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | write_mask<br>When every bit HIGH, enable the writing corresponding bit<br>When every bit LOW, don't care the writing corresponding bit |
| 15    | RW   | 0x0                | resetn_pwm_req<br>When HIGH, reset relative logic                                                                                       |
| 14    | RW   | 0×0                | presetn_pwm_req<br>When HIGH, reset relative logic                                                                                      |
| 13    | RW   | 0×0                | resetn_i2c3_req<br>When HIGH, reset relative logic                                                                                      |
| 12    | RW   | 0×0                | presetn_i2c3_req<br>When HIGH, reset relative logic                                                                                     |
| 11    | RW   | 0×0                | resetn_i2c2_req<br>When HIGH, reset relative logic                                                                                      |
| 10    | RW   | 0×0                | presetn_i2c2_req<br>When HIGH, reset relative logic                                                                                     |
| 9     | RW   | 0×0                | resetn_i2c1_req<br>When HIGH, reset relative logic                                                                                      |
| 8     | RW   | 0×0                | presetn_i2c1_req<br>When HIGH, reset relative logic                                                                                     |

| Bit | Attr | Reset Value | Description                                          |
|-----|------|-------------|------------------------------------------------------|
| 7   | RW   | 0x0         | resetn_i2c0_req<br>When HIGH, reset relative logic   |
| 6   | RW   | 0x0         | presetn_i2c0_req<br>When HIGH, reset relative logic  |
| 5   | RW   | 0x0         | resetn_uart4_req<br>When HIGH, reset relative logic  |
| 4   | RW   | 0x0         | presetn_uart4_req<br>When HIGH, reset relative logic |
| 3   | RW   | 0x0         | resetn_uart3_req<br>When HIGH, reset relative logic  |
| 2   | RW   | 0x0         | presetn_uart3_req<br>When HIGH, reset relative logic |
| 1   | RW   | 0x0         | resetn_uart2_req<br>When HIGH, reset relative logic  |
| 0   | RW   | 0x0         | presetn_uart2_req<br>When HIGH, reset relative logic |

CRU\_SOFTRST\_CON4 Address: Operational Base + offset (0x0410)

| Bit   | Attr  | <b>Reset Value</b> | Description                                                  |                                 |
|-------|-------|--------------------|--------------------------------------------------------------|---------------------------------|
|       |       |                    | write_mask                                                   |                                 |
| 31:16 | WO    | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |                                 |
|       |       |                    | When every bit LOW, don't care the writing corresponding bit |                                 |
| 15    | RW    | 0x0                | resetn_timer5_req                                            |                                 |
| 15    |       | 0.00               | When HIGH, reset relative logic                              |                                 |
| 14    | RW    | 0x0                | resetn_timer4_req                                            |                                 |
| 14    |       | 0.00               | When HIGH, reset relative logic                              |                                 |
| 13    | RW    | 0x0                | resetn_timer3_req                                            |                                 |
| 13    | KVV   | 0.00               | When HIGH, reset relative logic                              |                                 |
| 12    | RW    | V 0x0              | resetn_timer2_req                                            |                                 |
| 12    | KVV   |                    | When HIGH, reset relative logic                              |                                 |
| 11    | RW    | 0×0                | resetn_timer1_req                                            |                                 |
| 11    | r vv  |                    | When HIGH, reset relative logic                              |                                 |
| 10    | RW    | W 0×0              | resetn_timer0_req                                            |                                 |
| 10    |       |                    | When HIGH, reset relative logic                              |                                 |
| 9     | RW    |                    | presetn_timer0_req                                           |                                 |
| 9     | ĸw    |                    | 0x0                                                          | When HIGH, reset relative logic |
| 8     | RW    | 0x0                | resetn_tsadc_req                                             |                                 |
| 0     | r vv  |                    | When HIGH, reset relative logic                              |                                 |
| 7     | RW    | 0x0                | presetn_tsadc_req                                            |                                 |
| /     | K VV  | 0.00               | When HIGH, reset relative logic                              |                                 |
| 6     | RW    | 0x0                | presetn_saradc_req                                           |                                 |
| 0     | IX VV | 0.00               | When HIGH, reset relative logic                              |                                 |

| Bit | Attr | <b>Reset Value</b> | Description                     |                                 |
|-----|------|--------------------|---------------------------------|---------------------------------|
| 5   | RW   | 0x0                | resetn_spi2_req                 |                                 |
| 5   |      | 0.0                | When HIGH, reset relative logic |                                 |
| 4   | RW   | 0.20               | presetn_spi2_req                |                                 |
| 4   | ĸw   | 0×0                | When HIGH, reset relative logic |                                 |
| 2   | RW   | 0x0                | resetn_spi1_req                 |                                 |
| 3   | RW   |                    | When HIGH, reset relative logic |                                 |
| 2   | RW   | 0.20               | presetn_spi1_req                |                                 |
| 2   |      | 0x0                | When HIGH, reset relative logic |                                 |
| 1   |      | RW 0x0             | resetn_spi0_req                 |                                 |
| L . | ĸw   |                    | When HIGH, reset relative logic |                                 |
| 0   |      | 0.20               | presetn_spi0_req                |                                 |
| 0   | K VV | RW                 | RW 0x0                          | When HIGH, reset relative logic |

CRU SOFTRST CON5 Address: Operational Base + offset (0x0414)

| Bit   | Attr | Reset Value | Description                                                                                                                             |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000      | write_mask<br>When every bit HIGH, enable the writing corresponding bit<br>When every bit LOW, don't care the writing corresponding bit |
| 15    | RW   | 0x0         | presetn_usb_grf_req<br>When HIGH, reset relative logic                                                                                  |
| 14    | RW   | 0×0         | resetn_pmu_pvtm_req<br>When HIGH, reset relative logic                                                                                  |
| 13    | RW   | 0x0         | pmu_srstn_req<br>When HIGH, reset relative logic                                                                                        |
| 12    | RW   | 0x0         | presetn_usbsdmmc_det_req<br>When HIGH, reset relative logic                                                                             |
| 11    | RW   | 0x0         | presetn_grf_req<br>When HIGH, reset relative logic                                                                                      |
| 10    | RW   | 0x0         | presetn_gpio4_req<br>When HIGH, reset relative logic                                                                                    |
| 9     | RW   | 0x0         | presetn_gpio3_req<br>When HIGH, reset relative logic                                                                                    |
| 8     | RW   | 0x0         | presetn_gpio2_req<br>When HIGH, reset relative logic                                                                                    |
| 7     | RW   | 0x0         | presetn_gpio1_req<br>When HIGH, reset relative logic                                                                                    |
| 6     | RW   | 0x0         | presetn_gpio0_req<br>When HIGH, reset relative logic                                                                                    |
| 5     | RO   | 0x0         | reserved                                                                                                                                |
| 4     | RW   | 0x0         | otp_phy_srstn_req<br>When HIGH, reset relative logic                                                                                    |
| 3     | RW   | 0x0         | presetn_otp_phy_req<br>When HIGH, reset relative logic                                                                                  |

| Bit | Attr | <b>Reset Value</b> | Description                                               |
|-----|------|--------------------|-----------------------------------------------------------|
| 2   | RW   |                    | resetn_otp_ns_user_req<br>When HIGH, reset relative logic |
| 1   | RW   | 0x0                | resetn_otp_ns_sbpi_req<br>When HIGH, reset relative logic |
| 0   | RW   | 0x0                | presetn_otp_ns_req<br>When HIGH, reset relative logic     |

#### CRU SOFTRST CON6

Address: Operational Base + offset (0x0418)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |   |  |      |
|-------|------|--------------------|--------------------------------------------------------------|---|--|------|
|       |      |                    | write_mask                                                   |   |  |      |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |   |  |      |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |   |  |      |
| 15    | RW   | 0x0                | hresetn_usb2host_arb_req                                     |   |  |      |
| 15    |      | 0.0                | When HIGH, reset relative logic                              |   |  |      |
| 14    | RW   | 0x0                | hresetn_usb2host_req                                         |   |  |      |
| 14    |      | 0.0                | When HIGH, reset relative logic                              |   |  |      |
| 13    | RW   | 0x0                | resetn_usb2otg_adp_req                                       |   |  |      |
| 15    |      | 0.0                | When HIGH, reset relative logic                              |   |  |      |
| 12    | RW   | / 0x0              | resetn_usb2otg_req                                           |   |  |      |
| 12    |      | 0.0                | When HIGH, reset relative logic                              |   |  |      |
| 11    | RW   | V 0×0              | hresetn_usb2otg_req                                          |   |  |      |
|       | 1    |                    | When HIGH, reset relative logic                              |   |  |      |
| 10    | RW   | xw 0x0             | presetn_peri_niu_req                                         |   |  |      |
| 10    | 1    |                    | When HIGH, reset relative logic                              |   |  |      |
| 9     | RW   | RW OXO             | hresetn_peri_niu_req                                         |   |  |      |
| 5     |      | 1                  |                                                              | 1 |  | 0.00 |
| 8     | RW   | 0x0                | aresetn_peri_niu_req                                         |   |  |      |
| _     | 1    | 0.00               | When HIGH, reset relative logic                              |   |  |      |
| 7:2   | RO   | 0x0                | reserved                                                     |   |  |      |
| 1     | RW   | 0x0                | presetn_cpu_boost_req                                        |   |  |      |
| -     | 1    | 0.0                | When HIGH, reset relative logic                              |   |  |      |
| 0     | RW   | 0x0                | resetn_cpu_boost_req                                         |   |  |      |
| 0     |      | 0.00               | When HIGH, reset relative logic                              |   |  |      |

<u>**CRU SOFTRST CON7</u>** Address: Operational Base + offset (0x041c)</u>

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:14 | RO   | 0x0                | reserved                                                     |
| 13    | RW   | W/ 00              | aresetn_mac_req                                              |
|       |      | 0x0                | When HIGH, reset relative logic                              |

| Bit      | Attr | <b>Reset Value</b> | Description                     |  |                                 |
|----------|------|--------------------|---------------------------------|--|---------------------------------|
| 12       | RW   | 00                 | nresetn_nandc_req               |  |                                 |
| 12       | RW   | 0x0                | When HIGH, reset relative logic |  |                                 |
| 11       | RW   | 0x0                | hresetn_nandc_req               |  |                                 |
| 11       | RVV  | 0.00               | When HIGH, reset relative logic |  |                                 |
| 10       | RW   | 0x0                | hresetn_sdmmc_req               |  |                                 |
| 10       |      | 0.00               | When HIGH, reset relative logic |  |                                 |
| 9        | RW   | 0x0                | resetn_sfc_req                  |  |                                 |
| 9        |      | 0.00               | When HIGH, reset relative logic |  |                                 |
| 8        | RW   | 0x0                | hresetn_sfc_req                 |  |                                 |
| 0        |      | 0.00               | When HIGH, reset relative logic |  |                                 |
| 7        | RW   | 0x0                | hresetn_emmc_req                |  |                                 |
| <i>'</i> |      |                    | When HIGH, reset relative logic |  |                                 |
| 6        | RW   | 0×0                | hresetn_sdio_req                |  |                                 |
| 0        |      |                    | When HIGH, reset relative logic |  |                                 |
| 5        | RW   | 0x0                | utmi1_srst_req                  |  |                                 |
| 5        |      |                    | When HIGH, reset relative logic |  |                                 |
| 4        | RW   | 0x0                | utmi0_srst_req                  |  |                                 |
| -        |      |                    |                                 |  | When HIGH, reset relative logic |
| 3        | RW   | 0x0                | usbphypor_rst_req               |  |                                 |
| <u> </u> |      |                    | When HIGH, reset relative logic |  |                                 |
| 2        | RW   | 0x0                | resetn_usb2host_utmi_req        |  |                                 |
| 2        |      |                    | When HIGH, reset relative logic |  |                                 |
| 1        | RW   | 0x0                | resetn_usb2host_ehciphy_req     |  |                                 |
| -        |      |                    | When HIGH, reset relative logic |  |                                 |
| 0        | RW   | 0x0                | hresetn_usb2host_aux_req        |  |                                 |
| Ŭ        |      |                    | When HIGH, reset relative logic |  |                                 |

CRU SOFTRST CON8 Address: Operational Base + offset (0x0420)

| Bit   | Attr                                             | <b>Reset Value</b>              | Description                                                  |
|-------|--------------------------------------------------|---------------------------------|--------------------------------------------------------------|
|       |                                                  |                                 | write_mask                                                   |
| 31:16 | WO                                               | 0x0000                          | When every bit HIGH, enable the writing corresponding bit    |
|       |                                                  |                                 | When every bit LOW, don't care the writing corresponding bit |
| 15    | RW                                               | 0~0                             | mresetn_i2s2_8ch_tx_req                                      |
| 13    |                                                  | When HIGH, reset relative logic |                                                              |
| 14    | RW                                               |                                 | hresetn_i2s2_8ch_req                                         |
| 14    | RW 0x0 When HIGH, reset relative logic           |                                 | When HIGH, reset relative logic                              |
| 13    | RW                                               | 0.20                            | mresetn_i2s1_8ch_rx_req                                      |
| 13    | RW     0x0       When HIGH, reset relative logic |                                 | When HIGH, reset relative logic                              |
| 12    |                                                  | RW 0x0                          | mresetn_i2s1_8ch_tx_req                                      |
| 12    | RW                                               |                                 | When HIGH, reset relative logic                              |
| 11    | RW                                               |                                 | hresetn_i2s1_8ch_req                                         |
| 11    | ĸw                                               | 0x0                             | When HIGH, reset relative logic                              |

| Bit | Attr  | <b>Reset Value</b>              | Description                     |  |
|-----|-------|---------------------------------|---------------------------------|--|
| 10  | RW    | 0x0                             | mresetn_i2s0_8ch_rx_req         |  |
| 10  | K VV  | 0.00                            | When HIGH, reset relative logic |  |
| 9   | RW    | 0x0                             | mresetn_i2s0_8ch_tx_req         |  |
| 9   | N V V | 0.00                            | When HIGH, reset relative logic |  |
| 8   | RW    | 0x0                             | hresetn_i2s0_8ch_req            |  |
| 0   |       | 0.00                            | When HIGH, reset relative logic |  |
| 7   | RW    | 0x0                             | mresetn_spdifrx_req             |  |
| /   |       | 0.00                            | When HIGH, reset relative logic |  |
| 6   | RW    | V 0×0                           | hresetn_spdifrx_req             |  |
| 0   |       | 0.00                            | When HIGH, reset relative logic |  |
| 5   | RW    | 0x0                             | mresetn_spdiftx_req             |  |
| 5   |       | When HIGH, reset relative logic |                                 |  |
| 4   | RW    | 0x0                             | hresetn_spdiftx_req             |  |
| -   |       | 0,0                             | When HIGH, reset relative logic |  |
| 3   | RW    | 0x0                             | mresetn_pdm_req                 |  |
| 5   |       | 0,0                             | When HIGH, reset relative logic |  |
| 2   | RW    | 0x0                             | hresetn_pdm_req                 |  |
| 2   | Wh    |                                 | When HIGH, reset relative logic |  |
| 1   | RW    | 0x0                             | presetn_audio_niu_req           |  |
| -   |       |                                 | When HIGH, reset relative logic |  |
| 0   | RW    | 0x0                             | hresetn_audio_niu_req           |  |
| 0   |       |                                 | When HIGH, reset relative logic |  |

# CRU\_SOFTRST\_CON9

Address: Operational Base + offset (0x0424)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |  |
|-------|------|--------------------|--------------------------------------------------------------|--|
|       |      |                    | write_mask                                                   |  |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |  |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |  |
| 15:10 | RO   | 0x0                | reserved                                                     |  |
| 9     | RW   | 0.20               | presetn_acodec_req                                           |  |
| 9     | K VV | 0x0                | When HIGH, reset relative logic                              |  |
| 0     |      | 0x0                | hresetn_vad_req                                              |  |
| 8     | RW   |                    | When HIGH, reset relative logic                              |  |
| 7     |      | 0x0                | mresetn_i2s1_2ch_req                                         |  |
| /     | RW   |                    | When HIGH, reset relative logic                              |  |
| 6     | RW   | 0×0                | hresetn_i2s1_2ch_req                                         |  |
| 0     | K VV |                    | When HIGH, reset relative logic                              |  |
| 5     |      | .W 0x0             | mresetn_i2s0_2ch_req                                         |  |
| 5     | RVV  |                    | When HIGH, reset relative logic                              |  |
| 1     |      | V 0×0              | hresetn_i2s0_2ch_req                                         |  |
| 4     | RW   |                    | When HIGH, reset relative logic                              |  |
| 2     |      | 0.40               | mresetn_i2s3_8ch_rx_req                                      |  |
| 3     | RW   | / 0×0              | When HIGH, reset relative logic                              |  |

| Bit | Attr | <b>Reset Value</b> | Description                     |  |
|-----|------|--------------------|---------------------------------|--|
| 2   | RW   |                    | mresetn_i2s3_8ch_tx_req         |  |
| Z   | ĸvv  |                    | When HIGH, reset relative logic |  |
| -   |      | $W = 0 \times 0$   | hresetn_i2s3_8ch_req            |  |
| L   | RW   |                    | When HIGH, reset relative logic |  |
| 0   |      | RM IOXO            | mresetn_i2s2_8ch_rx_req         |  |
| 0   | KW   |                    | When HIGH, reset relative logic |  |

#### CRU SDMMC CONO

Address: Operational Base + offset (0x0480)

| Bit   | Attr   | <b>Reset Value</b> | Description                                                  |  |
|-------|--------|--------------------|--------------------------------------------------------------|--|
|       |        |                    | write_mask                                                   |  |
| 31:16 | WO     | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |  |
|       |        |                    | When every bit LOW, don't care the writing corresponding bit |  |
| 15:12 | RO     | 0x0                | reserved                                                     |  |
| 11    |        |                    | drv_sel                                                      |  |
| 11    | RW 0x0 |                    | drive select                                                 |  |
| 10:3  | RW     |                    | drv_delaynum                                                 |  |
| 10:5  | RVV    | 0x00               | drive delay number                                           |  |
| 2:1   |        | 0.2                | drv_degree                                                   |  |
| 2:1   | RW     | 0x2                | drive degree                                                 |  |
| 0     | RW     | 0.40               | init_state                                                   |  |
| 0     | ĸvv    | 0x0                | initial state                                                |  |

### CRU\_SDMMC\_CON1

Address: Operational Base + offset (0x0484)

| Bit   | Attr  | <b>Reset Value</b> | Description                                                  |  |
|-------|-------|--------------------|--------------------------------------------------------------|--|
|       |       |                    | write_mask                                                   |  |
| 31:16 | WO    | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |  |
|       |       |                    | When every bit LOW, don't care the writing corresponding bit |  |
| 15:12 | RO    | 0x0                | (0 reserved                                                  |  |
| 1 1   | RW    | / (0x0)            | sample_sel                                                   |  |
| 11    | RVV   |                    | sample select                                                |  |
| 10.2  | RW    | V 0x00             | sample_delaynum                                              |  |
| 10:3  | KW    | 0000               | sample delay number                                          |  |
| 2:1   | RW    | 0.40               | sample_degree                                                |  |
| 2.1   | r: vv | 0x0                | sample degree                                                |  |
| 0     | RO    | 0x0                | x0 reserved                                                  |  |

### CRU\_SDIO\_CONO

Address: Operational Base + offset (0x0488)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |  |
|-------|------|--------------------|--------------------------------------------------------------|--|
|       |      |                    | write_mask                                                   |  |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |  |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |  |
| 15:12 | RO   | 0x0                | reserved                                                     |  |
|       | עע   | / 0x0              | drv_sel                                                      |  |
| 11    | RW   |                    | drive select                                                 |  |
| 10:3  |      | 0.400              | drv_delaynum                                                 |  |
| 10:3  | RW   | V 0×00             | drive delay number                                           |  |
| 2:1   | עמ   | W 0x2              | drv_degree                                                   |  |
| 2.1   | RVV  |                    | drive degree                                                 |  |
| 0     | RW   | W 0x0              | init_state                                                   |  |
| 0     | κw   |                    | initial state                                                |  |

# CRU SDIO CON1

Address: Operational Base + offset (0x048c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |  |
|-------|------|--------------------|--------------------------------------------------------------|--|
|       |      |                    | write_mask                                                   |  |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |  |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |  |
| 15:12 | RO   | 0x0                | x0 reserved                                                  |  |
| 11    | RW   | 0×0                | sample_sel                                                   |  |
| 11    | RVV  |                    | sample select                                                |  |
| 10:3  | RW   | 0×00               | sample_delaynum                                              |  |
| 10.5  |      |                    | sample delay number                                          |  |
| 2:1 F | RW   | / 0×0              | sample_degree                                                |  |
|       | L AA |                    | sample degree                                                |  |
| 0     | RO   | 0x0                | reserved                                                     |  |

### CRU EMMC CONO

Address: Operational Base + offset (0x0490)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:12 | RO   | 0x0                | reserved                                                     |
| 1.1   | RW   | 0x0                | drv_sel                                                      |
| 11    | KW   |                    | drive select                                                 |
| 10:3  | עע   | W 0x00             | drv_delaynum                                                 |
| 10.5  | RVV  |                    | drive delay number                                           |
| 2:1   | D\// | W IOX2             | drv_degree                                                   |
| 2.1   | RVV  |                    | drive degree                                                 |
| 0     | עע   | $W = 0 \times 0$   | init_state                                                   |
| U     | κvv  |                    | initial state                                                |

#### CRU\_EMMC\_CON1

Address: Operational Base + offset (0x0494)

| Bit   | Attr   | <b>Reset Value</b> | Description                                                  |  |
|-------|--------|--------------------|--------------------------------------------------------------|--|
|       |        |                    | write_mask                                                   |  |
| 31:16 | WO     | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |  |
|       |        |                    | When every bit LOW, don't care the writing corresponding bit |  |
| 15:12 | RO     | 0x0                | x0 reserved                                                  |  |
| 11    | DW 0.0 | V 0×0              | sample_sel                                                   |  |
| 11    | RW     | 0.00               | sample select                                                |  |
| 10:3  | RW     |                    | sample_delaynum                                              |  |
| 10.5  | RVV    | 0x00               | sample delay number                                          |  |
| 2.1   | עעם    |                    | sample_degree                                                |  |
| 2:1   | RW     | 0x0                | sample degree                                                |  |
| 0     | RO     | 0x0 reserved       |                                                              |  |

# **2.5 Application Notes**

#### 2.5.1 PLL usage

FBDIV, POSTDIV1, BYPASS can be configured by programming CRU\_xPLL\_CON0. DSMPD, REFDIV, POSTDIV2 can be configured by programming CRU\_xPLL\_CON1. FRAC can be configured by programming CRU\_xPLL\_CON2. If DSMPD = 1, PLL is in integer mode. If DSMPD = 0, PLL is in fractional mode.

### A. PLL integer mode configuration

FOUTVCO = (FREF / REFDIV) \* FBDIV FOUTPOSTDIV = FOUTVCO / (POSTDIV1\*POSTDIV2) When FREF is 24MHz, and if 700MHz FOUTPOSTDIV is needed. The configuration can be: DSMPD = 1REFDIV = 6FBDIV = 175POSTDIV1=1 POSTDIV2=1 And then FOUTVCO = (FREF / REFDIV) \* FBDIV = 24/6\*175=700 FOUTPOSTDIV = FOUTVCO / (POSTDIV1\*POSTDIV2)=700/1/1=700 B. PLL fractional mode configuration  $FOUTVCO = (FREF / REFDIV) * (FBDIV + FRAC / (2^{24}))$ FOUTPOSTDIV = FOUTVCO / (POSTDIV1\*POSTDIV2) When FREF is 24MHz, and if 491.52MHz FOUTPOSTDIV is needed. The configuration can be: DSMPD = 0REFDIV = 1FBDIV = 40FRAC = 24'hf5c28fPOSTDIV1=2 POSTDIV2=1 And then  $FOUTVCO = (FREF / REFDIV) * (FBDIV + FRAC / (2^{24})) = 983.04$ FOUTPOSTDIV = FOUTVCO / (POSTDIV1\*POSTDIV2)=983.04/(2\*1)=491.52 C. PLL setting consideration

- VCO output clock from 800MHz to 3.2GHz
- The value of POSTDIV1 should always be greater than or equal to POSTDIV2
- For lowest power operation, the minimum VCO and FREF frequencies should be used. For minimum jitter operation, the highest VCO and FREF frequencies should be used.
- The supply rejection will be worse at the low end of the VCO range so care should be

taken to keep the supply clean for low power applications.

#### 2.5.2 PLL frequency change and lock check

PLL lock state can be checked in CRU\_xPLL\_CON1[10] register. The lock state is high when both original hardware PLL lock and PLL counter lock are high. The max lock time for PLL is 500 REF\_CLK.

The PLL counter lock initial value is GLB\_PLL\_LOCK [15:0], the default value is 15000. It recommends configure GLB\_PLL\_LOCK [15:0] to a smaller value after power up(for example: 500).

User should configure as following steps to change the PLL output frequency

- Change PLL from normal to slow mode by programming CRU\_MODE[9:0].
- Change PLL setting.
- Wait until PLL is lock state by checking CRU\_xPLL\_CON1[10] register or after delay about 500 REF\_CLK
- Change PLL into normal mode.

By default, user don't have to configure the register to power down PLL when change the PLL output frequency. When any RFDIV/FBDIV/FRACDIV is changed, CRU will assert PLL power down and release after 1us automatic. In addition, user also can configure CRU\_xPLL\_CON1[13] to power down PLL.

User can set CRU\_XPLL\_CON1[15] to 1'b1 to disable the PLL power down automatic. In this case, user should configure CRU\_xPLL\_CON1[14] to power down PLL before changing PLL setting, and release at least 1us after valid settings, referring to the following figure.



Fig. 2-5 PLL setting change timing

User also can use HWFFC (hardware fast frequency change) to change the APLL frequency as following steps:

- Set the CRU\_HWFFC\_INTST(interrupt related) and CRU\_HWFFC\_TH.
- Enable hwffc\_mode(CRU\_HWFFC\_CON0[9]).
- Set clk\_core\_div for backup PLL (CRU\_HWFFC\_CON0[3:0]).
- Set the new APLL setting to CRU\_APLL\_CON0, CRU\_APLL\_CON1, this setting will not take effect until hwffc\_req is asserted.
- Trigger hwffc\_req (CRU\_HWFFC\_CON0[8]), and Poll CRU\_HWFFC\_CON0[8]=0x1.
- HWFFC is done when CRU\_HWFFC\_CON0[8] is cleared and HWFFC interrupt happened (or interrupt status is asserted).

When HWFFC mode is enabled, some setting of APLL and core clock generate unit (configured by CRU\_APLL\_CON0, CRU\_APLL\_CON1 and CRU\_CLKSEL\_CON0) are also controlled by HWFFC module. The actually setting can be read by registers CRU\_APLL\_CON0\_S, CRU\_APLL\_CON1\_S and CRU\_CLKSEL\_CON0\_S.

### 2.5.3 Fractional divider usage

To get specific frequency, clocks of SPDIF, I2S, PDM, UART can be generated by fractional divider. Generally you must set that denominator is 20 times larger than numerator to generate precise clock frequency. So the fractional divider applies only to generate low frequency clock like SPDIF, I2S, UART and PDM. For implementation issue, the input source clocks of fractional divider also have the following limitation.

| Clock Name | Fractional divider source clock limitation |
|------------|--------------------------------------------|
| dclk_vop   | 270Mhz                                     |
| clk_pdm    | 800Mhz                                     |

| Clock Name            | Fractional divider source clock limitation |
|-----------------------|--------------------------------------------|
| clk_spdiftx           | 800Mhz                                     |
| clk_spdifrx           | 800Mhz                                     |
| clk_i2s0/1/2/3_8ch_tx | 800Mhz                                     |
| clk_i2s0/1/2/3_8ch_rx | 800Mhz                                     |
| clk_i2s0/1_2ch        | 800Mhz                                     |

## 2.5.4 Divfree50 divider usage

Some IPs, such as NAND, EMMC, SDIO and SDMMC need clock of 50% duty cycle, then Divfree50 divider is used.

## 2.5.5 DivfreeNP5 divider usage

Some IPs, such as UART needs some special frequency, then DivfreeNP5 is used. UART with baud rate of 4Mbps need use this divider to generate 64MHz clock from 480MHz of USBPHY PLL.

### 2.5.6 Global software reset usage

Two global software resets are designed in the chip, you can program CRU\_GLB\_SRST\_FST [15:0] as 0xfdb9 to assert the first global software reset glb\_srstn\_1 and program CRU\_GLB\_SRST\_SND [15:0] as 0xeca8 to assert the second global software reset glb\_srstn\_2. These two software resets are self-de-asserted by hardware. Resetting hold timing of global software reset (glb\_srstn\_1, glb\_srstn\_2, soc\_wdt\_rstn, soc\_tsadc\_rstn) can be programmable up to 178.9s.

Glb\_srstn\_1 resets almost all logic.

Glb\_srstn\_2 resets almost all logic except GRF and GPIOs.

### 2.5.7 Software reset usage

Almost all software reset are controlled by CRU registers. Especially for core, when it assert warm reset request, the corresponding bit of nCPUPORESET and nCORERESET will also be asserted.

For implementation issue, Some IPs clock have following frequency limitation. User should reduce the frequency to less than or equal to the limitation when assert the software reset.

| Reset request                                  | Clock Name       | limitation |
|------------------------------------------------|------------------|------------|
| resetn_msch_req(CRU_SOFTRST_CON1[7])           | ddrphy_dfi_clk4x | 1200Mhz    |
| resetn_crypto_apk_req(CRU_SOFTRST_CON2[5])     | clk_crypto_apk   | 275Mhz     |
| aresetn_dmac1_req(SGRF_SOFTRST_CON[12])        | aclk_bus         | 200Mhz     |
| resetn_ddrphy_clkdiv_req(CRU_SOFTRST_CON1[13]) | ddrphy_dfi_clk4x | 300Mhz     |
| CPU warm reset                                 | clk_core         | 800Mhz     |

### 2.5.8 SSCG usage

There are some scenes where SSCG should not be enabled. One scene is in communication where a fixed frequency is required. Another scene is a system requiring a clock with low long-term jitter.

When SSCG is usage, the PLL should be configured to fractional mode firstly for spread spectrum capability.

### A. SSCG use Internal Point Table

User can use SSCG with internal point table as following steps:

- Setting ssmod\_spread (CRU\_XPLL\_CON3[12:8]) and
  - ssmod\_downspread(CRU\_XPLL\_CON3[3])

The modulation amplitude is controlled by the value of ssmod\_spread. A ssmod\_spread value of 5'd0 turns off the modulation. A ssmod\_spread value of 5'd31 (5'b11111) gives maximum

modulation while a value of 5'd1 gives minimum modulation.

The modulation amplitude can be calculated from the value of modulation by:

Modulation Amplitude =  $\pm 5'd(ssmod\_spread)*0.1\%$ 

The modulation direction is determined by the ssmod\_downspread bit.

ssmod\_downspread=1'b1, then down spread mode is used. If ssmod\_spread =

5'd29. Then, the maximum PLL frequency is the nominally programmed value FNOM, and the minimum value is given by FNOM\* (1-0.029).

■ ssmod\_downspread=1'b0, then center spread mode is used. If ssmod\_spread = 5'd29. Then, the maximum PLL frequency would be determined by FNOM\*(1+0.029) and the minimum frequency by FNOM\* (1-0.029).

Setting the style of modulation (center versus down) and the modulation amplitude depend on the amount of EMI reduction desired and the timing margin for circuits running on the spread clock domain. The larger the spread value, the greater the reduction in EMI amplitude. However, the larger the spread value, the more timing margin needed for correct circuit operation.

• Setting ssmod\_sel\_ext\_wave (CRU\_XPLL\_CON4[0])=1'b0

When use internal point table. The frequency will change as following during 128 point:

- Change from minimum value to maximum value uniformly within 64 points
- Change from maximum value to minimum value uniformly within 64 points
- Spread spectrum modulator is implemented by repeating as above.
- Setting ssmod\_divval (CRU\_XPLL\_CON3[7:4])

The frequency of modulation FMOD= FREF / (Point number\*REFDIV\*ssmod\_divval). The FMOD is typically set above 32kHz and below the maximum frequency for modulation fidelity, which is determined by the PLL bandwidth. The maximum modulation frequency is conservatively set at FREF/(200\*REFDIV).

When FREF=24Mhz and REFDIV= 1, the value of ssmod\_divval can be 5, then the FMOD is 37.5Khz.

- Setting ssmod\_bp(CRU\_XPLL\_CON3[0])=1'b0
- Setting ssmod\_disable\_sscg(CRU\_XPLL\_CON3[1])=1'b0
- Setting Setting ssmod\_reset(CRU\_XPLL\_CON3[2])=1'b0

### A. SSCG use External Point Table

In addition to the internal shape table, tables external to the SSMOD can be accessed. This enables customization tables in both shape and the number of sample points for the envelope wave form up to 128 data points. The external table of 128 data points can be configured from CRU\_SSCGTBL0\_3~CRU\_SSCGTBL124\_127.

User can use SSMOD with external point table as following steps:

 Setting ssmod\_spread (CRU\_XPLL\_CON3[12:8]) and ssmod\_downspread(CRU\_XPLL\_CON3[3])

Same with internal point table usage.

- Setting ssmod\_sel\_ext\_wave (CRU\_XPLL\_CON4[0])=1'b1
- Setting ssmod\_ext\_maxaddr(CRU\_XPLL\_CON4[15:8]) and table0~table127(CRU\_SSCGTBL0\_3~CRU\_SSCGTBL124\_127)

ssmod\_ext\_maxaddr is the maximum table address. For example, if the number of points describing the envelope shape is 128, the ssmod\_ext\_maxaddr should be configured to 127. The table address circulate over the range 0 to 127.

The table0~table127 must be 8 bit numbers in the form of sign and magnitude

- 1.00 is represented by 8'b01111111, it is corresponded to maximum frequency.
- -1.00 in represented in the table by 8'b11111111, it is corresponded to minimum frequency.
- 0.5 in represented in the table by 8'b00111111.
- -0.5 in represented in the table by 8'b10111111.

The frequency will change base table0~table127 within 128 points, and then repeat.

Setting ssmod\_divval (CRU\_XPLL\_CON3[7:4])

The frequency of modulation FMOD= FREF/(Point number\*REFDIV\*ssmod\_divval). The point number equal to ssmod\_ext\_maxaddr+1.

- Setting ssmod\_bp(CRU\_XPLL\_CON3[0])=1'b0
- Setting ssmod\_disable\_sscg(CRU\_XPLL\_CON3[1])=1'b0
- Setting Setting ssmod\_reset(CRU\_XPLL\_CON3[2])=1'b0

# **Chapter 3 Cortex-A35**

# 3.1 Overview

The 3308 has a quad-core Cortex-A35 cluster with 256K L2 memory. Cortex-A35 processor, which is a mid-range, low-power processor that implements the ARMv8-A architecture. The Cortex-A35 processor includes following features:

- Full implementation of the ARMv8-A A64, A32, and T32 instruction sets
- Both the AArch32 and AArch64 execution states at all Exception levels (EL0 to EL3)
- In-order pipeline with direct and indirect branch prediction
- Separate Level 1 (L1) data and instruction side memory systems with a Memory Management Unit(MMU)
- Level 2 (L2) memory system that provides cluster memory coherency
- L2 cache
- TrustZone
- Support data engine that implements the Advanced SIMD and floating-point architecture support
- Support Cryptographic Extension
- ARMv8 debug logic with v7 Debug memory map
- Support Generic Interrupt Controller (GIC) CPU interface to connect to an external distributor
- Generic Timers supporting 64-bit count input from an external system counter

The configuration details are shown in following tables:

| Table 3-1 CPU Configuration |
|-----------------------------|

| Configuration Item              | Value    |  |
|---------------------------------|----------|--|
| Number of CPU                   | 4        |  |
| L1 I cache size                 | 32K      |  |
| L1 D cache size                 | 32K      |  |
| L2 cache size                   | 256K     |  |
| L2 data RAM output latency      | 3 cycles |  |
| L2 data RAM input latency       | 2 cycles |  |
| CPU cache protection            | No       |  |
| SCU L2 cache protection         | No       |  |
| BUS master interface            | AXI4     |  |
| NEON and floating-point support | Yes      |  |
| Cryptography extension          | Yes      |  |

# 3.2 Block Diagram

The Cortex-A35 sub system is shown in Figure 1-1. As illustrated, quad-core Cortex-A35 connects to system bus through SCU-L2 which can handle with CDC (clock domain crossing) issue.

The Cortex-A35 is connected with system counter, which can run under a constant frequency clock, for PPI interrupt generation.



Fig. 3-1 Block Diagram

# **3.3 Function Description**

Please refer to the document cortex\_a35\_r0p2\_trm.pdf for the detail function description.

# **Chapter 4 AXI PERF**

# 4.1 Overview

One AXI\_PERF blocks are used in the system: CPU\_AXI\_PERF for performance statistic on AXI bus of CPU. Following is the features of AXI\_PERF IP:

- AXI read statistic
  - Support max read latency of one ID
  - Support the statistic of the average latency of one ID
  - Support count the burst which the read latency is more than A value
  - Support read bandwidth statistic for one or all ID
  - Support read real bandwidth statistic and DDR align bandwidth statistic
- AXI write statistic
  - Support write bandwidth statistic for one or all ID
  - Support write real bandwidth statistic and DDR align bandwidth statistic
- AXI read and write address monitor
  - Support monitor read from appointed address area for one or some ID
  - Support monitor write to appointed address area for one or some ID
  - Interrupt generation

## 4.2 Block Diagram



Fig. 4-1 AXI\_PERF block diagram

# 4.3 Register Description of CPU\_AXI\_PERF

Please refer to Chapter GRF/CORE GRF.

# **4.4 Application Notes**

## 4.4.1 Start and finish flow

- Assert sw\_axi\_perf\_clr\_e 1, and then assert sw\_axi\_perf\_clr\_e 0
- Config all the signals which need to be configured (sw\_axi\_perf\_work\_e keeps 0)
- Assert sw\_axi\_perf\_work\_e 1 after getting A frame end signal to start AXI\_PERF
- Read back the statistic values after one or more frames
- Next loop

### 4.4.2 Read latency statistic case

The Read latency statistic is fit for one ID specify by sw\_rd\_latency\_id only

**Case1**: The user wants to get the average read latency and max read latency of one frame and ID 1 at CPU. Here are the steps:

- Finish CPU AXI PERF clear step
- Assert sw\_rd\_latency\_id 1, sw\_rd\_latency\_thr 0, sw\_axi\_perf\_frm\_type 1 (PERF\_LATENCY\_CTRL0=0x14)
- Start CPU AXI PERF
- Start CPU and wait for finish interrupt
- Read back PERF\_WORKING\_CNT. This value means how many cycles are used by this frame.
- Read back PERF\_RD\_MAX\_LATENCY\_NUM. This value means the max latency of one frame for ID 1.
- Read back PERF\_RD\_LATENCY\_SAMP\_NUM and PERF\_RD\_LATENCY\_ACC\_SUM. Use the formulation perf\_rd\_latency\_average=perf\_rd\_latency\_acc\_sum/perf\_rd\_latency\_samp\_num; perf\_rd\_latency\_average is the average latency of ID 1.
- Clear CPU AXI\_PERF and wait for next statistic

**Case2:** The user wants to statistic the read average latency of every ID (assume ID from 0 to 9) and 60 frames at CPU. The burst to be counted need bigger than n. Here are the steps:

- Finish CPU AXI PERF clear step
- Assert sw\_rd\_latency\_id 0, sw\_rd\_latency\_thr n, sw\_axi\_perf\_frm\_type 0 (PERF\_LATENCY\_CTRL0=0xn00)
- Start CPU AXI PERF
- Start CPU and run 60 frames continually
- Read back PERF\_WORKING\_CNT, this value which is divided by60 means the average cycle uses of running this scenario
- Read back PERF\_RD\_LATENCY\_SAMP\_NUM and PERF\_RD\_LATENCY\_ACC\_SUM. Use the formulation perf\_rd\_latency\_average=perf\_rd\_latency\_acc\_sum/perf\_rd\_latency\_samp\_num; perf\_rd\_latency\_average is the average latency of ID 0 by 60 frames.
- Clear CPU AXI PERF
- Repeat the above steps and finish id1 to id9 statistic

### 4.4.3 Bandwidth statistic case

**Case3:** The user wants to get the single frame read and write bandwidth of ID 1 at CPU. Here are the steps:

- Finish CPU AXI PERF clear step
- Assert sw\_ar\_cnt\_id\_type sw\_aw\_cnt\_id\_type 1, sw\_ar\_count\_id sw\_aw\_count\_id 1, sw\_axi\_cnt\_type 0, sw\_axi\_perf\_frm\_type 1(PERF\_LATENCY\_CTRL0=0x40 PERF\_LATENCY\_CTRL1=0x11c)
- Start CPU AXI PERF
- Start CPU and wait for finish interrupt
- Read back PERF\_RD\_AXI\_TOTAL\_BYTE, this value means the total read bytes of ID 1
- Read back PERF\_WR\_AXI\_TOTAL\_BYTE, this value means the total write bytes of ID 1
- Clear CPU AXI\_PERF and wait for next statistic

**Case4:** The user wants to get the 60 frames read and write average bandwidth of all ID at CPU (assume the DDR type is LPDDR4). Here are the steps:

- Finish CPU AXI PERF clear step
- Assert sw\_ar\_cnt\_id\_type sw\_aw\_cnt\_id\_type 0, sw\_addr\_align\_type 2, sw\_axi\_cnt\_type 1, sw\_axi\_perf\_frm\_type 0 (PERF\_LATENCY\_CTRL0=0x00 PERF\_LATENCY\_CTRL1=0x2)
- Start CPU AXI PERF
- Start CPU and run 60 frames continually
- Read back PERF\_RD\_AXI\_TOTAL\_BYTE, this value which is divided by60 means the average total read bytes of all ID
- Read back PERF\_WR\_AXI\_TOTAL\_BYTE, this value which is divided by60 means the average total write bytes of all ID
- Clear CPU AXI\_PERF and wait for next statistic

Note:In wrap mode, DDR is always aligned. So, we must solve the deviation of bandwidth statics when the sw\_axi\_cnt\_type assert to 1 by asserting the configured bit sw\_axi\_cnt\_type\_wrap to 1.

### 4.4.4 CPU address read and write monitor case

**Case5**: The user wants to monitor CPU of ID 127 read from or write to the address area (from 0x4000 to 0x8000) action of some scenario. Here are the steps:

- Finish CPU AXI PERF clear step, assert mon\_id\_msk 0
- Assert mon\_id\_type 1, mon\_id 127, AXI\_PERFE\_RD\_MON\_ST AXI\_PERFE\_WR\_MON\_ST 0x4000, AXI\_PERFE\_RD\_MON\_END, AXI\_PERFE\_WR\_MON\_END 0x8000 (AXI\_PERFE\_CON3=0xfffffe02)
- Start CPU AXI PERF
- Start CPU, finish this scenario and wait for the AXI PERF interrupt during this period
- If CPU get AXI PERF interrupt, then read back AXI\_PERFE\_INT\_STATUS, get ar\_mon\_axi\_hit\_flag and aw\_mon\_axi\_hit\_flag, these bits can make sure whether ID 127 read from the specify address area or write to the specify address area
- If the AXI PERF interrupt is not asserted, means ID 127's action does not hit the event
- Clear CPU AXI\_PERF and wait for next statistic

**Case6:** The user wants to monitor CPU of ID0 - ID127 read from or write to the address area (from 0x14000 to 0x18000) action of some scenario. Here are the steps:

- Finish CPU AXI PERF clear step, assert mon\_id\_msk 0
- Assert mon\_id\_type 0, mon\_id 0, AXI\_PERFE\_RD\_MON\_ST AXI\_PERFE\_WR\_MON\_ST 0x14000, AXI\_PERFE\_RD\_MON\_END, AXI\_PERFE\_WR\_MON\_END 0x18000 (AXI\_PERFE\_CON3=0xffff01fc)
- Start CPU AXI PERF
- Start CPU, finish this scenario and wait for the AXI PERF interrupt during this period
- If CPU get AXI PERF interrupt, then read back AXI\_PERFE\_INT\_STATUS, get ar\_mon\_axi\_hit\_flag and aw\_mon\_axi\_hit\_flag, these bits can make sure whether these IDs read from the specify address area or write to the specify address area. We can make sure which ID hit the event by aw\_mon\_axi\_id\_status or ar\_mon\_axi\_id\_status
- If the AXI PERF interrupt is not asserted, means no ID's action hit the event
- Clear CPU AXI\_PERF and wait for next statistic

# Chapter 5 CPU\_BOOST

# 5.1 Overview

The CPU\_BOOST accelerates the CPU frequency when only one core working in the multicore system.

The CPU\_BOSOT supports following features:

- When only one core is alive (3 core are in WFI), CPU clock will turn to high freq config. The trigger condition is CRU\_APLL configuration equal to CPU\_BOOST\_APLL\_CON.
- VPLL0/VPLL1 can be use as freq borrow PLL, and also can be use as target PLL.
- When CPU\_BOOST FSM is working, the WFI cores' wakeup interrupts(include FIQ & IRQ) will be blocked by CPU\_BOOST, until the FSM back to idle.
- If the next boost activity condition is too near from last boost (the interval time is less than switch threshold). The boost condition will not trigger boost activity, until interval time is bigger than switch threshold.
- The boost activity can be counted. Including boost switch times and high freq counter.

# 5.2 Block Diagram



Fig. 5-1 CPU\_BOOST block diagram

# **5.3 Register Description**

### 5.3.1 Registers Summary

| Name                                     | Offset | Size | Reset<br>Value | Description                                  |
|------------------------------------------|--------|------|----------------|----------------------------------------------|
| BOOST_APLL_CON0                          | 0x0000 | W    | 0x0000215e     | ARM PLL control register0                    |
| BOOST APLL CON1                          | 0x0004 | W    | 0x00001046     | ARM PLL control register1                    |
| BOOST CLK CON                            | 0x0008 | w    | 0x00000000     | CPU clock select and divide control register |
| BOOST BOOST CON                          | 0x000c | W    | 0x00000000     | CPU boost control register                   |
| BOOST SWITCH CNT                         | 0x0010 | W    | 0x00000000     | Switch counter register                      |
| BOOST HIGH PERF CNTO                     | 0x0014 | W    | 0x00000000     | High performance time counter register0      |
| BOOST_HIGH_PERF_CNT1                     | 0x0018 | W    | 0x00000000     | High performance time counter register1      |
| <u>BOOST_STATIS_THRESH</u><br><u>OLD</u> | 0x001c | w    | 0x00000100     | Switch counter threshold for statistics      |
| BOOST SHORT SWITCH<br>CNT                | 0x0020 | W    | 0×00000000     | Short switch counter register                |

| Name                | Offset | Size | Reset<br>Value | Description                        |
|---------------------|--------|------|----------------|------------------------------------|
| BOOST_SWTICH_THRESH | 0x0024 | w    | 0x00000100     | Frequency change switch            |
| OLD                 | 0x0024 | vv   | 0X00000100     | threshold                          |
| BOOST_FSM_STATUS    | 0x0028 | W    | 0x00000000     | FSM status register                |
| BOOST APLL LOW CONO | 0x002c | W    | 0x0000415e     | ARM PLL low freq control register0 |
| BOOST APLL LOW CON1 | 0x0030 | W    | 0x00001046     | ARM PLL low freq control register1 |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

## 5.3.2 Detail Register Description

#### **BOOST APLL CONO**

Address: Operational Base + offset (0x0000)

| Bit   | Attr         | <b>Reset Value</b> | Description                    |                  |
|-------|--------------|--------------------|--------------------------------|------------------|
| 21.16 | 16 WO 0x0000 |                    | bit_write_mask                 |                  |
| 51.10 | vvO          | 00000              | 16 bit write mask for lsb 15-0 |                  |
| 15    | RO           | 0x0                | reserved                       |                  |
| 14:12 | עע           | DW 0.2             | postdiv1                       |                  |
| 14:12 | KW           | 0x2                | PLL factor postdiv1            |                  |
| 11.0  |              | 0x15e              | fbdiv                          |                  |
| 11:0  | II:U KW      | RW 0               | UXISE                          | PLL factor fbdiv |

#### **BOOST APLL CON1**

Address: Operational Base + offset (0x0004)

| Bit      | Attr     | <b>Reset Value</b> | Description                       |
|----------|----------|--------------------|-----------------------------------|
| 31:16 WO | 0 0.0000 | bit_write_mask     |                                   |
| 51.10    | WU       | 0x0000             | 16 bit write mask for lsb 15-0    |
| 15:13    | RO       | 0x0                | reserved                          |
|          |          |                    | dsmpd                             |
| 12       | RW       | 0x1                | when 1, PLL work at interger mode |
|          |          |                    | when 0, PLL work at frac mode     |
| 11:9     | RO       | 0x0                | reserved                          |
| 8:6      | RW       | 0x1                | postdiv2                          |
| 0:0      | KW       | UXI                | PLL factor postdiv2               |
| 5:0      | RW       | 0x06               | refdiv                            |
| 5.0      | κvv      | 0,00               | PLL factor refdiv                 |

### BOOST\_CLK\_CON

Address: Operational Base + offset (0x0008)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_mask                                                   |
| 31:16 | WO   | 0x0000             | When every bit HIGH, enable the writing corresponding bit    |
|       |      |                    | When every bit LOW, don't care the writing corresponding bit |
| 15:13 | RO   | 0x0                | reserved                                                     |
|       |      |                    | backup_pll_usage_sel                                         |
| 12    | RW   | 0x0                | 1'b0: select backup PLL for freq borrow                      |
|       |      |                    | 1'b1: select backup PLL for target PLL                       |
| 11:10 | RO   | 0x0                | reserved                                                     |

| Bit | Attr | <b>Reset Value</b> | Description                                                |  |  |
|-----|------|--------------------|------------------------------------------------------------|--|--|
| 9:8 | RW   | 0×0                | cpu_pll_sel<br>2'b00: APLL<br>2'b01: VPLL0<br>2'b10: VPLL1 |  |  |
| 7:5 | RO   | 0x0                | reserved                                                   |  |  |
| 4:0 | RW   | 0x00               | core_div_con<br>clk=clk_src/(div_con+1)                    |  |  |

#### **BOOST BOOST CON**

Address: Operational Base + offset (0x000c)

| Bit   | Attr  | <b>Reset Value</b> | Description                                                      |
|-------|-------|--------------------|------------------------------------------------------------------|
| 31:16 | WO    | 0x0000             | write_mask                                                       |
| 51:10 | WU    | 0x0000             | 16 bit write mask for lsb 15-0                                   |
| 15:13 | RO    | 0x0                | reserved                                                         |
|       |       |                    | clear_all                                                        |
|       | W1    |                    | Clear all statistics configuration, including HIGH_PERF_CNT0/1,  |
| 12    | C     | 0x0                | SWITCH_CNT, FAST_SWITCH_CNT.                                     |
|       | C     |                    | 1'b0: normal                                                     |
|       |       |                    | 1'b1: clear all statistics configuration                         |
| 11:5  | RO    | 0x0                | reserved                                                         |
|       |       |                    | statis_enalbe                                                    |
| 4     | RW    | 0x0                | 1'b0: disable                                                    |
|       |       |                    | 1'b1: enable                                                     |
|       |       |                    | apll_low_freq_en                                                 |
| 3     | RW    | 0x0                | Control apll to low frequency when boost_enable is valid:        |
| 5     | 12.00 | W UXU              | 1'b0: disable                                                    |
|       |       |                    | 1'b1: enable                                                     |
|       |       |                    | apll_sw_ctrl                                                     |
| 2     | RW    | 0x0                | 1'b0: disable                                                    |
| 2     | 1     | 0.00               | 1'b1: software control cpu_pll_sel, core_div_con, apll_slowmode, |
|       |       |                    | apll_pd                                                          |
|       |       |                    | boost_recovery                                                   |
| 1     | RW    | 0x0                | 1'b0: normal                                                     |
|       |       |                    | 1'b1: recovery                                                   |
|       |       |                    | boost_enalbe                                                     |
| 0     | RW    | 0x0                | 1'b0: disable                                                    |
|       |       |                    | 1'b1: enable                                                     |

### **BOOST SWITCH CNT**

### Address: Operational Base + offset (0x0010)

| Bit  | Attr | <b>Reset Value</b> | Description                                                          |
|------|------|--------------------|----------------------------------------------------------------------|
| 31:0 | RO   | 0_00000000         | switch_cnt<br>This 32bit counter is for accumulating switch activity |

#### **BOOST HIGH PERF CNTO**

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description                                                       |  |  |  |
|------|------|--------------------|-------------------------------------------------------------------|--|--|--|
|      |      | 0x00000000         | high_perf_cnt                                                     |  |  |  |
| 31:0 | RO   |                    | This 32bit counter [31:0] in 64bit high performance time counter, |  |  |  |
|      |      |                    | which is for accumulating CPU run in high frequency               |  |  |  |

#### **BOOST\_HIGH\_PERF\_CNT1**

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                |  |  |  |  |  |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31:0 | RO   | 0x00000000         | high_perf_cnt<br>This 32bit counter [63:32] in 64bit high performance time<br>counter, which is for accumulating CPU run in high frequency |  |  |  |  |  |

#### **BOOST STATIS THRESHOLD**

Address: Operational Base + offset (0x001c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                  |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000100         | statis_threshold<br>If the high frequency sustain time is less than threshold,<br>SHORT_SWITCH_CNT will count. This threshold is based on 24M<br>clock cycle |

#### **BOOST SHORT SWITCH CNT**

Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                   |  |  |  |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:0 | RO   | 0x00000000         | short_swtich_cnt<br>If the high frequency sustain time is less than threshold,<br>SHORT_SWITCH_CNT will count |  |  |  |

#### **BOOST SWTICH THRESHOLD**

Address: Operational Base + offset (0x0024)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                          |  |  |  |
|------|------|--------------------|------------------------------------------------------------------------------------------------------|--|--|--|
| 31:0 | RW   | 0x00000100         | switch_threshold<br>If switch activity interval time is less than threshold, freq will not<br>change |  |  |  |

#### **BOOST\_FSM\_STATUS**

Address: Operational Base + offset (0x0028)

| Bit  | Attr | <b>Reset Value</b> | Description  |  |  |  |
|------|------|--------------------|--------------|--|--|--|
| 31:9 | RO   | 0x0                | reserved     |  |  |  |
|      |      |                    | idle_state   |  |  |  |
| 8    | RO   |                    | 1'b0: normal |  |  |  |
|      |      |                    | 1'b1: idle   |  |  |  |

| Bit                                | Attr       | <b>Reset Value</b>      | Description                |  |  |  |
|------------------------------------|------------|-------------------------|----------------------------|--|--|--|
|                                    |            |                         | req_fsm                    |  |  |  |
| 7:4 RO 0x0 4'b0000: initial state. |            | 0x0                     | 4'b0000: initial state.    |  |  |  |
|                                    |            |                         | others state is busy state |  |  |  |
|                                    |            |                         | boost_fsm                  |  |  |  |
| 3:0                                | RO 0x0 4'b | 4'b0000: initial state. |                            |  |  |  |
|                                    |            |                         | others state is busy state |  |  |  |

#### BOOST APLL LOW CONO

Address: Operational Base + offset (0x002c)

| Bit   | Attr | <b>Reset Value</b> | Description                    |  |  |  |
|-------|------|--------------------|--------------------------------|--|--|--|
| 31:16 | WO   | O 0x0000           | bit_write_mask                 |  |  |  |
| 51.10 | WU   |                    | 16 bit write mask for lsb 15-0 |  |  |  |
| 15    | RO   | 0x0                | reserved                       |  |  |  |
| 14.12 | 2 RW | 2W  0x4            | postdiv1                       |  |  |  |
| 14:12 |      |                    | PLL factor postdiv1            |  |  |  |
| 11.0  |      | 0x15e              | fbdiv                          |  |  |  |
| 11:0  | RW   | UXIDE              | PLL factor fbdiv               |  |  |  |

### **BOOST APLL LOW CON1**

Address: Operational Base + offset (0x0030)

| Bit   | Attr  | <b>Reset Value</b> | Description                       |  |  |
|-------|-------|--------------------|-----------------------------------|--|--|
| 31:16 |       | 0x0000             | bit_write_mask                    |  |  |
| 51.10 | RVV   | 00000              | 16 bit write mask for lsb 15-0    |  |  |
| 15:13 | RO    | 0x0                | reserved                          |  |  |
|       | dsmpd |                    |                                   |  |  |
| 12    | RW    | 0x1                | when 1, PLL work at interger mode |  |  |
|       |       |                    | when 0, PLL work at frac mode     |  |  |
| 11:9  | RO    | 0x0                | reserved                          |  |  |
| 8:6   | RW    | 0x1                | postdiv2                          |  |  |
| 0:0   | KW    | UXI                | PLL factor postdiv2               |  |  |
| E.0   |       | N 10x06            | refdiv                            |  |  |
| 5:0   | RW    |                    | PLL factor refdiv                 |  |  |

# **5.4 Application Notes**

The CPU\_BOOST config flow is as follow. Before changing frequency:

- a. Config BOOST\_APLL\_CON0/1 and BOOST\_APLL\_LOW\_CON0/1 for single core boost frequency and multi-core normal frequency.
- b. Config BOOST\_CLK\_CON for choosing VPLL0 usage and VPLL0 div\_con.
- c. Config BOOST\_BOOST\_CON[0] for enable boost function.

Frequency change flow:

- a. Config BOOST\_BOOST\_CON[1] for enable recovery, and wait for the CPU\_BOOST back to idle state by reading BOOST\_FSM\_STATUS[8].
- b. Config BOOST\_BOOST\_CON[3:2] for enable sw\_ctrl and low\_freq\_en.
- c. Config BOOST\_CLK\_CON for choosing VPLL0 usage and VPLL0 div\_con.
- d. Config CRU\_CLKSEL0\_CON for changing CPU PLL source to VPLL0.
- e. Config CRU\_MODE\_CON[1:0] for changing APLL to slowmode.

- f. Config CRU\_APLL\_CON0/1 for re-config APLL and power\_down APLL.
- g. Config BOOST\_BOOST\_CON[3] for disable low\_freq\_en.
- h. Config CRU\_APLL\_CON1 for deassert APLL power\_down.
- i. Waiting for APLL lock.
- j. Config CRU\_MODE\_CON [1:0] for changing APLL to normalmode.
- k. Config CRU\_CLKSEL0\_CON for changing CPU PLL source back to APLL.
- I. Config BOOST\_BOOST\_CON[1] for disable recovery.
- m. Config BOOST\_BOOST\_CON[2] for disable sw\_ctrl.

# Chapter 6 Audio Subsystem

# 6.1 Overview

Audio Subsystem is embedded with rich audio interfaces such as I2S, PCM, TDM, PDM, SPDIF and so on. It's also support a VAD(Voice Activity Detection) for human voice detection which can respond to human voice request timely and fast setup intelligent voice interaction application.

Audio Subsystem supports the following features:

- I2S with 2 channel
  - Support 2 I2S\_2CH components
  - I2S\_2CH\_0 support master tx/rx mode and slave tx/rx mode
  - I2S\_2CH\_0 is connected to chip IO
  - I2S\_2CH\_1 support slave rx mode
  - I2S\_2CH\_1 is connected with Audio Codec inside chip
  - Sample rate up to 192KHz
  - Support common LRCK signal for receiving and transmitting when the sample rate are same
- I2S with 8 channel
  - Support 4 I2S\_8CH components
  - I2S\_8CH\_0 support master tx/rx mode and slave tx/rx mode
  - I2S\_8CH\_1 support master tx/rx mode and slave tx/rx mode
  - I2S\_8CH\_0/1 are connected to chip IO
  - I2S\_8CH\_0 support max 8ch in and max 8ch out simultaneously
  - I2S\_8CH\_1 support tx plus rx max 10ch simultaneously
  - I2S\_8CH\_2 support master tx/rx mode and slave tx/rx mode
  - I2S\_8CH\_3 support slave rx mode, can only works as 4CH mode
  - I2S\_8CH\_2/3 are connected with Audio Codec inside chip
  - Sample rate up to 192KHz
  - Support independent SCLK and LRCK signals for receiving and transmitting
  - Support common SCLK and LRCK signal for receiving and transmitting when the sample rate are same
- I2S with 16 channel
  - Support one I2S\_16CH by gathering I2S\_8CH\_0 and I2S\_8CH\_1
  - Support master tx/rx mode and slave tx/rx mode
  - Sample rate up to 192KHz
- PDM with 8 channel
  - Sample rate up to 192KHz
- TDM with 8 channel
  - Support 4 TDM\_8CH, share same I2S\_8CH controller accordingly
  - Sample rate up to 192KHz@2CH and 48KHz@8CH
  - Support independent SCLK and LRCK signals for receiving and transmitting
  - Support common SCLK and LRCK signal for receiving and transmitting when the sample rate are same
- SPDIF
  - Support SPDIF TX x 1
  - Support SPDIF RX x 1
  - Support HDMI ARC
  - Sample rate up to 192KHz
  - Support SPDIF RX is bypassed to SPDIF TX directly
- Voice Activity Detection(VAD)
- Embedded Audio Codec

# 6.2 Block Diagram

N/A

# **6.3 Function Description**

## 6.3.1 I2S\_2CH\_0 Application Topology

I2S\_2CH\_0 support master transmitting/receiving mode and slave transmitting/receiving mode. IO LRCK\_TX is shared for transmitting and receiving modes, user should configure the I2S0\_2CH0 register CKR[29:28] to 0x1. If user wants to use both transmitting and receiving in master mode, user should enable transmitting and receiving at the same time. The sample rate should be same when transmitting and receiving at the same time. The direction of IO MCLK is controlled by CRU. The direction of IO SCLK and IO LRCK\_TX is controlled by I2S mode, it is output when I2S is master mode, and input when I2S is slave mode.



Fig. 6-1 I2S\_2CH\_0 application topology

## 6.3.2 I2S\_2CH\_1 Application Topology

I2S\_2CH\_1 only support slave receiving mode. The input data of I2S can select from any one of Audio Codec data outputs as follow figure shows, it is configured by GRF\_SOC\_CON1[13:12]. pin\_adc\_mclk source from mclk\_i2s\_rx of I2S\_8H\_2.



Fig. 6-2 I2S\_8CH\_1 application topology

# 6.3.3 I2S\_8CH\_0 Application Topology

I2S\_8CH\_0 support master transmitting/receiving mode and slave transmitting/receiving mode. It supports maximum 8 channels transmitting and 8 channels receiving simultaneously.

IO LRCK\_TX/LRCK\_RX can be shared for transmitting and receiving modes. User can configure the I2S\_8CH\_0 register CKR[29:28] to select LRCK\_TX or LRCK\_RX as common. The sharing will reduce the IO usage. After the sharing configuration, if user wants to use both transmitting and receiving in master mode, user should enable transmitting and receiving at the same time.

IO SCLK\_TX/SCLK\_RX can be shared for transmitting and receiving modes. User can configure the GRF\_SOC\_CON2[9:8] to select SCLK\_TX or SCLK\_RX as common. The sharing will reduce the IO usage. The LRCK\_TX/LRCK\_RX must be shared when SCLK\_TX/SCLK\_RX is shared, the reverse is the same.

The direction of IO SCLK and IO LRCK\_TX is controlled by I2S mode, it is output when I2S is master mode, and input when I2S is slave mode. The source selection of I2S1\_MCLK output is controlled by GRF\_SOC\_CON2[10].



Fig. 6-3 I2S\_8CH\_0 application topology

# 6.3.4 I2S\_8CH\_1 Application Topology

I2S\_2CH\_1 support master transmitting/receiving mode and slave transmitting/receiving mode. It supports maximum 10 channels (transmitting + receiving) simultaneously, eg 8 channels transmitting and 2 channels receiving.

I2S\_2CH\_1 support two group IOMUX scheme which is controlled by GRF\_SOC\_CON2[3]. IO LRCK\_TX/LRCK\_RX can be shared for transmitting and receiving modes. User can configure the I2S\_8CH\_1 register CKR[29:28] to select LRCK\_TX or LRCK\_RX as common. The sharing will reduce the IO usage. After the sharing configuration, if user wants to use both transmitting and receiving in master mode, user should enable transmitting and receiving at the same time.

IO SCLK\_TX/SCLK\_RX can be shared for transmitting and receiving modes. User can configure the GRF\_SOC\_CON2[1:0] to select SCLK\_TX or SCLK\_RX as common. The sharing will reduce the IO usage. The LRCK\_TX/LRCK\_RX must be shared when SCLK\_TX/SCLK\_RX is shared, the reverse is the same.

The direction of IO SCLK and IO LRCK\_TX is controlled by I2S mode, it is output when I2S is master mode, and input when I2S is slave mode.

The direction of I2S1\_SD01\_SDI3\_M0/1, I2S1\_SD02\_SDI2\_M0/1, I2S1\_SD03\_SDI1\_M0/1 is controlled by GRF\_SOC\_CON2[7:5]. The source selection of I2S1\_MCLK output is controlled by GRF\_SOC\_CON2[2].



Fig. 6-4 I2S\_8CH\_1 application topology

## 6.3.5 I2S\_16CH Application Topology

Support one I2S\_16CH by gathering I2S\_8CH\_0 and I2S\_8CH\_1.

When the I2S\_16CH is slave mode, the I2S\_8CH\_0 and I2S\_8CH\_1 are both slave mode, they can transmit or receive respective to gather.

When the I2S\_16CH is master mode, one of I2S\_8CH\_0 and I2S\_8CH\_1 should be master mode and the other should be slave mode. In this case, user should enable

GRF\_SOC\_CON2[14]. The figure below shows the topology when I2S\_8CH\_0 is master mode and I2S\_8CH\_1 is slave mode, the signal sclk/lrck\_gather\_tx/rx which derived by I2S\_8CH\_0 are input to I2S\_8CH\_1. User can also set I2S\_8CH\_1 to master mode and I2S\_8CH\_0 to slave mode, in this case, the signal sclk/lrck\_gather\_tx/rx which derived by I2S\_8CH\_1 are input to I2S\_8CH\_0.





# 6.3.6 I2S\_8CH\_2 Application topology

I2S\_8CH\_2 support master transmitting/receiving mode and slave transmitting/receiving mode. For each input data of I2S, it can select any one of Audio Codec output data, it is

controlled by GRF\_SOC\_CON1[7:0]. pin\_adc\_mclk source from mclk\_i2s\_rx of I2S\_8H\_2, and pin\_dac\_mclk source from mclk\_i2s\_tx of I2S\_8H\_2.



Fig. 6-6 I2S\_8CH\_2 application topology

## 6.3.7 I2S\_8CH\_3 Application Topology

I2S\_8CH\_3 only support slave receiving mode, and it can only works as 4 channels. For each valid input data of I2S, it can select any one of Audio Codec output data, it is controlled by GRF\_SOC\_CON1[11:8].



Fig. 6-7 I2S\_8CH\_3 application topology

## 6.3.8 VAD Application Topology

VAD support read voice data from I2S\_8CH\_0~3/PDM, and then use the data to detect the amplitude of voice. As the figure following shows, the data path is (1->2)->3 when SOC work at normal mode. When SOC enable the VAD and enter low power mode, the data path is (4). User can configure to work at 1 channel when in low power mode. After the voice detection event, VAD can wake up SOC and configure to work at multichannel at the same time. When SOC return to normal mode, it can disable the VAD and return to normal data path, and it can read the backtracking data from the Internal SRAM.

When DMA is enabled, the share address range of Internal SRAM can be accessed by VAD only.

Considering the power consumption of low power mode, user can reduce the frequency of PLL. User also can power down all PLL and select the xin\_osc0 as the clock source of I2S\_8CH/PDM.



Fig. 6-8 I2S\_2CH\_3 application topology

In normal mode, the DMA request of I2S\_8CH\_0~3/PDM is handled by system DMA controller. When VAD is enabled, the DMA request is handled by VAD. The topology of I2S\_8CH\_0 DMA request is shows as following figure, I2S\_8CH\_1~3 and PDM are same.



Fig. 6-9 I2S\_8CH\_0 DMA request and acknowledge

# **6.4 Register Description**

## 6.4.1 Registers Summary

N/A

## 6.4.2 Detail Register Description

N/A

# **6.5 Application Notes**

N/A

# Chapter 7 Audio Serial Port Controller (ASPC)

# 7.1 Overview

The Audio Serial Port Controller (ASPC) is a PDM interface controller and decoder that support mono PDM format. It integrates a clock generator driving the PDM microphone and embeds filters which decimate the incoming bit stream to obtain most common audio rates. ASPC supports the following features:

- Support one internal 32-bit wide and 128-location deep FIFOs for receiving audio data
- Support receive FIFO full, overflow interrupt and all interrupts can be masked
- Support configurable water level of receive FIFO full interrupt
- Support combined interrupt output
- Support AHB bus slave interface
- Support DMA handshaking interface and configurable DMA water level
- Support PDM master receive mode
- Support 4 paths. Each path is composed of two digital microphone channels, the ASPC can be used with four stereo or eight mono microphones. Each path is enabled or disabled independently
- Support 16 ~24 bit sample resolution
- Support sample rate: 8khz,16khz,32kHz,64kHz,128khz,11.025khz,22.05khz,44.1khz,88.2khz,176.4khz,12khz ,24khz,48khz,96khz,192khz
- Support two 16-bit audio data store together in one 32-bit wide location
- Support 16 to 31 bit audio data left or right justified in 32-bit wide FIFO
- Support programmable data sampling sensibility (rising or falling edge)

# 7.2 Block Diagram



#### System Interface

Fig. 7-1 ASPC Block Diagram

The system interface implements the APB slave operation. It contains not only control registers of receiver inside but also interrupt and DMA handshaking interface.

#### **Clock Generator**

The Clock Generator implements clock generation function. The input source clock to the module is MCLK, and by the divider of the module, the clock generator generates CLK\_PDM to receiver.

#### Receiver

The receiver can act as a decimation filter of PDM. And export PCM format data.

### **Receive FIFO**

The Receive FIFO is the buffer to store received audio data. The size of the FIFO is 32bits x

#### 128. ASP interface

The ASP interface implements PDM bit streams receive operation.

# 7.3 Function Description

## 7.3.1 AHB Interface

There is an AHB slave interface in ASPC. It is responsible for accessing registers and internal memories. The addresses of these registers and memories are listed in 7.4.1.

## 7.3.2 PDM Interface

The PDM interface is a 5-wire interface. The ASPC module can support up to four external stereo and eight digital microphones.

Follow two figure show two cases of use of the ASPC, but all configurations are possible with stereo and mono digital microphones.



Fig. 7-2 ASPC with Eight Mono MIC



Fig. 7-3 ASPC with Four Stereo MIC

The PDM interface consists of a serial-data shift clock output (ASP\_CLK) and a serial data input (ASP\_DATA). The clock is fanned out to both digital mics, and both digital mics' data (left channel and right channel) outputs share a single signal line. To share a single line, the digital mics tristate their output during one phase of the clock(high or low part of cycle, depending on how they are configured via their L/R input).



# 7.3.3 Digital Filter

The external PDMIC generates a PDM stream of bits and transfers it in one period or one half-period of the clock provided by the ASPC. The aim of the ASPC is to process data from the PDM interface, decimate and filter the data, and store the processed data in the FIFO. The four paths are identical. Each path is composed of a left and a right channel. The PDM interface delivers eight parallel data of 1 bit. Each bit goes to a filter. The aim of the filter is to limit the noise and export PCM format audio data.

## 7.3.4 Frequency Configuration

MCLK is the source clock signal. ASP\_CLK is the output clocks generated in the ASPC and is fed to the external microphones. They are also the internal clock of the external

microphones. User must take care about the value of ASP\_CLK when selecting the source clock (MCLK).



Fig. 7-5 ASPC Clock Structure

| Table 7-1 Relation between ASP_CLK and sample rate |  |
|----------------------------------------------------|--|
|                                                    |  |

| ASP_CLK   | Sample rate                                 |  |  |  |  |
|-----------|---------------------------------------------|--|--|--|--|
| 3.072Mhz  | 12khz,24khz,48khz,96khz,192khz              |  |  |  |  |
| 2.8224Mhz | 11.025khz,22.05khz,44.1khz,88.2khz,176.4khz |  |  |  |  |
| 2.048Mhz  | 8khz,16khz,32kHz,64kHz,128khz               |  |  |  |  |
|           |                                             |  |  |  |  |

User must configure the div\_con depended on the frequency of MCLK. If MCLK/ASP\_CLK is more than 40, ASPC\_CLK\_CTRL[6] should set to 0; if MCLK/ASP\_CLK is less than 35, ASPC\_CLK\_CTRL[6] should set to 1.

# 7.4 Register Description

## 7.4.1 Registers Summary

| Name                 | Offset | Size | Reset<br>Value | Description                              |
|----------------------|--------|------|----------------|------------------------------------------|
| ASPC SYSCONFIG       | 0x0000 | W    | 0x00000000     | ASPC system configure register           |
| ASPC CTRL0           | 0x0004 | W    | 0x78000017     | ASPC control register 0                  |
| ASPC CTRL1           | 0x0008 | W    | 0x0bb8ea60     | ASPC control register 1                  |
| ASPC_CLK_CTRL        | 0x000c | W    | 0x00000000     | ASPC clock control register              |
| ASPC HPF CTRL        | 0x0010 | W    | 0x0000000      | ASPC high pass filter control register   |
| ASPC_FIFO_CTRL       | 0x0014 | W    | 0x00000000     | ASPC FIFO control register               |
| ASPC DMA CTRL        | 0x0018 | W    | 0x0000001f     | ASPC DMA control register                |
| ASPC_INT_EN          | 0x001c | W    | 0x00000000     | ASPC interrupt enable register           |
| ASPC_INT_CLR         | 0x0020 | W    | 0x00000000     | ASPC interrupt clear register            |
| ASPC INT ST          | 0x0024 | W    | 0x00000000     | ASPC interrupt status register           |
| ASPC_RXFIFO_DATA_REG | 0x0030 | W    | 0x00000000     | ASPC receive FIFO data register          |
| ASPC DATAOR REG      | 0x0034 | w    | 0x00000000     | ASPC path0 right channel data register   |
| ASPC DATAOL REG      | 0x0038 | w    | 0x0000000      | ASPC path0 left channel data<br>register |
| ASPC_DATA1R_REG      | 0x003c | W    | 0x00000000     | ASPC path1 right channel data register   |
| ASPC_DATA1L_REG      | 0x0040 | W    | 0x0000000      | ASPC path1 left channel data register    |

| Name            | Offset | Size | Reset<br>Value | Description                                     |
|-----------------|--------|------|----------------|-------------------------------------------------|
| ASPC DATA2R REG | 0x0044 | W    | 0x00000000     | ASPC path2 right channel data<br>register       |
| ASPC_DATA2L_REG | 0x0048 | w    | 0x00000000     | ASPC path2 left channel data<br>register        |
| ASPC DATA3R REG | 0x004c | w    | 0x00000000     | ASPC path3 right channel data<br>register       |
| ASPC DATA3L REG | 0x0050 | w    | 0x00000000     | ASPC path3 left channel data<br>register        |
| ASPC DATA VALID | 0x0054 | W    | 0x00000000     | Path data valid register                        |
| ASPC VERSION    | 0x0058 | W    | 0x59313030     | ASPC version register                           |
| ASPC_INCR_RXDR  | 0x0400 | W    | 0x00000000     | Increment address receive FIFO<br>data register |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

## 7.4.2 Detail Register Description

### ASPC\_SYSCONFIG

Address: Operational Base + offset (0x0000)

| Bit  | Attr | <b>Reset Value</b> | Description                            |
|------|------|--------------------|----------------------------------------|
| 31:3 | RO   | 0x0                | reserved                               |
|      |      |                    | rx_start                               |
| 2    | RW   | 0.20               | RX Transfer start bit                  |
| 2    | RW   | 0x0                | 1'b0:stop RX transfer                  |
|      |      |                    | 1'b1:start RX transfer                 |
| 1    | RO   | 0x0                | reserved                               |
|      |      |                    | rx_clr                                 |
|      |      |                    | ASPC RX logic clear                    |
|      |      |                    | This is a self cleard bit. High active |
| 0    | RW   | 0x0                | Write 0x1: clear RX logic              |
|      |      |                    | Write 0x0: no action                   |
|      |      |                    | Read 0x1: clear ongoing                |
|      |      |                    | Read 0x0: clear done                   |

## ASPC\_CTRL0

Address: Operational Base + offset (0x0004)

| Bit | Attr | <b>Reset Value</b> | Description                                                       |
|-----|------|--------------------|-------------------------------------------------------------------|
|     |      |                    | sjm_sel                                                           |
|     |      |                    | Store justified mode:                                             |
|     |      |                    | (Can be written only when SYSCONFIG[2] is 0.)                     |
|     |      |                    | 16bit~31bit DATA stored in 32 bits width fifo.                    |
| 31  | RW   | 0x0                | If VDW select 16bit data, this bit is valid only when HWT select  |
|     |      |                    | 1.Because if HWT is 0, every fifo unit contain two 16bit data and |
|     |      |                    | 32 bit space is full, it is impossible to choose justified mode.  |
|     |      |                    | 1'b0:right justified                                              |
|     |      |                    | 1'b1:left justified                                               |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                             |  |  |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 30    | RW   | 0x1         | path3_en<br>Path 3 enable<br>1'b1: enable<br>1'b0: disable                                                                                                                                                                                                              |  |  |
| 29    | RW   | 0x1         | path2_en<br>Path 2 enable<br>1'b1: enable<br>1'b0: disable                                                                                                                                                                                                              |  |  |
| 28    | RW   | 0×1         | path1_en<br>Path 1 enable<br>1'b1: enable<br>1'b0: disable                                                                                                                                                                                                              |  |  |
| 27    | RW   | 0x1         | path0_en<br>Path 0 enable<br>1'b1: enable<br>1'b0: disable                                                                                                                                                                                                              |  |  |
| 26    | RW   | 0×0         | hwt_en<br>HWT<br>Halfword word transform<br>Only valid when VDW select 16bit data<br>1'b0: 32 bit data valid to AHB/APB bus. Low 16 bit for left<br>channel and high 16 bit for right channel<br>1'b1: low 16bit data valid to AHB/APB bus, high 16 bit data<br>invalid |  |  |
| 25:16 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                |  |  |
| 15:8  |      |             | int_div_con<br>integer divider<br>can be written only when SYSCONFIG[2] is 0                                                                                                                                                                                            |  |  |
| 7:5   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                |  |  |
| 4:0   | RW   | 0x17        | data_vld_width<br>(Can be written only when SYSCONFIG[2] is 0.)<br>Valid Data width<br>0~14: reserved<br>15: 16bit<br>16: 17bit<br>17: 18bit<br>18: 19bit<br><br>n: (n+1)bit<br>                                                                                        |  |  |

## ASPC CTRL1

Address: Operational Base + offset (0x0008)

| Bit   | Attr | <b>Reset Value</b> | Description                                   |
|-------|------|--------------------|-----------------------------------------------|
|       |      |                    | frac_div_numerator                            |
| 31:16 | RW   | 0x0bb8             | fraction divider numerator                    |
|       |      |                    | (Can be written only when SYSCONFIG[2] is 0.) |
|       |      |                    | frac_div_denomonator                          |
| 15:0  | RW   | 0xea60             | fraction divider denominator                  |
|       |      |                    | (Can be written only when SYSCONFIG[2] is 0.) |

## ASPC CLK CTRL

Address: Operational Base + offset (0x000c)

| Bit  |    | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                     |
|------|----|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO | 0x0                | reserved                                                                                                                                                                                                                                                                                        |
| 6    | RW | 0×0                | frac_div_ratio_sel<br>fraction clk divider ratio select:<br>(Can be written only when SYSCONFIG[2] is 0.)<br>1'b0: ratio is more than 40<br>1'b1: ratio is less than 35                                                                                                                         |
| 5    | RW | 0x0                | pdm_clk_en<br>Pdm clk enable.working at PDM mode<br>(Can be written only when SYSCONFIG[2] is 0.)<br>1'b0: pdm clk disable<br>1'b1: pdm clk enable                                                                                                                                              |
| 4    | RW | 0×0                | div_type_sel<br>divider type select signal<br>1'b0: fraction divider<br>1'b1: integer divider<br>(Can be written only when SYSCONFIG[2] is 0.)                                                                                                                                                  |
| 3    | RW | 0×0                | clk_polar<br>ASP_CLK polarity selection<br>(Can be written only when SYSCONFIG[2] is 0.)<br>1'b0: no inverted<br>1'b1: inverted                                                                                                                                                                 |
| 2:0  | RW | 0x0                | pdm_ds_ratio<br>DS_RATIO,working at PDM mode<br>(Can be written only when SYSCONFIG[2] is 0.)<br>3'b000: sample rate 192k/176.5k/128k<br>3'b001: sample rate 96kk/88.2k/64k<br>3'b010: sample rate 96kk/44.1k/32k<br>3'b011: sample rate 24kk/22.05k/16k<br>3'b100: sample rate 12kk/11.025k/8k |

# ASPC HPF CTRL

Address: Operational Base + offset (0x0010)

| Bit  | Attr | <b>Reset Value</b> |          | Description |  |
|------|------|--------------------|----------|-------------|--|
| 31:4 | RO   | 0x0                | reserved |             |  |

| Bit | Attr | Reset Value | Description                                          |
|-----|------|-------------|------------------------------------------------------|
|     |      |             | hpfle                                                |
| 3   | RW   | 0x0         | HPFLE<br>high pass filter enable for left channel    |
|     |      |             | 1'b0: high pass filter for right channel is disabled |
|     |      |             | 1'b1: high pass filter for right channel is enabled  |
|     |      |             | hpfre                                                |
|     |      |             | HPFRE                                                |
| 2   | RW   | 0x0         | high pass filter enable for right channel            |
|     |      |             | 1'b0: high pass filter for right channel is disabled |
|     |      |             | 1'b1: high pass filter for right channel is enabled  |
|     |      |             | hpf_cf                                               |
|     |      |             | HPF_CF                                               |
|     |      |             | high pass filter configure register                  |
| 1:0 | RW   | 0x0         | 2'b00: 3.79Hz                                        |
|     |      |             | 2'b01: 60Hz                                          |
|     |      |             | 2'b10: 243Hz                                         |
|     |      |             | 2'b11: 493Hz                                         |

### ASPC\_FIFO\_CTRL

Address: Operational Base + offset (0x0014)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                      |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | RO   | 0x0                | reserved                                                                                                                                                                         |
| 14:8  | RW   | 0×00               | rft<br>Receive FIFO Threshold<br>When the number of receive FIFO entries is more than or equal to<br>this threshold plus 1, the receive FIFO threshold interrupt is<br>triggered |
| 7:0   | RO   | 0x00               | rfl<br>RFL<br>Receive FIFO Level<br>Contains the number of valid data entries in the receive FIFO                                                                                |

## ASPC DMA CTRL

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                            |  |
|------|------|--------------------|----------------------------------------------------------------------------------------|--|
| 31:9 | RO   | 0x0                | reserved                                                                               |  |
| 8    | RW   | 0×0                | rde<br>Receive DMA Enable<br>1'b0 : Receive DMA disabled<br>1'b1 : Receive DMA enabled |  |
| 7    | RO   | 0x0                | reserved                                                                               |  |

| Bit | Attr     | <b>Reset Value</b> | Description                                                         |
|-----|----------|--------------------|---------------------------------------------------------------------|
|     |          |                    | rdl                                                                 |
|     | 6:0 RW ( | 0x1f               | Receive Data Level                                                  |
| 6.0 |          |                    | This bit field controls the level at which a DMA request is made by |
| 0.0 |          |                    | the receive logic. The watermark level = DMARDL+1; that is,         |
|     |          |                    | dma_rx_req is generated when the number of valid data entries       |
|     |          |                    | in the receive FIFO is equal to or above this field value + 1       |

#### ASPC INT EN

Address: Operational Base + offset (0x001c)

| Bit  | Attr | <b>Reset Value</b> | Description                   |
|------|------|--------------------|-------------------------------|
| 31:2 | RO   | 0x0                | reserved                      |
|      |      |                    | rxoie                         |
| 1    | RW   | 0.40               | RX overflow interrupt enable  |
| L .  | RVV  | 0×0                | 1'b0: disable                 |
|      |      |                    | 1'b1: enable                  |
|      |      |                    | rxtie                         |
| 0    |      | 0×0                | RX threshold interrupt enable |
| 0    | RW   |                    | 1'b0: disable                 |
|      |      |                    | 1'b1: enable                  |

#### ASPC INT\_CLR

Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:2 | RO   | 0x0                | reserved                                             |
| 4    | W1   | 00                 | rxoic                                                |
| L    | С    | 0x0                | RX overflow interrupt clear, high active, auto clear |
| 0    | RO   | 0x0                | reserved                                             |

## ASPC INT ST

Address: Operational Base + offset (0x0024)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |
|------|------|--------------------|-----------------------------------------------------------------|
| 31:2 | RO   | 0x0                | reserved                                                        |
| 1    | RO   | 0×0                | rxoi<br>RX overflow interrupt<br>1'b0: inactive<br>1'b1: active |
| 0    | RO   | 0x0                | rxfi<br>RX full interrupt<br>1'b0: inactive<br>1'b1: active     |

### ASPC RXFIFO DATA REG

Address: Operational Base + offset (0x0030)

### RK3308 TRM-Part1

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                     |
|------|------|--------------------|-------------------------------------------------------------------------------------------------|
| 31:0 |      |                    | rxdr<br>Dessive FIFO shadow Desister                                                            |
| 51:0 | RO   |                    | Receive FIFO shadow Register<br>When the register is read, data in the receive FIFO is accessed |

### ASPC DATAOR REG

Address: Operational Base + offset (0x0034)

| Bit  | Attr | <b>Reset Value</b> | Description                      |
|------|------|--------------------|----------------------------------|
| 31:0 | RO   | 0x00000000         | data0r                           |
| 51.0 |      |                    | Data of the path 0 right channel |

#### ASPC DATAOL REG

Address: Operational Base + offset (0x0038)

| Bit  | Attr | <b>Reset Value</b> | Description                     |
|------|------|--------------------|---------------------------------|
| 31:0 | RO   | 0x00000000         | data0l                          |
| 31:0 |      |                    | Data of the path 0 left channel |

#### ASPC DATA1R REG

Address: Operational Base + offset (0x003c)

| Bit  | Attr | <b>Reset Value</b> | Description                      |
|------|------|--------------------|----------------------------------|
| 31:1 | RO   | 0x0                | reserved                         |
| 0    |      | 0x0                | data1r                           |
| 0    | RO   |                    | Data of the path 1 right channel |

### ASPC DATA1L REG

Address: Operational Base + offset (0x0040)

| Bit  | Attr | <b>Reset Value</b> | Description                     |
|------|------|--------------------|---------------------------------|
| 31:0 | RO   | 0x00000000         | data1l                          |
| 51.0 |      |                    | Data of the path 1 left channel |

#### ASPC DATA2R REG

Address: Operational Base + offset (0x0044)

| Bit  | Attr | <b>Reset Value</b> | Description                      |
|------|------|--------------------|----------------------------------|
| 31:0 | RO   | 0x00000000         | data2r                           |
| 51.0 | κυ   | 0x00000000         | Data of the path 2 right channel |

#### ASPC DATA2L REG

Address: Operational Base + offset (0x0048)

| Bit  | Attr | <b>Reset Value</b> | Description                     |
|------|------|--------------------|---------------------------------|
| 31:0 | RO   | 0×00000000         | data2l                          |
| 31:0 |      |                    | Data of the path 2 left channel |

#### ASPC DATA3R REG

Address: Operational Base + offset (0x004c)

| Bit  | Attr | <b>Reset Value</b> | Description                                |
|------|------|--------------------|--------------------------------------------|
| 31:0 | RO   | 0x00000000         | data3r<br>Data of the path 3 right channel |

### ASPC DATA3L REG

Address: Operational Base + offset (0x0050)

| Bit  | Attr | <b>Reset Value</b> | Description                               |
|------|------|--------------------|-------------------------------------------|
| 31:0 | RO   | 0×00000000         | data3l<br>Data of the path 3 left channel |

### ASPC DATA VALID

Address: Operational Base + offset (0x0054)

| Bit  | Attr | <b>Reset Value</b> | Description                                   |
|------|------|--------------------|-----------------------------------------------|
| 31:4 | RO   | 0x0                | reserved                                      |
|      |      |                    | path0_vld                                     |
| 3    | RC   | 0x0                | 1'b0: DATA0R_REG, DATA0L_REG value is invalid |
|      |      |                    | 1'b1: DATA0R_REG, DATA0L_REG value is valid   |
|      |      |                    | path1_vld                                     |
| 2    | RC   | 0x0                | 1'b0: DATA1R_REG, DATA1L_REG value is invalid |
|      |      |                    | 1'b1: DAT1R_REG, DATA1L_REG value is valid    |
|      |      |                    | path2_vld                                     |
| 1    | RC   | 0x0                | 1'b0: DATA2R_REG, DATA2L_REG value is invalid |
|      |      |                    | 1'b1: DATA2R_REG, DATA2L_REG value is valid   |
|      |      |                    | path3_vld                                     |
| 0    | RC   | 0x0                | 1'b0: DATA3R_REG, DATA3L_REG value is invalid |
|      |      |                    | 1'b1: DATA3R_REG, DATA3L_REG value is valid   |

### ASPC VERSION

Address: Operational Base + offset (0x0058)

| Bit  | Attr | <b>Reset Value</b> | Description             |
|------|------|--------------------|-------------------------|
| 31:0 | RO   | 0x59313030         | version<br>ASPC version |

### ASPC RXDR

Address: Operational Base + offset (0x0400)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                    |  |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|--|
| 31:0 | RO   |                    | receive_fifo_data<br>FIFO data can be read from these registers, This register is used<br>when the access address is Increment |  |

# 7.5 Interface Description

| Table 7-2 ASPC Interface Description |               |                                                                          |                                                            |  |  |
|--------------------------------------|---------------|--------------------------------------------------------------------------|------------------------------------------------------------|--|--|
| Module Pin                           | Directi<br>on | Pin Name                                                                 | IOMUX Setting                                              |  |  |
| O_asp_clk                            | 0             | GPIO1_A4/LCDC_D0/I2S1_8CH_SCL<br>K_RX_M0/PDM_8CH_CLK_M0                  | GRF_GPIO1A_IOMUX[9:8]=2'B11                                |  |  |
|                                      |               | GPIO1_B6/LCDC_D10/I2S1_8CH_SC<br>LK_RX_M1/PDM_8CH_CLK_M1/MAC_<br>MDIO    | GRF_GPIO1B_IOMUX_L[15:12]=4'B100                           |  |  |
|                                      |               | GPIO2_A6/I2S0_8CH_SCLK_RX/PDM<br>_8CH_CLK_S_M2                           | GRF_GPIO2A_IOMUX[13:12]=2'B10                              |  |  |
|                                      |               | GPIO2_A4/I2S0_8CH_MCLK/PDM_8C<br>H_CLK_M_M2                              | GRF_GPIO2A_IOMUX[13:12]=2'B10<br>GRF_SOC_CON12[2]=1'B1     |  |  |
| I_asp_data0                          | I             | GPIO1_B3/LCDC_D7/I2S1_8CH_SDI<br>0_M0/PDM_8CH_SDI0_M0                    | GRF_GPIO1B_IOMUX_L[7:6]=2'B11<br>GRF_SOC_CON2[12]=2'B00    |  |  |
|                                      |               | GPIO1_C5/LCDC_D17/I2S1_8CH_SD<br>I0_M1/PDM_8CH_SDI0_M1/MAC_RX<br>D1      | GRF_GPIO1C_IOMUX_H[3:0]=4'B100<br>GRF_SOC_CON2[12]=2'B01   |  |  |
|                                      |               | GPIO2_B5/I2S0_8CH_SDI0/PDM_8C<br>H_SDI0_M2                               | GRF_GPIO2B_IOMUX[11:10]=2'B10<br>GRF_SOC_CON2[12]=2'B10    |  |  |
| I_asp_data1                          | I             | GPIO1_B2/LCDC_D6/I2S1_8CH_SDO<br>3_SDI1_M0/PDM_8CH_SDI1_M0               | GRF_GPI01B_IOMUX_L[5:4]=2'B11<br>GRF_SOC_CON2[12]=2'B00    |  |  |
|                                      |               | GPIO1_C4/LCDC_D16/I2S1_8CH_SD<br>O3_SDI1_M1/PDM_8CH_SDI1_M1/M<br>AC_RXD0 | GRF_GPIO1C_IOMUX_L[15:12]=4'B100<br>GRF_SOC_CON2[12]=2'B01 |  |  |
|                                      |               | GPIO2_B6/I2S0_8CH_SDI1/PDM_8C<br>H_SDI1_M2                               | GRF_GPIO2B_IOMUX[13:12]=2'B10<br>GRF_SOC_CON2[12]=2'B10    |  |  |
| I_asp_data2                          | Ι             | GPIO1_B1/LCDC_D5/I2S1_8CH_SDO<br>2_SDI2_M0/PDM_8CH_SDI2_M0               | GRF_GPIO1B_IOMUX_L[3:2]=2'B11<br>GRF_SOC_CON2[12]=2'B00    |  |  |
|                                      |               | GPIO1_C3/LCDC_D15/I2S1_8CH_SD<br>O2_SDI2_M1/PDM_8CH_SDI2_M1/M<br>AC_TXD1 | GRF_GPIO1C_IOMUX_L[11:8]=4'B100<br>GRF_SOC_CON2[12]=2'B01  |  |  |
|                                      |               | GPIO2_B7/I2S0_8CH_SDI2/PDM_8C<br>H_SDI2_M2                               | GRF_GPIO2B_IOMUX[15:14]=2'B10<br>GRF_SOC_CON2[12]=2'B10    |  |  |
| I_asp_data3                          | I             | GPIO1_B0/LCDC_D4/I2S1_8CH_SDO<br>1_SDI3_M0/PDM_8CH_SDI3_M0               | GRF_GPIO1B_IOMUX_L[1:0]=2'B11<br>GRF_SOC_CON2[12]=2'B00    |  |  |
|                                      |               | GPIO1_C2/LCDC_D14/I2S1_8CH_SD<br>O1_SDI3_M1/PDM_8CH_SDI3_M1/M<br>AC_TXD0 | GRF_GPI01C_IOMUX_L[7:4]=4'B100<br>GRF_SOC_CON2[12]=2'B01   |  |  |
|                                      |               | GPIO2_C0/I2S0_8CH_SDI3/PDM_8C<br>H_SDI3_M2                               | GRF_GPIO2C_IOMUX[1:0]=2'B10<br>GRF_SOC_CON2[12]=2'B10      |  |  |

Notes: I=input, O=output, I/O=input/output, bidirectional When use GPIO2\_A4/I2S0\_8CH\_MCLK/PDM\_8CH\_CLK\_M\_M2, the output enable is control by pmic\_sleep

# 7.6 Application Notes



Fig. 7-6 ASPC operation flow

# **Chapter 8 Audio Codec**

# 8.1 Overview

Audio Codec is a low power, high resolution, stereo CODEC solution which employs Sigma-Delta noise-shaping technique. The ADC, DAC and power amplifier are integrated to provide total solutions. With 24 bits resolution for DAC and 24 bits resolution for ADC, Audio Codec is suitable for applications in high end consumer digital audio systems, automobile audio, multimedia and digital systems. It supports following features:

- 24 bits DAC with 93dB(A-weighted) SNR
- Support  $16 \sim 32\Omega$  headphone out and  $10k\Omega$  line output
- 24 bits ADC with 92dB(A-weighted) SNR
- Support single-ended or differential microphone input
- Automatic Level Control (ALC) for smooth audio recording
- Pure logic process: no need for mixed signal layers and less mask cost
- Low power: DAC 3mA per channel, ADC 2.5mA per channel, less than 0.05mA for standby
- Support Mono, Stereo, 5.1 and 7.1 HiFi channel performance
- Programmable input and output analog gains
- Digital interpolation and decimation filter integrated
- Sampling rate of 8kHz/11.025kHz/12kHz/16kHz/22.05kHz/24kHz/32kHz/44.1kHz/48kHz/64kHz/88.2kHz /96kHz/128kHz/176.4kHz/192kHz
- 1.8V supply for analog and 1.0V supply for digital

# 8.2 Block Diagram



Fig. 8-1 Audio Codec overview

The default Audio Codec IP contains 2 DAC channels for stereo playback and 8 ADC channels for stereo recording from microphone.

# **8.3 Function description**

## 8.3.1 Digital Interface

Audio Codec IP provides the I2S PCM interface of audio data stream which gets into DAC and out from ADC, both of which can be configured in master or slave mode. Different audio data formats are available for different operating modes. This is demonstrated in following table.

| Data Farmata                               | ADC          |              | DAC          |              |
|--------------------------------------------|--------------|--------------|--------------|--------------|
| Ata Formats Left Justified Right Justified | Master       | Slave        | Master       | Slave        |
| Left Justified                             | $\checkmark$ | ×            | $\checkmark$ | $\checkmark$ |
| Right Justified                            | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| I2S                                        | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| DSP/PCM mode A                             | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| DSP/PCM mode B                             | $\checkmark$ | ×            |              | $\checkmark$ |

Table 8-1 Supported Data Formats in Different Modes

I2S\_PCM interface supports five audio data formats: Left Justified mode, Right Justified mode, I2S mode, DSP/PCM mode A and mode B. They are valid when the device operates as

#### a master or slave.

For Left Justified mode, the data format is illustrated in Fig. 8-2. The MSB is valid at the first rising edge of sck after ws transition is done. The other valid bits up to the LSB are transmitted sequentially. Due to varied word length, different sck frequency and sample rate, some unused sck cycles may appear before every ws transition, which means the data in this period is invalid.



Fig. 8-2 Left Justified Mode (assuming n-bit word length)

For Right Justified mode, the data format is shown in Fig. 8-3. The LSB becomes valid at the last rising edge of sck before ws transition is done. As the MSB is transmitted first, the other valid bits up to the MSB are followed in order. Due to varied word length, different sck frequency and sample rate, some unused sck cycles may exist after every ws transition, which means the data in this period is invalid.



Fig. 8-3 Right Justified Mode (assuming n-bit word length)

For I2S mode, the data format is depicted in Fig. 8-4. The MSB becomes available at the second rising edge of sck when ws transition is done. The other valid bits up to the LSB are transmitted in order. Due to varied word length, different sck frequency and sample rate, some unused sck cycles may appear between the LSB of the current sample and the MSB of the next one, which means the data in this period can be ignored.



Fig. 8-4 I2S Mode (assuming n-bit word length)

For DSP/PCM mode, the left channel data is transmitted first, followed by right channel data. For DSP/PCM mode A/B, the MSB is available at the second and first rising edge of sck after the rising edge of ws respectively, as shown in Fig. 8-5 and Fig.8-6. Based on word length, sck frequency and sample rate, there may be some invalid data between the LSB of the right channel data and the next sample.



Fig. 8-5 DSP/PCM Mode A (assuming n-bit word length)



Fig. 8-6 DSP/PCM Mode B (assuming n-bit word length)

### 8.3.2 Analog Interface





There are two microphone input pin, MICP and MICN. They can be configured as differential inputs by the microphone PGA (MIC).

The signal of microphone output should be input to Audio Codec through DC-blocking capacitor, as shown in following figure.



Fig. 8-8 Input DC-blocking capacitor

The capacitance and input resistance from a high pass filter. For example, when the gain of the MIC module is 20dB, the input resistance is  $45k\Omega$  and 0.1uF DC-blocking capacitor is used, the lower cut-off frequency is:

$$f = \frac{1}{2\pi RC} = \frac{1}{2\pi \times 45 \times 10^3 \times 0.1 \times 10^{-6}} = 35.4 Hz$$

The capacitance of the DC-blocking capacitor should be determined by the minimum input impedance and application requirements. If the output of microphone is single-ended, the audio ADC input should be connected as following figure.



Fig. 8-9 Input single-ended DC-blocking capacitor

Microphone PGA has two gains to amplify the input signal, that is 0dB and +20dB. Automatic Level Control (ALC) function is included to adjust the signal level, which is input into ADC. ALC will measure the signal magnitude and compare it to defined threshold. Then it will adjust the ALC controlled gain (ALC\_L and ALC\_R) according to the comparison result. When the AGC function is off, the gain (ALC\_L and ALC\_R) is directly controlled by register, and the programmable gain range is from -18dB to +28.5dB, and the tuning step is 1.5dB. Audio Codec supports two line output and two headphone out configurations. The DAC output can drive load through DC-blocking capacitor.

In the configuration using DC-blocking capacitor, shown in the following figure, the headphone ground is connected to the real ground. The capacitance and the load resistance determine the lower cut-off frequency. For instance, if  $600\Omega$  load and 4.7uF DC-blocking capacitor are used, the lower cut-off frequency is:

$$f = \frac{1}{2\pi RC} = \frac{1}{2\pi \times 600 \times 4.7 \times 10^{-6}} = 56.5 Hz$$

The DC-blocking capacitor can be increased to lower the cut-off frequency for better bass response.



Fig. 8-10 Output DC-blocking capacitor

The headphone-out driver has a gain range from -39dB to +6dB with a tuning step of 1.5dB. The line out driver has a gain range from -16.5dB to +6dB with a tuning step of 1.5dB.

## **8.3.3** Interface Relationship

The relationships between I2S interface and parallel audio data for different ADC and DAC channels are shown in the following figure.





# **8.4 Register Description**

## 8.4.1 Register Summary

| Name                     | Offset | Size | Reset<br>Value | Description                     |
|--------------------------|--------|------|----------------|---------------------------------|
| ACODEC GLB CON           | 0x0000 | W    | 0x0000007      | Global Control Register         |
| ACODEC_ADC_DIG_CON1      | 0x0004 | W    | 0x00000050     | ADC Digital Control 1 Register  |
| ACODEC_ADC_DIG_CON2      | 0x0008 | W    | 0x000000e      | ADC Digital Control 2 Register  |
| ACODEC ADC DIG CON3      | 0x000c | W    | 0x0000000f     | ADC Digital Control 3 Register  |
| ACODEC_ADC_DIG_CON4      | 0x0010 | W    | 0x0000004      | ADC Digital Control 4 Register  |
| ACODEC ADC DIG CON7      | 0x001c | W    | 0x00000000     | ADC Digital Control 7 Register  |
| ACODEC ALC DIG CONO      | 0x0040 | W    | 0x00000000     | ALC Digital Control 0 Register  |
| ACODEC_ALC_DIG_CON1      | 0x0044 | W    | 0x0000046      | ALC Digital Control 1 Register  |
| ACODEC ALC DIG CON2      | 0x0048 | W    | 0x0000041      | ALC Digital Control 2 Register  |
| ACODEC ALC DIG CON3      | 0x004c | W    | 0x0000002c     | ALC Digital Control 3 Register  |
| ACODEC_ALC_DIG_CON4      | 0x0050 | W    | 0x00000000     | ALC Digital Control 4 Register  |
| ACODEC ALC DIG CON5      | 0x0054 | W    | 0x0000026      | ALC Digital Control 5 Register  |
| ACODEC ALC DIG CON6      | 0x0058 | W    | 0x0000040      | ALC Digital Control 5 Register  |
| ACODEC ALC DIG CON7      | 0x005c | W    | 0x0000036      | ALC Digital Control 7 Register  |
| ACODEC ALC DIG CON8      | 0x0060 | W    | 0x0000020      | ALC Digital Control 8 Register  |
| ACODEC_ALC_DIG_CON9      | 0x0064 | W    | 0x0000038      | ALC Digital Control 9 Register  |
| ACODEC ALC DIG CON1<br>2 | 0x0070 | w    | 0x0000000c     | ALC Digital Control 12 Register |
| ACODEC DAC DIG CON1      | 0x0304 | W    | 0x00000050     | DAC Digital Control 1 Register  |
| ACODEC DAC DIG CON2      | 0x0308 | W    | 0x0000000e     | DAC Digital Control 2 Register  |

| Name                | Offset  | Size | Reset<br>Value | Description                      |
|---------------------|---------|------|----------------|----------------------------------|
| ACODEC DAC DIG CON3 | 0x030c  | W    | 0x00000000     | DAC Digital Control 3 Register   |
| ACODEC DAC DIG CON4 |         | W    | 0x00000022     | DAC Digital Control 4 Register   |
| ACODEC DAC DIG CON5 | 0x0314  | W    | 0x00000000     | DAC Digital Control 5 Register   |
| ACODEC DAC DIG CON1 |         |      |                |                                  |
| <u>0</u>            | 0x0328  | W    | 0x0000000f     | DAC Digital Control 10 Register  |
| ACODEC_DAC_DIG_CON1 | 0,022.5 | 14/  | 0x000000ff     | DAC Digital Control 11 Degister  |
| <u>1</u>            | 0x032c  | W    | 0x00000011     | DAC Digital Control 11 Register  |
| ACODEC_DAC_DIG_CON1 | 0x0330  | w    | 0x00000003     | DAC Digital Control 12 Register  |
| 2                   | 0X0330  | vv   | 0x00000005     | DAC Digital Control 12 Register  |
| ACODEC DAC DIG CON1 | 0x0334  | w    | 0x000000c2     | DAC Digital Control 13 Register  |
| <u>3</u>            | 070334  | ••   | 0,00000002     |                                  |
| ACODEC DAC DIG CON1 | 0x0338  | w    | 0x00000000     | DAC Digital Control 14 Register  |
| <u>4</u>            |         |      |                |                                  |
| ACODEC ADC ANA CONO |         | W    |                | ADC Analog Control 0 Register    |
| ACODEC ADC ANA CON1 | 0x0344  | W    | 0x0000000      | ADC Analog Control 1 Register    |
| ACODEC ADC ANA CON2 | 0x0348  | W    | 0x0000000      | ADC Analog Control 2 Register    |
| ACODEC_ADC_ANA_CON3 |         | W    | 0x0000000c     | ALC Analog Control 3 Register    |
| ACODEC ADC ANA CON4 |         | W    | 0x000000c      | ALC Analog Control 4 Register    |
| ACODEC_ADC_ANA_CON5 | 0x0354  | W    | 0x0000000      | ADC Analog Control 5 Register    |
| ACODEC ADC ANA CON6 | 0x0358  | W    | 0x0000000      | ADC Analog Control 6 Register    |
| ACODEC ADC ANA CON7 | 0x035c  | W    | 0x00000050     | ADC Analog Control 7 Register    |
| ACODEC ADC ANA CON8 | 0x0360  | W    | 0x0000000      | ADC Analog Control 8 Register    |
| ACODEC ADC ANA CON1 | 0x0368  | w    | 0~0000001      | ADC Analog Control 10 Register   |
| <u>0</u>            | 0,0000  | ~~   | 0,0000001      |                                  |
| ACODEC ADC ANA CON1 | 0x036c  | w    | 0×00000000     | ADC Analog Control 11 Register   |
| <u>1</u>            | 0,0000  | **   | 0,00000000     |                                  |
| ACODEC_DAC_ANA_CON0 | 0x0440  | W    | 0x0000000      | DAC Analog Control 0 Register    |
| ACODEC DAC ANA CON1 | 0x0444  | W    |                | DAC Analog Control 1 Register    |
| ACODEC DAC ANA CON2 | 0x0448  | W    | 0x0000000      | DAC Analog Control 2 Register    |
| ACODEC_DAC_ANA_CON3 |         | W    |                | DAC Analog Control 3 Register    |
| ACODEC DAC ANA CON4 | 0x0450  | W    | 0x0000000      | DAC Analog Control 4 Register    |
| ACODEC DAC ANA CON5 | 0x0454  | W    | 0x0000000      | DAC Analog Control 5 Register    |
| ACODEC DAC ANA CON6 | 0x0458  | W    | 0x0000000      | DAC Analog Control 6 Register    |
| ACODEC DAC ANA CON7 | 0x045c  | W    | 0x0000088      | DAC Analog Control 7 Register    |
| ACODEC_DAC_ANA_CON8 | 0x0460  | W    | 0x0000088      | DAC Analog Control8 Register     |
| ACODEC DAC ANA CON1 | 0x0470  | w    | 0×00000022     | DAC Analog Control 12 Register   |
| 2                   | 0,0470  | vv   | 0.00000022     |                                  |
| ACODEC_DAC_ANA_CON1 | 0x0474  | w    | 0×0000000      | DAC Analog Control 13 Register   |
| <u>3</u>            |         |      |                | access W - WORD (32 hits) access |

Notes: <u>Size</u> : **B** - Byte (8 bits) access, **HW** - Half WORD (16 bits) access, **W** -WORD (32 bits) access When configure ACODEC\_ADC\_DIG\_CONx, user should add a offset address to correspond channel: add offset 0x000 for left\_0(ADC1) and right\_0(ADC2) channel, add offset 0x0c0 for left\_1(ADC3) and right\_1(ADC4) channel, add offset 0x180 for left\_2(ADC5) and right\_2(ADC6) channel,

add offset 0x240 for left\_3(ADC7) and right\_3(ADC8) channel.

When configure ACODEC\_ALC\_DIG\_CONx, user should add a offset address to correspond channel: add offset 0x000 for left channel ALC1, add offset 0x040 for right channel ALC2, add offset 0x0c0 for left channel ALC3, add offset 0x100 for right channel ALC4, add offset 0x180 for left channel ALC5, add offset 0x1c0 for right channel ALC6, add offset 0x240 for left channel ALC7, add offset 0x280 for right channel ALC8.

When configure ACODEC\_ADC\_ANA\_CONx, user should add a offset address to correspond channel:

add offset 0x000 for left\_0(ADC1) and right\_0(ADC2) channel,

add offset 0x040 for left\_1(ADC3) and right\_1(ADC4) channel,

add offset 0x080 for left\_2(ADC5) and right\_2(ADC6) channel, add offset 0x0c0 for left\_3(ADC7) and right\_3(ADC8) channel.

## **8.4.2** Detail Register Description

## ACODEC GLB CON

Address: Operational Base + offset (0x0000)

| Bit  | Attr | <b>Reset Value</b> | Description                                                        |
|------|------|--------------------|--------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                           |
|      |      | 00                 | ADC_BIST_RESET                                                     |
| 7    | RW   |                    | ADC bist module reset                                              |
| /    |      | 0x0                | 1'b0: Reset                                                        |
|      |      |                    | 1'b1: Work                                                         |
|      |      |                    | DAC_BIST_RESET                                                     |
| 6    | RW   | 0x0                | DAC bist module reset                                              |
| 0    |      | 0.00               | 1'b0: Reset                                                        |
|      |      |                    | 1'b1: Work                                                         |
|      |      |                    | ADC_MCLK_GATING                                                    |
|      |      |                    | The enable signal of the ADC MCLK gating which cover the ADC       |
|      | 5 RW |                    | data path(ADC1~ADC8).                                              |
| 5    |      | 0x0                | 1'b0: Enable                                                       |
|      |      |                    | 1'b1: Disable                                                      |
|      |      |                    | Note: The ADC data path don't contain the AGC and I2S TX           |
|      |      |                    | module.                                                            |
|      |      |                    | DAC_MCLK_GATING                                                    |
|      |      |                    | The enable signal of the DAC MCLK gating which cover the DAC       |
| 4    | RW   | 0x0                | data path(DAC1~DAC2)                                               |
| -    |      | 0.00               | 1'b0: Enable                                                       |
|      |      |                    | 1'b1: Disable                                                      |
|      |      |                    | Note: The DAC data path don't contain the I2S RX module.           |
| 3    | RO   | 0x0                | reserved                                                           |
|      |      |                    | CODEC_ADC_DIGITAL_RST                                              |
|      |      |                    | Codec ADC digital core reset. This reset only reset the codec data |
| 2    | RW   | 0x1                | path.                                                              |
|      |      |                    | 1'b0: Reset                                                        |
|      |      |                    | 1'b1: Work                                                         |
|      |      |                    | CODEC_DAC_DIGITAL_RST                                              |
|      |      |                    | Codec DAC digital core reset. This reset only reset the codec data |
| 1    | RW   | 0×1                | path.                                                              |
|      |      |                    | 1'b0: Reset                                                        |
|      |      |                    | 1'b1: Work                                                         |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                       |  |  |  |
|-----|------|--------------------|-------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0   | RW   | 0x1                | CODEC_SYSTEM_RST<br>Codec system reset.<br>This signal will reset the registers which control all the digital and |  |  |  |
|     |      |                    | analog part.<br>1'b0: Reset<br>1'b1: Work                                                                         |  |  |  |

Address: Operational Base + offset (0x0004)

| Bit  | 1  | <b>Reset Value</b> | Description                                                      |
|------|----|--------------------|------------------------------------------------------------------|
| 31:8 | RO | 0x0                | reserved                                                         |
|      |    |                    | ADC_I2S_LRC_POL                                                  |
| 7    | RW | 0x0                | ADC I2S LRC Polarity                                             |
| /    | RW | UXU                | 1'b0: Normal                                                     |
|      |    |                    | 1'b1: Reversal                                                   |
|      |    |                    | ADC_I2S_VALID_LEN                                                |
|      |    |                    | Valid Word Length in one 1/2Frame                                |
| 6:5  | RW | 0x2                | 2'b00: 16 bits                                                   |
| 0.5  |    | 0.72               | 2'b01: 20 bits                                                   |
|      |    |                    | 2'b10: 24 bits                                                   |
|      |    |                    | 2'b11: 32 bits                                                   |
|      |    |                    | ADC_I2S_MODE                                                     |
|      |    |                    | ADC I2S MODE                                                     |
|      |    |                    | 2'b00: Right Justified Mode                                      |
|      |    |                    | 2'b01: Left Justified Mode                                       |
|      |    |                    | 2'b10: I2S Mode                                                  |
| 4:3  | RW | 0x2                | 2'b11: PCM Mode                                                  |
|      |    |                    | Note: Same word length in 1/2frame and valid data is not         |
|      |    |                    | supported in                                                     |
|      |    |                    | Right Justified Mode. For example, 32/24 or 24/20 is supported,  |
|      |    |                    | but 32/32 or 24/24 is not supported. (1/2frame length/valid data |
|      |    |                    | length)                                                          |
| 2    | RO | 0x0                | reserved                                                         |
|      |    |                    | ADC_I2S_SWAP                                                     |
| 1    | RW | 0x0                | ADC Left-Right SWAP                                              |
| 1    | 1  | 0.00               | 1'b0: Normal                                                     |
|      |    |                    | 1'b1: Swap                                                       |
|      |    |                    | ADC_I2S_TYPE                                                     |
| 0    | RW | 0x0                | ADC I2S TYPE                                                     |
|      |    | 0,00               | 1'b0: Stereo                                                     |
|      |    |                    | 1'b1: Mono                                                       |

## ACODEC ADC DIG CON2

Address: Operational Base + offset (0x0008)

| Bit  | Attr   | <b>Reset Value</b> | Description                          |
|------|--------|--------------------|--------------------------------------|
| 31:6 | RO     | 0x0                | reserved                             |
|      |        |                    | ADC_MODE_IO                          |
| 5    |        | 0x0                | ADC I2S Mode select for IO pin       |
| 5    | RW     | UXU                | 1'b0: Slave mode                     |
|      |        |                    | 1'b1: Master mode                    |
|      |        |                    | ADC_MODE                             |
| 4    | RW     | 0x0                | ADC I2S Mode select for inner module |
| 4    | 4 KW U | UXU                | 1'b0: Slave mode                     |
|      |        |                    | 1'b1: Master mode                    |
|      |        | RW 0x3             | ADC_I2S_FRAME_LEN                    |
|      |        |                    | ADC I2S 1/2Frame Word Length         |
| 3:2  | DW/    |                    | 2'b00: 16 bits                       |
| J.Z  | L A A  |                    | 2'b01: 20 bits                       |
|      |        |                    | 2'b10: 24 bits                       |
|      |        |                    | 2'b11: 32 bits                       |
|      |        |                    | ADC_I2S_RST                          |
| 1    | RW     | 0x1                | ADC I2S Reset                        |
| T    |        | 0.11               | 1'b0: Reset                          |
|      |        |                    | 1'b1: Work                           |
|      |        |                    | ADC_I2S_BIT_CLK_POL                  |
| 0    | RW     | 0x0                | ADC I2S Bit Clock Polarity           |
| 0    |        |                    | 1'b0: Normal                         |
|      |        |                    | 1'b1: Reversal                       |

Address: Operational Base + offset (0x000c)

| Bit  | Attr | <b>Reset Value</b>     | Description                                                   |
|------|------|------------------------|---------------------------------------------------------------|
| 31:4 | RO   | 0x0                    | reserved                                                      |
|      |      |                        | ADC_LEFT_CHANNEL_BIST                                         |
|      |      |                        | ADC Left Channel Bist Mode select                             |
|      |      |                        | 2'b00: Normal Left Channel data to the PCM(normal mode)       |
| 3:2  | RW   | 0x3                    | 2'b01: Sine Wave to the PCM( bist mode enable and need to set |
| 5.2  | r vv | 023                    | the GLB_CON[7] )                                              |
|      |      |                        | 2'b10: Cube Wave to the PCM( bist mode enable and need to set |
|      |      |                        | the GLB_CON[7] )                                              |
|      |      |                        | 2'b11: Normal Right channel data to the PCM( normal mode )    |
|      |      | ADC_RIGHT_CHANNEL_BIST |                                                               |
|      |      | ₹₩ 0x3                 | ADC Right Channel Bist Mode select                            |
|      |      |                        | 2'b00: Normal Right Channel data to the PCM(normal mode)      |
| 1:0  | DW/  |                        | 2'b01: Sine Wave to the PCM( bist mode enable and need to set |
| 1.0  | r vv |                        | the GLB_CON[7] )                                              |
|      |      |                        | 2'b10: Cube Wave to the PCM( bist mode enable and need to set |
|      |      |                        | the GLB_CON[7] )                                              |
|      |      |                        | 2'b11: Normal Left channel data to the PCM( normal mode )     |

Address: Operational Base + offset (0x0010)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:3 | RO   | 0x0                | reserved                                             |
|      |      |                    | HPF_DIS                                              |
| 2    | RW   | 0x1                | Disable the high pass filter in the ADC path         |
| Z    | K VV |                    | 1'b0: HPF Enable                                     |
|      |      |                    | 1'b1: HPF Disable                                    |
|      |      |                    | HPF_CUT_FREQ                                         |
|      |      | W 0x0              | Select the cut-off frequency of the high pass filter |
| 1:0  |      |                    | 2'b00: 20Hz                                          |
| 1.0  | K VV |                    | 2'b01: 245Hz                                         |
|      |      |                    | 2'b10: 612Hz                                         |
|      |      |                    | 2'b11: reserved                                      |

#### ACODEC ADC DIG CON7

Address: Operational Base + offset (0x001c)

| Bit  | Attr   | <b>Reset Value</b> | Description                                                     |
|------|--------|--------------------|-----------------------------------------------------------------|
| 31:6 | RO     | 0x0                | reserved                                                        |
|      |        |                    | Config_ADCL_DATA                                                |
| 5:4  | RW     | 0x0                | Configure the input of ADCL data path when the register         |
| 5.4  | r vv   | 0.00               | ADC_DIG_CON7[1] is 1.                                           |
|      |        |                    | Note: Please keep the default value                             |
|      |        |                    | Config_ADCR_DATA                                                |
| 2.7  | 3:2 RW | 0x0                | Configure the input of ADCR data path when the register         |
| 5.2  |        | 0.00               | ADC_DIG_CON7[0] is 1.                                           |
|      |        |                    | Note: Please keep the default value                             |
|      |        | W 0×0              | ADCL_DATA_SEL                                                   |
|      |        |                    | Select the input of the ADCL data path                          |
| 1    | D\//   |                    | 1'b0: Select the normal path as the input of ADC data path      |
| 1    |        |                    | 1'b1: Select the register ADC_DIG_CON7[5:4] as the input of the |
|      |        |                    | ADC data path                                                   |
|      |        |                    | Note: Please keep the default value                             |
|      |        |                    | ADCR_DATA_SEL                                                   |
|      |        |                    | Select the input of the ADCR data path                          |
| 0    | RW     | 0x0                | 1'b0: Select the normal path as the input of ADC data path      |
| 0    | ĸvv    | 0.00               | 1'b1: Select the register ADC_DIG_CON7[3:2] as the input of the |
|      |        |                    | ADC data path                                                   |
|      |        |                    | Note: Please keep the default value                             |

#### ACODEC ALC DIG CONO

Address: Operational Base + offset (0x0040)

| Bit  | Attr | <b>Reset Value</b> | Description                                                |
|------|------|--------------------|------------------------------------------------------------|
| 31:7 | RO   | 0x0                | reserved                                                   |
|      |      |                    | GAIN_ATT_METHOD                                            |
| c    | RW   | 0x0                | Choose the method to control the gain attack               |
| 6    | RVV  | UXU                | 1'b0: Normal way                                           |
|      |      |                    | 1'b1: Jack way                                             |
|      |      |                    | CTRL_GEN_METHOD                                            |
|      |      |                    | There are four methods to generate the control signals     |
|      |      |                    | 2'b00: Normal way                                          |
| 5:4  | RW   | 0x0                | 2'b01: Jack way 1                                          |
| 5.4  |      | 0.00               | 2'b10: Jack way 2                                          |
|      |      |                    | 2'b11: Jack way 3                                          |
|      |      |                    | This register is used to choose the method to generate the |
|      |      |                    | control signals according to the actual situation          |
|      |      |                    | AGC_HOLD_TIME                                              |
|      |      |                    | AGC hold time before gain is increased in normal mode      |
|      |      |                    | 4'b0000: 0ms                                               |
|      |      |                    | 4'b0001: 2ms                                               |
|      |      |                    | 4'b0010: 4ms                                               |
|      |      |                    | 4'b0011: 8ms                                               |
| 3:0  | RW   | 0x0                | 4'b0100: 16ms                                              |
|      |      |                    | 4'b0101: 32ms                                              |
|      |      |                    | 4'b0110: 64ms                                              |
|      |      |                    | 4'b0111: 128ms                                             |
|      |      |                    | 4'b1000: 256ms                                             |
|      |      |                    | 4'b1001: 512ms                                             |
|      |      |                    | 4'b1010: 1s                                                |
|      |      |                    | 4'b1011~1111: 0ms                                          |

Address: Operational Base + offset (0x0044)

| Bit  | Attr | <b>Reset Value</b> |          | Description |  |
|------|------|--------------------|----------|-------------|--|
| 31:8 | RO   | 0x0                | reserved |             |  |

| Bit | Attr | Reset Value | Description                   |
|-----|------|-------------|-------------------------------|
|     |      |             | DECAY_TIME                    |
|     |      |             | Decay (gain ramp-up) time     |
|     |      |             | Normal MODE(reg_agc_mode =0)  |
|     |      |             | 4'b0000: 500us                |
|     |      |             | 4'b0001: 1ms                  |
|     |      |             | 4'b0010: 2ms                  |
|     |      |             | 4'b0011: 4ms                  |
|     |      |             | 4'b0100: 8ms                  |
|     |      |             | 4'b0101: 16ms                 |
|     |      |             | 4'b0110: 32ms                 |
|     | RW   | 0x4         | 4'b0111: 64ms                 |
|     |      |             | 4'b1000: 128ms                |
|     |      |             | 4'b1001: 256ms                |
| 7:4 |      |             | 4'b1010: 512ms                |
| ,   |      |             | 4'b1011~1111: 512ms           |
|     |      |             | Limiter MODE(reg_agc_mode =1) |
|     |      |             | 4'b0000: 125us                |
|     |      |             | 4'b0001: 250us                |
|     |      |             | 4'b0010: 500us                |
|     |      |             | 4'b0011: 1ms                  |
|     |      |             | 4'b0100: 2ms                  |
|     |      |             | 4'b0101: 4ms                  |
|     |      |             | 4'b0110: 8ms                  |
|     |      |             | 4'b0111: 16ms                 |
|     |      |             | 4'b1000: 32ms                 |
|     |      |             | 4'b1001: 64ms                 |
|     |      |             | 4'b1010: 128ms                |
|     |      |             | 4'b1011~1111: 128ms           |

| Bit | Attr | Reset Value | Description                   |
|-----|------|-------------|-------------------------------|
|     |      |             | ATTACK_TIME                   |
|     |      |             | Attack (gain ramp-down) Time  |
|     |      |             | Normal MODE(reg_agc_mode =0)  |
|     |      |             | 4'b0000: 125us                |
|     |      |             | 4'b0001: 250us                |
|     |      |             | 4'b0010: 500us                |
|     |      |             | 4'b0011: 1ms                  |
|     |      |             | 4'b0100: 2ms                  |
|     |      |             | 4'b0101: 4ms                  |
|     |      |             | 4'b0110: 8ms                  |
|     | RW   |             | 4'b0111: 16ms                 |
|     |      | 0x6         | 4'b1000: 32ms                 |
|     |      |             | 4'b1001: 64ms                 |
| 3:0 |      |             | 4'b1010: 128ms                |
| 0.0 |      |             | 4'b1011~1111: 125us           |
|     |      |             | Limiter MODE(reg_agc_mode =1) |
|     |      |             | 4'b0000: 32us                 |
|     |      |             | 4'b0001: 64us                 |
|     |      |             | 4'b0010: 125us                |
|     |      |             | 4'b0011: 250us                |
|     |      |             | 4'b0100: 500us                |
|     |      |             | 4'b0101: 1ms                  |
|     |      |             | 4'b0110: 2ms                  |
|     |      |             | 4'b0111: 4ms                  |
|     |      |             | 4'b1000: 8ms                  |
|     |      |             | 4'b1001: 16ms                 |
|     |      |             | 4'b1010: 32ms                 |
|     |      |             | 4'b1011~1111: 32us            |

ACODEC ALC DIG CON2 Address: Operational Base + offset (0x0048)

| Bit  | Attr | Reset Value | Description                                                      |
|------|------|-------------|------------------------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                                         |
|      |      |             | AGC_MODE                                                         |
| 7    |      | 00          | Determines the AGC mode of operation                             |
| 7    | RW   | 0x0         | 1'b0: AGC mode(normal mode)                                      |
|      |      |             | 1'b1: Limiter mode                                               |
|      |      |             | AGC_ZERO_CRO_EN                                                  |
| c    |      | 0.41        | AGC users zero cross enable                                      |
| 6    | RW   | 0x1         | 1'b0: Disabled                                                   |
|      |      |             | 1'b1: Enabled, the AGC gain will update at zero cross enable     |
|      |      |             | LOW_AMPLITUDE_RECOVERY                                           |
|      |      |             | When in the limiter mode, the low amplitude signal will recovery |
| 5    | RW   | 0.40        | in two modes:                                                    |
| 5    | RW   | 0x0         | 1'b0: The gain will recovery to the value of the reg_pga_lvol    |
|      |      |             | 1'b1: The gain will recovery to the gain at the moment when the  |
|      |      |             | mode changes from AGC to Limiter                                 |
|      |      | 0×0         | FAST_DEC_CTRL                                                    |
|      |      |             | When the amplitude of the signal is more than 87.5% of the Full  |
| 4    | RW   |             | scale, use this signal to control the fast decrement:            |
|      |      |             | 1'b0: Disabled                                                   |
|      |      |             | 1'b1: Enabled                                                    |
|      |      |             | AGC_NOISE_GATE_EN                                                |
| 3    | RW   | 0x0         | AGC noise gate function enable                                   |
| 5    |      | UXU         | 1'b0: Disabled                                                   |
|      |      |             | 1'b1: Enabled                                                    |
|      |      |             | AGC_NOISE_GATE_THRESHOLD                                         |
|      |      |             | AGC noise gate threshold                                         |
|      |      |             | 3'b000: -39dB                                                    |
|      |      |             | 3'b001: -45dB                                                    |
| 2:0  | RW   | 0x1         | 3'b010: -51dB                                                    |
| 2.0  | 1    | UXI         | 3'b011: -57dB                                                    |
|      |      |             | 3'b100: -63dB                                                    |
|      |      |             | 3'b101: -69dB                                                    |
|      |      |             | 3'b110: -75dB                                                    |
|      |      |             | 3'b111: -81dB                                                    |

ACODEC ALC DIG CON3 Address: Operational Base + offset (0x004c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
| 31:6 | RO   | 0x0                | reserved                                                      |
|      | RW   | W 0x1              | LEFT_CHANNEL_PGA_ZERO_CRO_EN                                  |
| F    |      |                    | Left channel input PGA zero cross enable                      |
| 5    |      |                    | 1'b0: Update gain when gain register changes.                 |
|      |      |                    | 1'b1: Update gain on 1st zero cross after gain register write |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Attr | Reset Value | LEFT_CHANNEL_PGA_GAIN<br>Left channel input PGA gain<br>5'b0_0000: -18dB<br>5'b0_0001: -16.5dB<br>5'b0_0010: -15dB                                                                                                                                                                                                                                                                                                                        |
| 4:0 | RW   | 0x0c        | 5'b0_0011: -13.5dB<br>5'b0_0100: -12dB<br>5'b0_0110: -9dB<br>5'b0_0111: -7.5dB<br>5'b0_1000: -6dB<br>5'b0_1001: -4.5dB<br>5'b0_1010: -3dB<br>5'b0_1011: -1.5dB<br>5'b0_1101: +1.5dB<br>5'b0_1101: +1.5dB<br>5'b0_1110: +3dB<br>5'b0_1111: +4.5dB<br>5'b1_0001: +7.5dB<br>5'b1_0010: +9dB<br>5'b1_0010: +9dB<br>5'b1_0101: +10.5dB<br>5'b1_0101: +13.5dB<br>5'b1_0110: +15dB<br>5'b1_0110: +15dB<br>5'b1_0111: +16.5dB<br>5'b1_0100: +18dB |
|     |      |             | 5'b1_1000: +18dB<br>5'b1_1001: +19.5dB<br>5'b1_1010: +21dB<br>5'b1_1011: +22.5dB<br>5'b1_1100: +24dB<br>5'b1_1101: +25.5dB<br>5'b1_1110: +27dB<br>5'b1_1111: +28.5dB                                                                                                                                                                                                                                                                      |

Address: Operational Base + offset (0x0050)

| Bit  | Attr | <b>Reset Value</b> | Description                                         |
|------|------|--------------------|-----------------------------------------------------|
| 31:4 | RO   | 0x0                | reserved                                            |
| 3    |      | /  0x0             | SLOW_CLOCK_EN                                       |
|      | RW   |                    | Slow clock enabled, used for the zero cross timeout |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                   |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | Atti | Reset value        | APPROXIMATE_RATE<br>Approximate sample rate<br>3'b000: 96kHz<br>3'b001: 48kHz<br>3'b010: 44.1kHz                                                              |
| 2:0 | RW   | 0×0                | 3'b010: 44.1kH2<br>3'b011: 32kHz<br>3'b100: 24kHz<br>3'b101: 16kHz<br>3'b110: 12kHz<br>3'b111: 8kHz<br>Note: According to the sample rate to choose the right |

Address: Operational Base + offset (0x0054)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                      |
| 7:0  | RW   | 0x26               | LOW_8_BITS_AGC_MAX<br>The low 8 bits of the AGC maximum level |

#### ACODEC ALC DIG CON6

Address: Operational Base + offset (0x0058)

| Bit  | Attr | <b>Reset Value</b> | Description                              |
|------|------|--------------------|------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                 |
| 7:0  | RW   | SW 10x40           | HIGH_8_BITS_AGC_MAX                      |
| 7.0  |      |                    | The high 8 bits of the AGC maximum level |

#### ACODEC ALC DIG CON7

Address: Operational Base + offset (0x005c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                      |
| 7:0  | RW   | 0x36               | LOW_8_BITS_AGC_MIN<br>The low 8 bits of the AGC minimum level |

### ACODEC ALC DIG CON8

Address: Operational Base + offset (0x0060)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |
|------|------|--------------------|-----------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                        |
| 7:0  | RW   | 0x20               | HIGH_8_BITS_AGC_MIN<br>The high 8 bits of the AGC minimum level |

### ACODEC ALC DIG CON9

Address: Operational Base + offset (0x0064)

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:7 | RO   | 0x0                | reserved                  |
|      |      |                    | AGC_FUNCTION_SELECT       |
| 6    | RW   | 0x0                | AGC function select       |
| 0    | R VV | 0.00               | 1'b0: AGC function off    |
|      |      |                    | 1'b1: AGC function enable |
|      |      |                    | MAX_GAIN_PGA              |
|      |      |                    | Set maximum gain of PGA   |
|      |      |                    | 3'b000: -13.5dB           |
|      |      |                    | 3'b001: -7.5dB            |
| 5:3  | RW   | 0x7                | 3'b010: -1.5dB            |
| 5.5  | 1    |                    | 3'b011: +4.5dB            |
|      |      |                    | 3'b100: +10.5dB           |
|      |      |                    | 3'b101: +16.5dB           |
|      |      |                    | 3'b110: +22.5dB           |
|      |      |                    | 3'b111: +28.5dB           |
|      |      |                    | MIN_GAIN_PGA              |
|      |      |                    | Set minimum gain of PGA   |
|      |      |                    | 3'b000: -18dB             |
|      |      |                    | 3'b001: -12dB             |
| 2:0  | RW   | 0x0                | 3'b010: -6dB              |
| 2.0  |      |                    | 3'b011: 0dB               |
|      |      |                    | 3'b100: +6dB              |
|      |      |                    | 3'b101: +12dB             |
|      |      |                    | 3'b110: +18dB             |
|      |      |                    | 3'b111: +24dB             |

Address: Operational Base + offset (0x0070)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
| 31:5 | RO   | 0x0                | reserved                                                       |
|      |      |                    | AGC_GAIN_VALUE                                                 |
| 4:0  | RO   | 0x0c               | It shows the current value of the agc gain value. When the agc |
|      |      |                    | function is disable, this value is 0x0c                        |

### ACODEC DAC DIG CON1

Address: Operational Base + offset (0x0304)

| Bit  | Attr | <b>Reset Value</b> | Description          |
|------|------|--------------------|----------------------|
| 31:8 | RO   | 0x0                | reserved             |
|      |      | V 0×0              | DAC_I2S_LRC_POL      |
| 7    | RW   |                    | DAC I2S LRC Polarity |
| /    | κw   |                    | 1'b0: Normal         |
|      |      |                    | 1'b1: Reversal       |

| Bit      | Attr | Reset Value | Description                                                     |
|----------|------|-------------|-----------------------------------------------------------------|
|          |      |             | DAC_I2S_VALID_LEN                                               |
|          |      |             | Valid Word Length in one 1/2Frame                               |
| 6:5      | RW   | 0x2         | 2'b00: 16 bits                                                  |
| 0.5      |      | 0.72        | 2'b01: 20 bits                                                  |
|          |      |             | 2'b10: 24 bits                                                  |
|          |      |             | 2'b11: 32 bits                                                  |
|          |      |             | DAC_I2S_MODE                                                    |
|          |      |             | DAC I2S MODE                                                    |
|          |      |             | 2'b00: Right Justified Mode                                     |
|          |      |             | 2'b01: Left Justified Mode                                      |
|          |      |             | 2'b10: I2S Mode                                                 |
| 4:3      | RW   |             | 2'b11: PCM Mode                                                 |
|          |      |             | Note: Same word length in 1/2frame and valid data is not        |
|          |      |             | supported in                                                    |
|          |      |             | Right Justified Mode. For example, 32/24 or 24/20 is supported, |
|          |      |             | but 32/32                                                       |
|          |      |             | or 24/24 is not supported. (1/2frame length/valid data length)  |
|          |      |             | DAC_I2S_SWAP                                                    |
| 2        | RW   | V 0×0       | DAC Left-Right SWAP                                             |
| <u> </u> |      |             | 1'b0: Normal                                                    |
|          |      |             | 1'b1: Swap                                                      |
| 1:0      | RO   | 0x0         | reserved                                                        |

Address: Operational Base + offset (0x0308)

| Bit  | Attr | <b>Reset Value</b> | Description                          |
|------|------|--------------------|--------------------------------------|
| 31:6 | RO   | 0x0                | reserved                             |
|      |      |                    | DAC_MODE_IO                          |
| 5    | RW   | 0x0                | DAC I2S Mode select for IO pin       |
| 5    | RVV  | 0.00               | 1'b0: Slave mode                     |
|      |      |                    | 1'b1: Master mode                    |
|      |      |                    | DAC_MODE                             |
| 4    | RW   | 0.20               | DAC I2S Mode select for inner module |
| 4    | RVV  | 0x0                | 1'b0: Slave mode                     |
|      |      |                    | 1'b1: Master mode                    |
|      |      | W 0x3              | DAC_I2S_FRAME_LEN                    |
|      |      |                    | DAC I2S 1/2Frame Word Length         |
| 3:2  |      |                    | 2'b00: 16 bits                       |
| 5.2  | RVV  |                    | 2'b01: 20 bits                       |
|      |      |                    | 2'b10: 24 bits                       |
|      |      |                    | 2'b11: 32 bits                       |
|      |      |                    | DAC_I2S_RST                          |
| 1    | RW   | 0x1                | DAC I2S Reset                        |
| 1    | r vv |                    | 1'b0: Reset                          |
|      |      |                    | 1'b1: Work                           |

| Bit | Attr | <b>Reset Value</b> | Description                |
|-----|------|--------------------|----------------------------|
|     |      | 0×0                | DAC_I2S_BIT_CLK_POL        |
| 0   | RW   |                    | DAC I2S Bit Clock Polarity |
| U   |      |                    | 1'b0: Normal               |
|     |      |                    | 1'b1: Reversal             |

Address: Operational Base + offset (0x030c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
| 31:4 | RO   | 0x0                | reserved                                                      |
|      |      |                    | DAC_LEFT_CHANNEL_BIST                                         |
|      |      |                    | DAC Left Channel Bist Mode select                             |
|      |      |                    | 2'b00: Normal Right Channel data to the PCM(normal mode)      |
| 3:2  | RW   | 0x0                | 2'b01: Sine Wave to the PCM( bist mode enable and need to set |
| 5.2  |      | 0.00               | the GLB_CON[6] )                                              |
|      |      |                    | 2'b10: Cube Wave to the PCM( bist mode enable and need to set |
|      |      |                    | the GLB_CON[6] )                                              |
|      |      |                    | 2'b11: Normal Left channel data to the PCM( normal mode )     |
|      |      | 0×0                | DAC_RIGHT_CHANNEL_BIST                                        |
|      |      |                    | DAC Right Channel Bist Mode select                            |
|      |      |                    | 2'b00: Normal Right Channel data to the PCM(normal mode)      |
| 1:0  | RW   |                    | 2'b01: Sine Wave to the PCM( bist mode enable and need to set |
| 1.0  | r vv |                    | the GLB_CON[6] )                                              |
|      |      |                    | 2'b10: Cube Wave to the PCM( bist mode enable and need to set |
|      |      |                    | the GLB_CON[6] )                                              |
|      |      |                    | 2'b11: Normal Left channel data to the PCM( normal mode )     |

## ACODEC\_DAC\_DIG\_CON4

Address: Operational Base + offset (0x0310)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
| 31:7 | RO   | 0x0                | reserved                                                      |
|      |      |                    | MODULATOR_GAIN                                                |
|      |      |                    | Set the gain of the modulator                                 |
|      |      |                    | 3'b000:0db                                                    |
| 6:4  | RW   | V 0x2              | 3'b001:2db                                                    |
| 0.4  | ĸvv  |                    | 3'b010:2.8db                                                  |
|      |      |                    | 3'b011:3.5db                                                  |
|      |      |                    | 3'b100:4.2db                                                  |
|      |      |                    | 3'b101:4.8db                                                  |
| 3    | RO   | 0x0                | reserved                                                      |
| 2:0  | RW   | 0.2                | CIC_IP_FILTER_GAIN                                            |
| 2.0  | ĸw   | RW 0x2             | Set the gain of output signal of the cic interpolation filter |

#### ACODEC DAC DIG CON5

Address: Operational Base + offset (0x0314)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                      |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                         |
| 2    | RW   | 0x0                | DACL_DATA_SEL<br>Choose the input of the DAC left channel.<br>1'b0: Normal Data<br>1'b1: Using the register to control the input data of the DAC left<br>channel<br>Note: When we choose the register to control the input data of<br>the DAC left channel, we can use the register<br>DAC DIG_CON10~DAC_DIG_CON11 to set the input data value   |
| 1    | RW   | 0×0                | DACR_DATA_SEL<br>Choose the input of the DAC right channel.<br>1'b0: Normal Data<br>1'b1: Using the register to control the input data of the DAC right<br>channel<br>Note: When we choose the register to control the input data of<br>the DAC left channel, we can use the register<br>DAC_DIG_CON10~DAC_DIG_CON11 to set the input data value |
| 0    | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                         |

Address: Operational Base + offset (0x0328)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |
|------|------|--------------------|-----------------------------------------------------------------|
| 31:4 | RO   | 0x0                | reserved                                                        |
|      |      |                    | DAC_DATA_HIGH                                                   |
|      |      |                    | Configure the bit [11:8] of DAC data when choose the register   |
| 3:0  | RW   | 0xf                | value as the input of the DAC channel.                          |
|      |      |                    | Please reference the description of register DAC_DIG_CON5[2:1]. |
|      |      |                    | Note: Please keep the default value                             |

### ACODEC DAC DIG CON11

Address: Operational Base + offset (0x032c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |
|------|------|--------------------|-----------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                        |
|      |      |                    | DAC_DATA_LOW                                                    |
|      |      |                    | Configure the bit [7:0] of DAC data when choose the register    |
| 7:0  | RW   | 0xff               | value as the input of the DAC channel.                          |
|      |      |                    | Please reference the description of register DAC_DIG_CON5[2:1]. |
|      |      |                    | Note: Please keep the default value                             |

#### ACODEC DAC DIG CON12

Address: Operational Base + offset (0x0330)

| Bit  | Attr | <b>Reset Value</b> | Description                     |
|------|------|--------------------|---------------------------------|
| 31:2 | RO   | 0x0                | reserved                        |
| 1:0  | RW   | W 0x3              | DELAY_TIME_DETECT_HIGH          |
| 1:0  |      |                    | Please refer the DAC_DIG_CON13. |

Address: Operational Base + offset (0x0334)

| Bit  | Attr | <b>Reset Value</b> | Description                                            |
|------|------|--------------------|--------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                               |
|      | RW   | W 0xc2             | DELAY_TIME_DETECT_LOW                                  |
| 7:0  |      |                    | The value(DELAY_TIME_DETECT_HIGH[1:0]<<8 +             |
| 7.0  |      |                    | DELAY_TIME_DETECT_LOW[7:0]) indicate the delay time of |
|      |      |                    | detecting the headphone inserting or unplugged.        |

#### ACODEC DAC DIG CON14

Address: Operational Base + offset (0x0338)

| Bit  | Attr | <b>Reset Value</b> | Description                                             |  |  |
|------|------|--------------------|---------------------------------------------------------|--|--|
| 31:1 | RO   | 0x0                | eserved                                                 |  |  |
|      |      | 0x0                | HEADPHONE_INSERT                                        |  |  |
| 0    |      |                    | The flag indicates whether the headphone have inserted. |  |  |
| 0    | RO   |                    | 1'b0: Don't have                                        |  |  |
|      |      |                    | 1'b1: Having headset to be inserted                     |  |  |

#### ACODEC ADC ANA CONO

Address: Operational Base + offset (0x0340)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |  |  |
|------|------|--------------------|-----------------------------------------------------------------|--|--|
| 31:8 | RO   | 0x0                | reserved                                                        |  |  |
|      |      |                    | ADC_CH2_MIC_MUTE                                                |  |  |
| 7    | RW   | 0x0                | The mute signal of MIC module in the ADC channel 2.             |  |  |
| /    | r vv | 0.00               | 1'b0: Mute                                                      |  |  |
|      |      |                    | 1'b1: Work                                                      |  |  |
|      |      |                    | ADC_CH2_MIC_INIT                                                |  |  |
| 6    | RW   | 0x0                | The initial signal of MIC module in the ADC channel 2.          |  |  |
| 0    |      |                    | 1'b0: Initialization                                            |  |  |
|      |      |                    | 1'b1: Work                                                      |  |  |
|      |      | W 0×0              | ADC_CH2_MIC_EN                                                  |  |  |
| 5    | RW   |                    | The enable signal of MIC module in the ADC channel 2.           |  |  |
| 5    | r vv |                    | 1'b0: Disable                                                   |  |  |
|      |      |                    | 1'b1: Enable                                                    |  |  |
|      |      |                    | ADC_CH2_BUF_REF_EN                                              |  |  |
| 4    | RW   | 0.20               | The enable signal of reference voltage buffer of ADC channel 2. |  |  |
| 4    | L AN | / 0x0              | 1'b0: Disable                                                   |  |  |
|      |      |                    | 1'b1: Enable                                                    |  |  |

| Bit | Attr | <b>Reset Value</b> | Description                                                     |
|-----|------|--------------------|-----------------------------------------------------------------|
|     |      |                    | ADC_CH1_MIC_MUTE                                                |
| 3   | RW   | 0x0                | The mute signal of MIC module in the ADC channel 1.             |
| 5   | RVV  | 0.00               | 1'b0: Mute                                                      |
|     |      |                    | 1'b1: Work                                                      |
|     |      |                    | ADC_CH1_MIC_INIT                                                |
| 2   |      | 0.40               | The initial signal of MIC module in the ADC channel 1.          |
| 2   | RW   | 0×0                | 1'b0: Initialization                                            |
|     |      |                    | 1'b1: Work                                                      |
|     |      | N 0x0              | ADC_CH1_MIC_EN                                                  |
| 1   | RW   |                    | The enable signal of MIC module in the ADC channel 1.           |
| L . | RVV  |                    | 1'b0: Disable                                                   |
|     |      |                    | 1'b1: Enable                                                    |
|     |      |                    | ADC_CH1_BUF_REF_EN                                              |
| 0   |      | V 0×0              | The enable signal of reference voltage buffer of ADC channel 1. |
| 0   | RW   |                    | 1'b0: Disable                                                   |
|     |      |                    | 1'b1: Enable                                                    |

#### ACODEC\_ADC\_ANA\_CON1

Address: Operational Base + offset (0x0344)

| Bit  | Attr | <b>Reset Value</b> | Description                                              |  |  |
|------|------|--------------------|----------------------------------------------------------|--|--|
| 31:6 | RO   | 0x0                | reserved                                                 |  |  |
|      |      |                    | ADC_CH2_MIC_GAIN                                         |  |  |
|      |      |                    | The gain signal of MIC module in the ADC channel 2.      |  |  |
|      |      |                    | 2'b00: 0dB                                               |  |  |
| 5:4  | RW   | 0x0                | 2'b11: 20dB                                              |  |  |
| 5.4  |      | 0.00               | Others: reserve                                          |  |  |
|      |      |                    | Note: When ADC is used as loopback, it is recommended to |  |  |
|      |      |                    | configure 2'b00. When ADC is used as MIC input, it is    |  |  |
|      |      |                    | recommended to configure 2'b11.                          |  |  |
| 3:2  | RO   | 0x0                | reserved                                                 |  |  |
|      |      |                    | ADC_CH1_MIC_GAIN                                         |  |  |
|      |      |                    | The gain signal of MIC module in the ADC channel 1.      |  |  |
|      |      |                    | 2'b00: 0dB                                               |  |  |
| 1:0  | RW   | 0x0                | 2'b11: 20dB                                              |  |  |
| 1.0  |      |                    | Others: reserve                                          |  |  |
|      |      |                    | Note: When ADC is used as loopback, it is recommended to |  |  |
|      |      |                    | configure 2'b00. When ADC is used as MIC input, it is    |  |  |
|      |      |                    | recommended to configure 2'b11.                          |  |  |

### ACODEC\_ADC\_ANA\_CON2

Address: Operational Base + offset (0x0348)

| Bit  | Attr | Reset Value | Description                                                                                                                                     |  |  |  |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:7 | RO   | 0x0         | reserved                                                                                                                                        |  |  |  |
| 6    | RW   | 0×0         | ADC_CH2_ZEROCROSS_DET_EN<br>The enable signal of input zero-crossing detection module in the<br>ADC channel 2.<br>1'b0: Disable                 |  |  |  |
|      |      |             | 1'b1: Enable                                                                                                                                    |  |  |  |
| 5    | RW   | 0×0         | ADC_CH2_ALC_INIT<br>The initial signal of ALC module in the ADC channel 2.<br>1'b0: Initialization<br>1'b1: Work                                |  |  |  |
| 4    | RW   | 0×0         | ADC_CH2_ALC_EN<br>The enable signal of ALC module in the ADC channel 2.<br>1'b0: Disable<br>1'b1: Enable                                        |  |  |  |
| 3    | RO   | 0x0         | reserved                                                                                                                                        |  |  |  |
| 2    | RW   | 0x0         | ADC_CH1_ZEROCROSS_DET_EN<br>The enable signal of input zero-crossing detection module in the<br>ADC channel 1.<br>1'b0: Disable<br>1'b1: Enable |  |  |  |
| 1    | RW   | 0×0         | ADC_CH1_ALC_INIT<br>The initial signal of ALC module in the ADC channel 1.<br>1'b0: Initialization<br>1'b1: Work                                |  |  |  |
| 0    | RW   | 0x0         | ADC_CH1_ALC_EN<br>The enable signal of ALC module in the ADC channel 1.<br>1'b0: Disable<br>1'b1: Enable                                        |  |  |  |

| ACUD  | <u>ACODEC ADC ANA CONS</u>                  |                    |             |  |  |  |  |  |
|-------|---------------------------------------------|--------------------|-------------|--|--|--|--|--|
| Addre | Address: Operational Base + offset (0x034c) |                    |             |  |  |  |  |  |
| Bit   | Attr                                        | <b>Reset Value</b> | Description |  |  |  |  |  |
| 31:5  | RO                                          | 0x0                | reserved    |  |  |  |  |  |

| Bit               | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|-------------------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| <b>Bit</b><br>4:0 |      | Reset Value | Description           ADC_CH1_ALC_GAIN           The gain signal of ALC module in the ADC channel 1.           5'b0_0000: -18dB           5'b0_0001: -16.5dB           5'b0_0010: -15dB           5'b0_0011: -13.5dB           5'b0_0100: -12dB           5'b0_0101: -10.5dB           5'b0_0101: -10.5dB           5'b0_0101: -10.5dB           5'b0_0101: -10.5dB           5'b0_0101: -10.5dB           5'b0_1000: 6dB           5'b0_1001: -4.5dB           5'b0_1001: -4.5dB           5'b0_1011: -1.5dB           5'b0_1011: -1.5dB           5'b0_1101: -1.5dB           5'b0_1101: -1.5dB           5'b0_1101: -1.5dB           5'b0_1101: +1.5dB           5'b0_1101: +1.5dB           5'b1_0001: +7.5dB           5'b1_0001: +7.5dB           5'b1_0001: +7.5dB           5'b1_0001: +12dB           5'b1_0011: +13.5dB           5'b1_0011: +15dB           5'b1_0011: +16.5dB           5'b1_1001: +13dB           5'b1_1001: +12dB           5'b1_1001: +21dB           5'b1_1001: +21dB           5'b1_1001: +24dB           5'b1_1001: +24dB           5'b1_1101: +25.5dB           5' |  |  |  |  |

Address: Operational Base + offset (0x0350)

| Bit  | Attr | <b>Reset Value</b> |          | Description |  |
|------|------|--------------------|----------|-------------|--|
| 31:5 | RO   | 0x0                | reserved |             |  |

| Bit        | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|------------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| <b>Bit</b> |      | Reset Value | Description           ADC_CH2_ALC_GAIN           The gain signal of ALC module in the ADC channel 2.           5'b0_0000: -18dB           5'b0_0001: -16.5dB           5'b0_0010: -15dB           5'b0_0101: -13.5dB           5'b0_0101: -13.5dB           5'b0_0101: -10.5dB           5'b0_0111: -7.5dB           5'b0_0111: -7.5dB           5'b0_0101: -10.5dB           5'b0_0101: -20B           5'b0_0101: -3dB           5'b0_1001: -4.5dB           5'b0_1010: -3dB           5'b0_1011: -1.5dB           5'b0_1101: -3dB           5'b0_1101: -1.5dB           5'b0_1101: -1.5dB           5'b0_1101: -1.5dB           5'b0_1101: +1.5dB           5'b0_1111: +4.5dB           5'b1_1011: +1.5dB           5'b1_0001: +7.5dB           5'b1_0001: +7.5dB           5'b1_0010: +12dB           5'b1_0101: +13.5dB           5'b1_0101: +13.5dB           5'b1_0101: +13.5dB           5'b1_0101: +13.5dB           5'b1_0101: +13.5dB           5'b1_1001: +12.5dB           5'b1_1001: +21.4B           5'b1_1001: +22.5dB           5'b1_101: +22.5dB           5'b1_1101: +22.5dB |  |  |  |  |

Address: Operational Base + offset (0x0354)

| Bit  | Attr | <b>Reset Value</b> | Description                                            |  |  |  |
|------|------|--------------------|--------------------------------------------------------|--|--|--|
| 31:7 | RO   | 0x0                | eserved                                                |  |  |  |
|      |      | W 0×0              | ADC_CH2_ADC_INIT                                       |  |  |  |
| C    |      |                    | The initial signal of ADC module in the ADC channel 2. |  |  |  |
| 6    | RW   |                    | 1'b0: Initialization                                   |  |  |  |
|      |      |                    | 1'b1: Work                                             |  |  |  |

| Bit | Attr | <b>Reset Value</b> | Description                                             |  |  |  |
|-----|------|--------------------|---------------------------------------------------------|--|--|--|
|     |      |                    | ADC_CH2_ADC_EN                                          |  |  |  |
| 5   | RW   | 0x0                | The enable signal of ADC module in the ADC channel 2.   |  |  |  |
| 5   | K VV | 0.00               | 1'b0: Disable                                           |  |  |  |
|     |      |                    | 1'b1: Enable                                            |  |  |  |
|     |      |                    | ADC_CH2_CLK_EN                                          |  |  |  |
| 4   | RW   | 0x0                | The enable signal of clock module in the ADC channel 2. |  |  |  |
| 4   | r vv | 0.00               | 1'b0: Disable                                           |  |  |  |
|     |      |                    | 1'b1: Enable                                            |  |  |  |
| 3   | RO   | 0x0                | reserved                                                |  |  |  |
|     |      | V 0x0              | ADC_CH1_ADC_INIT                                        |  |  |  |
| 2   | RW   |                    | The initial signal of ADC module in the ADC channel 1.  |  |  |  |
| Z   | RW   |                    | 1'b0: Initialization                                    |  |  |  |
|     |      |                    | 1'b1: Work                                              |  |  |  |
|     |      |                    | ADC_CH1_ADC_EN                                          |  |  |  |
| 1   | RW   | 0×0                | The enable signal of ADC module in the ADC channel 1.   |  |  |  |
| L.  | K VV | W UXU              | 1'b0: Disable                                           |  |  |  |
|     |      |                    | 1'b1: Enable                                            |  |  |  |
|     |      |                    | ADC_CH1_CLK_EN                                          |  |  |  |
| 0   | RW   | 0x0                | The enable signal of clock module in the ADC channel 1. |  |  |  |
| 0   |      | 0.00               | 1'b0: Disable                                           |  |  |  |
|     |      |                    | 1'b1: Enable                                            |  |  |  |

## ACODEC\_ADC\_ANA\_CON6

Address: Operational Base + offset (0x0358)

| Bit  | Attr | <b>Reset Value</b> | Description                                               |  |  |
|------|------|--------------------|-----------------------------------------------------------|--|--|
| 31:1 | RO   | 0x0                | reserved                                                  |  |  |
|      |      |                    | ADC_CURRENT_EN                                            |  |  |
|      |      |                    | The enable signal of current source for ADC channel 1 and |  |  |
| 0    | RW   | 0x0                | channel 2.                                                |  |  |
|      |      |                    | 1'b0: Disable                                             |  |  |
|      |      |                    | 1'b1: Enable                                              |  |  |

## ACODEC ADC ANA CON7

Address: Operational Base + offset (0x035c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                       |
|      |      |                    | ADC_CH2_IN_SEL                                                 |
|      |      |                    | ADC_CH2_IN_SEL[1] is reserved, it should be 1'b0.              |
|      |      |                    | ADC_CH2_IN_SEL[0], the signal to select microphone as input of |
| 7:6  | RW   | 0x1                | the ADC channel 2                                              |
|      |      |                    | 1'b0: Don't select                                             |
|      |      |                    | 1'b1: Select                                                   |
|      |      |                    | Note: The register configuration is only valid for ADC2        |

| Bit | Attr | <b>Reset Value</b> | Description                                                    |
|-----|------|--------------------|----------------------------------------------------------------|
|     |      |                    | ADC_CH1_IN_SEL                                                 |
|     |      |                    | ADC_CH1_IN_SEL[1] is reserved, it should be 1'b0.              |
|     |      |                    | ADC_CH1_IN_SEL[0], the signal to select microphone as input of |
| 5:4 | RW   | 0x1                | the ADC channel 1                                              |
|     |      |                    | 1'b0: Don't select                                             |
|     |      |                    | 1'b1: Select                                                   |
|     |      |                    | Note: The register configuration is only valid for ADC1        |
|     |      |                    | ADC_MICROPHONE_BIAS_BUF_EN                                     |
|     |      |                    | The enable signal of microphone bias voltage buffer.           |
|     | RW   | 0×0                | 1'b0: Disable                                                  |
| 3   |      |                    | 1'b1: Enable                                                   |
|     |      |                    | Note: Only the reg (ADC_ANA_CON7+0x40)[3] and reg              |
|     |      |                    | (ADC_ANA_CON7+0x80)[3] represent the enable signal of          |
|     |      |                    | MICBIAS1 and MICBIAS2 respectively                             |
|     |      |                    | ADC_LEVEL_RANGE_MICBIAS                                        |
|     |      |                    | The level range control signal of MICBIAS voltage:             |
|     |      |                    | 3'b000: 0.5*AVDD33                                             |
|     |      |                    | 3'b001: 0.55*AVDD33                                            |
|     |      |                    | 3'b010: 0.6*AVDD33                                             |
| 2:0 | RW   | 0x0                | 3'b011: 0.65*AVDD33                                            |
| 2.0 | r vv | UXU                | 3'b100: 0.7*AVDD33                                             |
|     |      |                    | 3'b101: 0.75*AVDD33                                            |
|     |      |                    | 3'b110: 0.8*AVDD33                                             |
|     |      |                    | 3'b111: 0.85*AVDD33                                            |
|     |      |                    | Note: Only the reg (ADC_ANA_CON7+0x0)[2:0] represent the       |
|     |      |                    | level range control signal of MICBIAS voltage                  |

Address: Operational Base + offset (0x0360)

| Bit  | Attr | <b>Reset Value</b> | Description                                            |
|------|------|--------------------|--------------------------------------------------------|
| 31:5 | RO   | 0x0                | reserved                                               |
|      |      |                    | ADC_MICBIAS_CURRENT_EN                                 |
|      | RW   | 0×0                | The enable signal of current source for MICBIAS.       |
| 1    |      |                    | 1'b0: Disable                                          |
| 4    |      |                    | 1'b1: Enable                                           |
|      |      |                    | Note: Only the reg (ADC_ANA_CON8+0x0)[4] represent the |
|      |      |                    | enable signal of current source for MICBIAS            |
| 3:0  | RO   | 0x0                | reserved                                               |

## ACODEC ADC ANA CON10

Address: Operational Base + offset (0x0368)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                       |
|      |      |                    | ADC_RFF_EN                                                     |
|      |      |                    | The enable signal of reference voltage module.                 |
| 7    | RW   | 0x0                | 1'b0: Disable                                                  |
| /    | RVV  | UXU                | 1'b1: Enable                                                   |
|      |      |                    | Note: Only the reg (ADC_ANA_CON10+0x0)[7] represent the        |
|      |      |                    | enable signal of reference voltage module                      |
|      |      |                    | ADC_CURRENT_CHARGE_SEL                                         |
|      |      |                    | The control signal to select current to pre-charge/dis-charge. |
|      |      |                    | CURRENT_CHARGE_SEL[6]:                                         |
|      |      |                    | 1'b0: Choose the current I0                                    |
|      |      |                    | 1'b1: Don't choose the current I0                              |
|      |      | 0×01               | CURRENT_CHARGE_SEL[5]:                                         |
|      |      |                    | 1'b0: Choose the current 2*I0                                  |
|      |      |                    | 1'b1: Don't choose the current 2*I0                            |
|      |      |                    | CURRENT_CHARGE_SEL[4]:                                         |
|      |      |                    | 1'b0: Choose the current 4*I0                                  |
|      |      |                    | 1'b1: Don't choose the current 4*I0                            |
|      |      |                    | CURRENT_CHARGE_SEL[3]:                                         |
| 6:0  | RW   |                    | 1'b0: Choose the current 8*I0                                  |
|      |      |                    | 1'b1: Don't choose the current 8*I0                            |
|      |      |                    | CURRENT_CHARGE_SEL[2]:                                         |
|      |      |                    | 1'b0: Choose the current 16*I0                                 |
|      |      |                    | 1'b1: Don't choose the current 16*I0                           |
|      |      |                    | CURRENT_CHARGE_SEL[1]:                                         |
|      |      |                    | 1'b0: Choose the current 32*I0                                 |
|      |      |                    | 1'b1: Don't choose the current 32*I0                           |
|      |      |                    | CURRENT_CHARGE_SEL[0]:                                         |
|      |      |                    | 1'b0: Choose the current 64*I0                                 |
|      |      |                    | 1'b1: Don't choose the current 64*I0                           |
|      |      |                    | Note: Only the reg (ADC_ANA_CON10+0x0)[6:0] represent the      |
|      |      |                    | control signal to select current to pre-charge/dis_charge      |

### ACODEC\_ADC\_ANA\_CON11

Address: Operational Base + offset (0x036c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                       |
|------|------|--------------------|-------------------------------------------------------------------|
| 31:2 | RO   | 0x0                | reserved                                                          |
|      |      |                    | ADC_ALCR_CON_GAIN_PGAR                                            |
|      |      |                    | Enable the function that uses the ALCR module to control the gain |
| 1    | RW   | 0x0                | of the PGAR                                                       |
|      |      |                    | 1'b0: Disable                                                     |
|      |      |                    | 1'b1: Enable                                                      |

| Bit | Attr | <b>Reset Value</b> | Description                                                       |
|-----|------|--------------------|-------------------------------------------------------------------|
|     |      |                    | ADC_ALCL_CON_GAIN_PGAL                                            |
|     |      |                    | Enable the function that uses the ALCL module to control the gain |
| 0   | RW   | 0x0                | of the PGAL                                                       |
|     |      |                    | 1'b0: Disable                                                     |
|     |      |                    | 1'b1: Enable                                                      |

## ACODEC\_DAC\_ANA\_CON0

Address: Operational Base + offset (0x0440)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:2 | RO   | 0x0                | reserved                                             |
|      |      |                    | DAC_HEADPHONE_DET_EN                                 |
| 1    |      | 0×0                | The enable signal of headphone detection module      |
| L L  | RW   |                    | 1'b0: Disable                                        |
|      |      |                    | 1'b1: Enable                                         |
|      |      |                    | DAC_CURRENT_EN                                       |
| 0    |      |                    | The enable signal of current source for DAC channel. |
| 0    | ĸvv  |                    | 1'b0: Disable                                        |
|      |      |                    | 1'b1: Enable                                         |

## ACODEC DAC ANA CON1

Address: Operational Base + offset (0x0444)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
| 31:7 | RO   | 0x0                | reserved                                                       |
|      |      |                    | DAC_BUF_REF_R_EN                                               |
|      |      |                    | The enable signal of reference voltage buffer in the right DAC |
| 6    | RW   | 0x0                | channel                                                        |
|      |      |                    | 1'b0: Disable                                                  |
|      |      |                    | 1'b1: Enable                                                   |
|      |      |                    | DAC_POP_SOUND_R                                                |
|      |      |                    | The control signal of POP sound in the right DAC channel       |
| 5:4  | RW   | 0x1                | 2'b01: Initialization                                          |
|      |      |                    | 2'b10: Work                                                    |
|      |      |                    | others: reserved                                               |
| 3    | RO   | 0x0                | reserved                                                       |
|      |      |                    | DAC_BUF_REF_L_EN                                               |
|      |      |                    | The enable signal of reference voltage buffer in the left DAC  |
| 2    | RW   | 0x0                | channel                                                        |
|      |      |                    | 1'b0: Disable                                                  |
|      |      |                    | 1'b1: Enable                                                   |
|      |      |                    | DAC_POP_SOUND_L                                                |
|      |      |                    | The control signal of POP sound in the left DAC channel        |
| 1:0  | RW   | 0x1                | 2'b01: Initialization                                          |
|      |      |                    | 2'b10: Work                                                    |
|      |      |                    | others: reserved                                               |

ACODEC DAC ANA CON2 Address: Operational Base + offset (0x0448)

| Bit  | Attr | <b>Reset Value</b> | Description                                                       |
|------|------|--------------------|-------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                          |
|      |      |                    | DAC_R_DAC_INIT                                                    |
| 7    | DW   | 0.40               | The initial signal of DAC module in the right DAC channel         |
| 7    | RW   | 0x0                | 1'b0: Initialization                                              |
|      |      |                    | 1'b1: Work                                                        |
|      |      |                    | DAC_R_DAC_EN                                                      |
| 6    | RW   | 0x0                | The enable signal of DAC module in the right DAC channel          |
| 6    | RVV  | UXU                | 1'b0: Disable                                                     |
|      |      |                    | 1'b1: Enable                                                      |
|      |      |                    | DAC_R_CLK_EN                                                      |
| 5    | RW   | 0x0                | The enable signal of clock module in the right DAC channel.       |
| 5    | RVV  | UXU                | 1'b0: Disable                                                     |
|      |      |                    | 1'b1: Enable                                                      |
|      |      |                    | DAC_R_REF_EN                                                      |
|      |      | 0×0                | The enable signal of reference voltage of DAC module in the right |
| 4    | RW   |                    | DAC channel                                                       |
|      |      |                    | 1'b0: Disable                                                     |
|      |      |                    | 1'b1: Enable                                                      |
|      |      | / 0x0              | DAC_L_DAC_INIT                                                    |
| 3    | RW   |                    | The initial signal of DAC module in the left DAC channel          |
| 5    |      |                    | 1'b0: Initialization                                              |
|      |      |                    | 1'b1: Work                                                        |
|      |      |                    | DAC_L_DAC_EN                                                      |
| 2    | RW   | 0x0                | The enable signal of DAC module in the left DAC channel           |
| -    |      |                    | 1'b0: Disable                                                     |
|      |      |                    | 1'b1: Enable                                                      |
|      |      |                    | DAC_L_CLK_EN                                                      |
| 1    | RW   | 0x0                | The enable signal of clock module in the left DAC channel.        |
| -    |      |                    | 1'b0: Disable                                                     |
|      |      |                    | 1'b1: Enable                                                      |
|      |      |                    | DAC_L_REF_EN                                                      |
|      |      | 0×0                | The enable signal of reference voltage of DAC module in the left  |
| 0    | RW   |                    | DAC channel                                                       |
|      |      |                    | 1'b0: Disable                                                     |
|      |      |                    | 1'b1: Enable                                                      |

## ACODEC DAC ANA CON3

Address: Operational Base + offset (0x044c)

| Bit  | Attr | Reset Value | Description                                                 |
|------|------|-------------|-------------------------------------------------------------|
| 31:7 | RO   | 0x0         | reserved                                                    |
|      |      |             | DAC_R_HPOUT_INIT                                            |
| 6    | RW   | 0x0         | The initial signal of HPOUT module in the right DAC channel |
| 0    | RVV  | UXU         | 1'b0: Initialization                                        |
|      |      |             | 1'b1: Work                                                  |
|      |      |             | DAC_R_HPOUT_EN                                              |
| 5    | RW   | 0x0         | The enable signal of HPOUT module in the right DAC channel  |
| 5    | RVV  | UXU         | 1'b0: Disable                                               |
|      |      |             | 1'b1: Enable                                                |
|      |      | 0×0         | DAC_R_HPOUT_MUTE                                            |
| 1    | RW   |             | The mute signal of HPOUT module in the right DAC channel    |
| 4    | RW   |             | 1'b0: Mute                                                  |
|      |      |             | 1'b1: Work                                                  |
| 3    | RO   | 0x0         | reserved                                                    |
|      |      |             | DAC_L_HPOUT_INIT                                            |
| 2    |      | RW 0x0      | The initial signal of HPOUT module in the left DAC channel  |
| Z    | K VV |             | 1'b0: Initialization                                        |
|      |      |             | 1'b1: Work                                                  |
|      |      |             | DAC_L_HPOUT_EN                                              |
| 1    |      | W 0×0       | The enable signal of HPOUT module in the left DAC channel   |
| 1    | K VV |             | 1'b0: Disable                                               |
|      |      |             | 1'b1: Enable                                                |
|      |      |             | DAC_L_HPOUT_MUTE                                            |
| 0    |      | 0×0         | The mute signal of HPOUT module in the left DAC channel     |
| 0    | K VV |             | 1'b0: Mute                                                  |
|      |      |             | 1'b1: Work                                                  |

Address: Operational Base + offset (0x0450)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                      |
|      |      |                    | DAC_R_GAIN                                                    |
|      |      |                    | The gain signal of line out module in the right DAC channel.  |
| 7.6  |      | 0.40               | 2'b00: -6dB                                                   |
| 7:6  | RW   | 0x0                | 2'b01: -3dB                                                   |
|      |      |                    | 2'b10: -1.5dB                                                 |
|      |      |                    | 2'b11: 0dB                                                    |
|      |      | W 0×0              | DAC_R_LINEOUT_MUTE                                            |
| -    |      |                    | The mute signal of line out module in the right DAC channel   |
| 5    | RW   |                    | 1'b0: Mute                                                    |
|      |      |                    | 1'b1: Work                                                    |
|      |      |                    | DAC_R_LINEOUT_EN                                              |
| 4    |      |                    | The enable signal of line out module in the right DAC channel |
| 4    | RW   |                    | 1'b0: Disable                                                 |
|      |      |                    | 1'b1: Enable                                                  |

| Bit | Attr | <b>Reset Value</b> | Description                                                  |
|-----|------|--------------------|--------------------------------------------------------------|
|     |      |                    | DAC_L_GAIN                                                   |
|     |      |                    | The gain signal of line out module in the left DAC channel.  |
| 3:2 |      | 0.40               | 2'b00: -6dB                                                  |
| 5.2 | RW   | 0x0                | 2'b01: -3dB                                                  |
|     |      |                    | 2'b10: -1.5dB                                                |
|     |      |                    | 2'b11: 0dB                                                   |
|     |      | W 0×0              | DAC_L_LINEOUT_MUTE                                           |
| 1   |      |                    | The mute signal of line out module in the left DAC channel   |
| 1   | RVV  |                    | 1'b0: Mute                                                   |
|     |      |                    | 1'b1: Work                                                   |
|     |      |                    | DAC_L_LINEOUT_EN                                             |
| 0   |      |                    | The enable signal of line out module in the left DAC channel |
| 0   | RW   |                    | 1'b0: Disable                                                |
|     |      |                    | 1'b1: Enable                                                 |

Address: Operational Base + offset (0x0454)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                          |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x0                | reserved                                                                                                                                                                             |
| 4:0  | RW   | 0×00               | DAC_L_HPOUT_GAIN<br>The gain signal of HPOUT module in the left DAC channel.<br>5'b00000: -39dB<br><br>5'b11010: 0dB<br><br>5'b11101: 4.5dB<br>5'b11110~5'b11111: 6dB<br>Step: 1.5dB |

## ACODEC DAC ANA CON6

Address: Operational Base + offset (0x0458)

| Bit  | Attr | <b>Reset Value</b> | Description                                               |
|------|------|--------------------|-----------------------------------------------------------|
| 31:5 | RO   | 0x0                | reserved                                                  |
|      |      |                    | DAC_R_HPOUT_GAIN                                          |
|      |      |                    | The gain signal of HPOUT module in the right DAC channel. |
|      |      |                    | 5'b00000: -39dB                                           |
|      |      |                    |                                                           |
| 4:0  | RW   | 0x00               | 5'b11010: 0dB                                             |
|      |      |                    |                                                           |
|      |      |                    | 5'b11101: 4.5dB                                           |
|      |      |                    | 5'b11110~5'b11111: 6dB                                    |
|      |      |                    | Step: 1.5dB                                               |

#### ACODEC DAC ANA CON7

| Bit  | Attr | <b>Reset Value</b> | Description                                             |
|------|------|--------------------|---------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                |
| 7:4  |      |                    | HPOUTR_DS                                               |
|      | RW   | 0x8                | HPOUT driver strength for right channel                 |
|      |      |                    | The smaller the value, the greater the driver strength  |
| 3:0  | RW   |                    | HPOUTL_DS                                               |
|      |      |                    | HPOUT driver strength for left channel                  |
|      |      |                    | The smaller the value , the greater the driver strength |

Address: Operational Base + offset (0x045c)

#### ACODEC DAC ANA CON8

Address: Operational Base + offset (0x0460)

| Bit  | Attr | Reset Value | Description                                             |
|------|------|-------------|---------------------------------------------------------|
| 31:8 | RO   | 0x0         | reserved                                                |
|      |      |             | HPOUTR_DS                                               |
| 7:4  | RW   | 0x8         | LINEOUT driver strength for right channel               |
|      |      |             | The smaller the value , the greater the driver strength |
| 3:0  | RW   | 0x8         | LINEOUTL_DS                                             |
|      |      |             | LINEOUT driver strength for left channel                |
|      |      |             | The smaller the value , the greater the driver strength |

#### ACODEC DAC ANA CON12

Address: Operational Base + offset (0x0470)

| Bit  | Attr                                              | <b>Reset Value</b>                                         | Description                                                 |
|------|---------------------------------------------------|------------------------------------------------------------|-------------------------------------------------------------|
| 31:8 | RO                                                | 0x0                                                        | reserved                                                    |
|      |                                                   |                                                            | The select signal of HPMIX module in the right DAC channel. |
|      | RW                                                | 0x0                                                        | DAC_R_HPMIX_SEL [1] is reserved, it should be 1'b0.         |
| 7:6  |                                                   |                                                            | DAC_R_HPMIX_SEL[0],Select input from I2S                    |
|      |                                                   |                                                            | 1'b0: Don't select                                          |
|      |                                                   |                                                            | 1'b1: Select                                                |
|      | RW                                                | 0×2                                                        | DAC_R_HPMIX_GAIN                                            |
|      |                                                   |                                                            | The gain signal of HPMIX module in the right DAC channel.   |
| 5:4  |                                                   |                                                            | 2'b01: -6dB                                                 |
|      |                                                   |                                                            | 2'b10: 0dB                                                  |
|      |                                                   |                                                            | others: reserved                                            |
|      | DAC L HPMIX SEL [1] is reserved, it should be 1'b |                                                            | DAC_L_HPMIX_SEL                                             |
|      |                                                   | The select signal of HPMIX module in the left DAC channel. |                                                             |
| 3:2  |                                                   | DAC_L_HPMIX_SEL [1] is reserved, it should be 1'b0.        |                                                             |
| 5.2  |                                                   |                                                            | DAC_L_HPMIX_SEL[0],Select input from I2S                    |
|      |                                                   |                                                            | 1'b0: Don't select                                          |
|      |                                                   |                                                            | 1'b1: Select                                                |

| Bit | Attr | <b>Reset Value</b> | Description                                              |
|-----|------|--------------------|----------------------------------------------------------|
|     |      |                    | DAC_L_HPMIX_GAIN                                         |
|     |      |                    | The gain signal of HPMIX module in the left DAC channel. |
| 1:0 | RW   | 0x2                | 2'b01: -6dB                                              |
|     |      |                    | 2'b10: 0dB                                               |
|     |      |                    | others: reserved                                         |

#### ACODEC\_DAC\_ANA\_CON13

Address: Operational Base + offset (0x0474)

| Bit  | Attr                                                                            | <b>Reset Value</b>                                         | Description                                                 |
|------|---------------------------------------------------------------------------------|------------------------------------------------------------|-------------------------------------------------------------|
| 31:7 | RO                                                                              | 0x0                                                        | reserved                                                    |
|      |                                                                                 | 0x0                                                        | DAC_R_HPMIX_MUTE                                            |
| 6    | RW                                                                              |                                                            | The mute signal of HPMIX module in the right DAC channel    |
| 0    |                                                                                 |                                                            | 1'b0: Mute                                                  |
|      |                                                                                 |                                                            | 1'b1: Work                                                  |
|      |                                                                                 |                                                            | DAC_R_HPMIX_INIT                                            |
| 5    | RW                                                                              | 0x0                                                        | The initial signal of HPMIX module in the right DAC channel |
| 5    | r vv                                                                            | UXU                                                        | 1'b0: Initialization                                        |
|      |                                                                                 |                                                            | 1'b1: Work                                                  |
|      |                                                                                 | 0x0                                                        | DAC_R_HPMIX_EN                                              |
| 4    |                                                                                 |                                                            | The enable signal of HPMIX module in the right DAC channel  |
| 4    | RW                                                                              |                                                            | 1'b0: Disable                                               |
|      |                                                                                 |                                                            | 1'b1: Enable                                                |
| 3    | RO                                                                              | 0x0                                                        | reserved                                                    |
|      | RW                                                                              | 0×0                                                        | DAC_L_HPMIX_MUTE                                            |
| 2    |                                                                                 |                                                            | The mute signal of HPMIX module in the left DAC channel     |
| 2    |                                                                                 |                                                            | 1'b0: Mute                                                  |
|      |                                                                                 |                                                            | 1'b1: Work                                                  |
|      |                                                                                 |                                                            | DAC_L_HPMIX_INIT                                            |
| 1    | RW0x0The initial signal of HPMIX module in the left DAC<br>1'b0: Initialization | The initial signal of HPMIX module in the left DAC channel |                                                             |
| L    |                                                                                 | 0.00                                                       | 1'b0: Initialization                                        |
|      |                                                                                 |                                                            | 1'b1: Work                                                  |
|      |                                                                                 | .W 0x0                                                     | DAC_L_HPMIX_EN                                              |
| 0    |                                                                                 |                                                            | The enable signal of HPMIX module in the left DAC channel   |
| 0    | KVV                                                                             |                                                            | 1'b0: Disable                                               |
|      |                                                                                 |                                                            | 1'b1: Enable                                                |

# **8.5 Interface Description**

N/A

# 8.6 Application Note

8.6.1 Enable DAC I2S Interface Flow

- 0. Supply the power of the digital part and reset the Audio Codec.
- 1. Provide stable clock bus clock(CRU\_CLKGAT\_CON14[12]).
- 2. Provide stable clock pin\_dac\_mclk(Clock source from mclk\_tx of I2S\_8CH\_2).
- 3. Reset ACODEC (CRU\_SOFTRST\_CON9[9]).
- 4. Reset ACODEC by soft reset register as follow:

Set ACODEC\_GLB\_CON=0x0

Set ACODEC\_GLB\_CON=0x1

5. Configure the ACODEC\_DAC\_DIG\_CON1~3 related to the DAC I2S function.

6. Enable the DAC as follow:

Set ACODEC\_GLB\_CON=0x3

7. Begin to input the I2S data stream to the I2S interface of the ACODEC DAC.

8.6.2 Enable DC I2S Interface Flow

1. Provide stable clock bus clock(CRU\_CLKGAT\_CON14[12]).

2. Provide stable clock pin\_dac\_mclk(Clock source from mclk\_rx of I2S\_8CH\_2).

3. Reset ACODEC (CRU\_SOFTRST\_CON9[9]).

4. Reset ACODEC by soft reset register as follow:

Set ACODEC\_GLB\_CON=0x0

Set ACODEC\_GLB\_CON=0x1

5. Configure the ACODEC\_ADC\_DIG\_CON1~3 for the all ADC channel, a offset address should be added as follow:

add offset 0x000 for left\_0(ADC1) and right\_0(ADC2) channel;

add offset 0x0c0 for left\_1(ADC3) and right\_1(ADC4) channel;

add offset 0x180 for left\_2(ADC5) and right\_2(ADC6) channel;

add offset 0x240 for left\_3(ADC7) and right\_3(ADC8) channel.

It's recommended to configure ACODEC\_ADC\_DIG\_CON3 to 0x0.

6. Enable the ADC as follow:

Set ACODEC\_GLB\_CON=0x5

7. Begin to use the I2S interface of ADC to output the parallel data.

### 8.6.3 Power Up

1. Supply the power of digital part and reset the Audio Codec.

2. Configure ACODEC\_DAC\_ANA\_CON1[1:0] and ACODEC\_DAC\_ANA\_CON1[5:4] to 0x1, to setup dc voltage of the DAC channel output.

3. Configure the register ACODEC\_ADC\_ANA\_CON10[6:0] to 0x1.

4. Supply the power of the analog part(AVDD,AVDDRV).

5. Configure the register ACODEC\_ADC\_ANA\_CON10[7] to 0x1 to setup reference voltage.

6. Change the register ACODEC\_ADC\_ANA\_CON10[6:0] from the 0x1 to 0x7f step by step or configure the ACODEC\_ADC\_ANA\_CON10[6:0] to 0x7f directly. The suggestion slot time of the step is 20ms.

7. Wait until the voltage of VCM keeps stable at the AVDD/2.

8. Configure the register ACODEC\_ADC\_ANA\_CON10[6:0] to the appropriate value(expect 0x0) for reducing power.

#### 8.6.4 Power Off

0. Keep the power on and disable the DAC and ADC.

1. Configure the register ACODEC\_ADC\_ANA\_CON10[6:0] to 0x1.

2. Configure the register ACODEC\_ADC\_ANA\_CON10[7] to 0x0.

3.Change the register ACODEC\_ADC\_ANA\_CON10[6:0] from the 0x1 to 0x7f step by step or configure the ACODEC\_ADC\_ANA\_CON10[6:0] to 0x7f directly. The suggestion slot time of the step is 20ms.

4. Wait until the voltage of VCM keeps stable at the AGND.

5. Power off the analog power supply.

6. Power off the digital power supply.

#### 8.6.5 Enable MICBIAS

0. Power up the ACODEC and keep the AVDDH stable.

1. Configure ACODEC\_ADC\_ANA\_CON7[2:0] to the certain value.

2. Wait until the VCMH keep stable.

3. Configure ACODEC\_ADC\_ANA\_CON8[4] to 0x1.

4. Configure the (ADC\_ANA\_CON7+0x40)[3] or (ADC\_ANA\_CON7+0x80)[3] to 0x1.

(ADC\_ANA\_CON7+0x40)[3] used to control the MICBIAS1, and

(ADC\_ANA\_CON7+0x80)[3] used to control the MICBIAS2.

#### 8.6.6 Disable MICBIAS

0. Enable the MICBIAS and keep the Audio Codec stable.

1. Configure the (ADC\_ANA\_CON7+0x40)[3] or (ADC\_ANA\_CON7+0x80)[3] to 0x0.

2. Configure ACODEC\_ADC\_ANA\_CON8[4] to 0x0.

8.6.7 Enable DAC

0. Power up the Audio Codec and input the mute signal.

1. Set the ACODEC\_DAC\_ANA\_CON0[0] to 0x1, to enable the current source of DAC.

2. Set the ACODEC\_DAC\_ANA\_CON1[6] and ACODEC\_DAC\_ANA\_CON1[2] to 0x1, to enable the reference voltage buffer.

3. Set the ACODEC\_DAC\_ANA\_CON1[5:4] and ACODEC\_DAC\_ANA\_CON1[1:0] to 0x2, to select the dc voltage of the HPDRV module from internal.

4. Set the ACODEC\_DAC\_ANA\_CON13[4] and ACODEC\_DAC\_ANA\_CON13[0] to 0x1, to enable the HPMIX of DAC.

5.Set the ACODEC\_DAC\_ANA\_CON13[5] and ACODEC\_DAC\_ANA\_CON13[1] to 0x1, to end the initialization of HPMIX.

6. Set the ACODEC\_ DAC\_ANA\_CON4[4] and ACODEC\_ DAC\_ANA\_CON4[0] to 0x1, to enable the line out module in DAC.

7. Set the ACODEC\_ DAC\_ANA\_CON3[5] and ACODEC\_ DAC\_ANA\_CON3[1] to 0x1, to enable the HPDRV module in DAC.

8. Set the ACODEC\_ DAC\_ANA\_CON3[6] and ACODEC\_ DAC\_ANA\_CON3[2] to 0x1, to end the initialization of HPDRV.

9. Set ACODEC\_DAC\_ANA\_CON2[4] and ACODEC\_DAC\_ANA\_CON2[0] to 0x1, to enable the high and low reference voltage of DAC.

10. Set ACODEC\_DAC\_ANA\_CON2[5] and ACODEC\_DAC\_ANA\_CON2[1] to 0x1, to enable the clock module of DAC.

11. Set ACODEC\_DAC\_ANA\_CON2[6] and ACODEC\_DAC\_ANA\_CON2[2] to 0x1, to enable the DAC.

12. Set ACODEC\_DAC\_ANA\_CON2[7] and ACODEC\_DAC\_ANA\_CON2[3] to 0x1,to end the initialization of DAC.

13. Set ACODEC\_DAC\_ANA\_CON12[7:6] and ACODEC\_DAC\_ANA\_CON12[3:2] to select the input signal of HPMIX module.

14. Set ACODEC\_DAC\_ANA\_CON13[6] and ACODEC\_DAC\_ANA\_CON13[2] to 0x1 to end the mute station of the HPMIX module in the DAC.

15. Set ACODEC\_DAC\_ANA\_CON12[5:4] and ACODEC\_DAC\_ANA\_CON12[1:0] to select the gain of HPMIX module.

16. Set ACODEC\_DAC\_ANA\_CON3[4] and ACODEC\_DAC\_ANA\_CON3[0] to 0x1 to end the mute station of the DRV module in the DAC.

17. Set ACODEC\_DAC\_ANA\_CON4[5] and ACODEC\_DAC\_ANA\_CON4[1] to 0x1 to end the mute station of the line out module in the DAC.

18. Set ACODEC\_ DAC\_ANA\_CON5[4:0] and ACODEC\_ DAC\_ANA\_CON6[4:0] to select the gain of HPDDRV module in the DAC.

19. Set ACODEC\_ DAC\_ANA\_CON4[7:6] and ACODEC\_ DAC\_ANA\_CON4[3:2] to select the gain of line out module in the DAC.

20. Play the music.

Note1. If the ACODEC\_ DAC\_ANA\_CON12[6] or ACODEC\_ DAC\_ANA\_CON12[2] is set to 0x0, ignoring the step9~12.

Note2. If the ACODEC\_ DAC\_ANA\_CON12[7] or ACODEC\_ DAC\_ANA\_CON12[3] is set to 0x1, the ADC0 or ADC1 should be enabled firstly, and please refer to Enable ADC Configuration Standard Usage Flow(expect step7~step9,step14).

Note3. If no opening the line out, ignoring the step6, step17 and step19.

Note4. If no opening the headphone out, ignoring the step3,step7~8,step16 and step18. Note5. In the step18, adjust the register step by step to the appropriate value and taking 10ms as one time step.

### 8.6.8 Disable DAC

0. Keep the DAC channel work and input the mute signal.

1. Set ACODEC\_ DAC\_ANA\_CON4[7:6] and ACODEC\_ DAC\_ANA\_CON4[3:2] to select the gain of line out module in the DAC.

2. Set ACODEC\_ DAC\_ANA\_CON5[4:0] and ACODEC\_ DAC\_ANA\_CON6[4:0] to 0x0, to select the gain of HPDDRV module in the DAC.

3. Set ACODEC\_DAC\_ANA\_CON13[6] and ACODEC\_DAC\_ANA\_CON13[2] to 0x0, to mute the HPMIX module in the DAC.

4.Set ACODEC\_DAC\_ANA\_CON12[7:6] and ACODEC\_DAC\_ANA\_CON12[3:2] to 0x0, to select the input signal of HPMIX module.

5. Set ACODEC\_DAC\_ANA\_CON3[4] and ACODEC\_DAC\_ANA\_CON3[0] to 0x0 to mute the DRV module in the DAC.

6. Set ACODEC\_DAC\_ANA\_CON2[7] and ACODEC\_DAC\_ANA\_CON2[3] to 0x0, to initialize the DAC.

7. Set the ACODEC\_ DAC\_ANA\_CON3[5] and ACODEC\_ DAC\_ANA\_CON3[1] to 0x0, to disable the HPDRV module in DAC.

8. Set ACODEC\_DAC\_ANA\_CON4[5] and ACODEC\_DAC\_ANA\_CON4[1] to 0x0 to mute the line out module.

9. Set the ACODEC\_ DAC\_ANA\_CON4[4] and ACODEC\_ DAC\_ANA\_CON4[0] to 0x0, to disable the line out module in DAC.

10. Set the ACODEC\_DAC\_ANA\_CON13[4] and ACODEC\_DAC\_ANA\_CON13[0] to 0x0, to disable the HPMIX of DAC.

11. Set ACODEC\_DAC\_ANA\_CON2[6] and ACODEC\_DAC\_ANA\_CON2[2] to 0x0, to disable the DAC.

12. Set ACODEC\_DAC\_ANA\_CON2[5] and ACODEC\_DAC\_ANA\_CON2[1] to 0x0, to disable the clock module of DAC.

13. Set ACODEC\_DAC\_ANA\_CON2[4] and ACODEC\_DAC\_ANA\_CON2[0] to 0x0, to disable the high and low reference voltage of DAC.

14. Set the ACODEC\_DAC\_ANA\_CON1[5:4] and ACODEC\_DAC\_ANA\_CON1[1:0] to 0x1, to select the dc voltage of the HPDRV module from VCM PAD.

15. Set the ACODEC\_DAC\_ANA\_CON1[6] and ACODEC\_DAC\_ANA\_CON1[2] to 0x0, to disable the reference voltage buffer.

16. Set the ACODEC\_DAC\_ANA\_CON0[0] to 0x0, to disable the current source of DAC. 17. Set the ACODEC\_ DAC\_ANA\_CON3[6] and ACODEC\_ DAC\_ANA\_CON3[2] to 0x0, to begin the initialization of HPDRV.

18. Set the ACODEC\_DAC\_ANA\_CON13[5] and ACODEC\_DAC\_ANA\_CON13[1] to 0x0, to begin the initialization of HPMIX.

19. Set ACODEC\_DAC\_ANA\_CON12[5:4] and ACODEC\_DAC\_ANA\_CON12[1:0] to select the gain of HPMIX module.

Note1. In the step2, adjusting the register step by step to the appropriate value and taking 20ms as time step.

Note2. If the ACODEC\_DAC\_ANA\_CON12[7] or ACODEC\_DAC\_ANA\_CON12[3] is set to 0x1, add the steps from the section Disable ADC Configuration Standard Usage Flow after complete the step 19.

## 8.6.9 Enable ADC

0. Power up the Audio Codec.

1. Configure the register ACODEC\_ADC\_ANA\_CON7[7:6], to set microphone as input of the ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON7[5:4], to set microphone as input of the ADC left channel1.

2. Configure the register ACODEC\_ADC\_ANA\_CON0[7] to 1, to end the mute station of the ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON0[3] to 1, to end the mute station of the ADC left channel.

3. Configure the register ACODEC\_ADC\_ANA\_CON6[0] to 1, to enable the current source of audio.

4. Configure the register ACODEC\_ADC\_ANA\_CON0[4] to 1, to enable the reference voltage buffer in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON0[0] to 1, to enable the reference voltage buffer in ADC left channel.

5. Configure the register ACODEC\_ADC\_ANA\_CON0[5] to 1, to enable the MIC module in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON0[1] to 1, to enable the MIC module in ADC

left channel.

6. Configure the register ACODEC\_ADC\_ANA\_CON2[4] to 1, to enable the ALC module in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON2[0] to 1, to enable the ALC module in ADC right channel.

7. Configure the register ACODEC\_ADC\_ANA\_CON5[4] to 1, to enable the clock module in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON5[0] to 1, to enable the clock module in ADC left channel.

8. Configure the register ACODEC\_ADC\_ANA\_CON5[5] to 1, to enable the ADC module in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON5[1] to 1, to enable the ADC module in ADC left channel.

9. Configure the register ACODEC\_ADC\_ANA\_CON5[6] to 1, to end the initialization of the ADC module.

Configure the register ACODEC\_ADC\_ANA\_CON5[2] to 1, to end the initialization of the ADC module.

10. Configure the register ACODEC\_ADC\_ANA\_CON2[5] to 1, to end the initialization of the ALC right module.

Configure the register ACODEC\_ADC\_ANA\_CON2[1] to 1, to end the initialization of the ALC left module.

11. Configure the register ACODEC\_ADC\_ANA\_CON0[6] to 1, to end the initialization of the MIC right module.

Configure the register ACODEC\_ADC\_ANA\_CON0[2] to 1, to end the initialization of the MIC right module.

12. Configure the register ACODEC\_ADC\_ANA\_CON1[5:4], to select the gain of the MIC right module.

Configure the register ACODEC\_ADC\_ANA\_CON1[1:0], to select the gain of the MIC left module.

13. Configure the register ACODEC\_ADC\_ANA\_CON3[4:0], to select the gain of the ALC left module.

Configure the register ACODEC\_ADC\_ANA\_CON4[4:0], to select the gain of the ALC right module.

14. Configure the register ACODEC\_ADC\_ANA\_CON2[6] to 1, to enable the zero-crossing detection function in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON2[2] to 1, to enable the zero-crossing detection function in ADC left channel

Note1. Please ignore the step1 for enabling ADC3, ADC4, ADC5, ADC6, ADC7, and ADC8 Note2. Please ignore the step14 if the AGC function is closed

Note3. When configure ACODEC\_ADC\_ANA\_CONx, user should add a offset address to correspond channel:

add offset 0x000 for left\_0(ADC1) and right\_0(ADC2) channel;

add offset 0x040 for left\_1(ADC3) and right\_1(ADC4) channel;

add offset 0x080 for left\_2(ADC5) and right\_2(ADC6) channel;

add offset 0x0c0 for left\_3(ADC7) and right\_3(ADC8) channel.

Note4. When enable ADC for exiting lower power mode (ADC is configured to disable and Audio Codec is still power on), step0,1,2,12,13 can be ignored. Step4 and step5 can be merged as one step, step7,8 and 9 can be merged as one step.

## 8.6.10 Disable ADC

0. Keep ADC channel work and stop recording.

1. Configure the register ACODEC\_ADC\_ANA\_CON2[6] to 0, to disable the zero-crossing detection function in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON2[2] to 0, to disable the zero-crossing detection function in ADC left channel.

2. Configure the register ACODEC\_ADC\_ANA\_CON5[5] to 0, to disable the ADC module in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON5[1] to 0, to disable the ADC module in ADC

left channel.

3. Configure the register ACODEC\_ADC\_ANA\_CON5[4] to 0, to disable the clock module in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON5[0] to 0, to disable the clock module in ADC left channel.

4. Configure the register ACODEC\_ADC\_ANA\_CON2[4] to 0, to disable the ALC module in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON2[0] to 0, to disable the ALC module in ADC left channel.

5. Configure the register ACODEC\_ADC\_ANA\_CON0[5] to 0, to disable the MIC module in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON0[1] to 0, to disable the MIC module in ADC left channel

6. Configure the register ACODEC\_ADC\_ANA\_CON0[4] to 0, to disable the reference voltage buffer in ADC right channel.

Configure the register ACODEC\_ADC\_ANA\_CON0[0] to 0, to disable the reference voltage buffer in ADC left channel.

7. Configure the register ACODEC\_ADC\_ANA\_CON6[0] to 0, to disable the current source of the ADC.

8. Configure the register ACODEC\_ADC\_ANA\_CON5[6] to 0, to begin the initialization of the ADC right module.

Configure the register ACODEC\_ADC\_ANA\_CON5[2] to 0, to begin the initialization of the ADC left module.

9. Configure the register ACODEC\_ADC\_ANA\_CON2[5] to 0, to begin the initialization of the ALC right module.

Configure the register ACODEC\_ADC\_ANA\_CON2[1] to 0, to begin the initialization of the ALC left module.

10. Configure the register ACODEC\_ADC\_ANA\_CON0[6] to 0, to begin the initialization of the MIC right module.

Configure the register ACODEC\_ADC\_ANA\_CON0[2] to 0, to begin the initialization of the MIC left module

### 8.6.11 Enable ALC

1. Set he max level and min level of the ALC need to control. The AGC register ACODEC\_ALC\_DIG\_CON5 and ACODEC\_ALC\_DIG\_CON6 control the max level of the ALC. max\_level={ACODEC\_ALC\_DIG\_CON6, ACODEC\_ALC\_DIG\_CON5}; The relationship between the max\_level and the signal amplitude(dB) is equal to:

amplitude(dB)=20log(max\_level/0x7fff), 0x7fff means the full scale amplitude. The ACODEC\_ALC\_DIG\_CON7 and ACODEC\_ALC\_DIG\_CON8 control the min level of the ALC. min\_level={ACODEC\_ALC\_DIG\_CON8, ACODEC\_ALC\_DIG\_CON7}; The relationship between the min\_level and the signal amplitude(dB) is equal to:

amplitude(dB)=20log(min\_level/0x7fff), 0x7fff means the full scale amplitude

2. Set ACODEC\_ALC\_DIG\_CON4[2:0] according to the sample rate

3. Set ACODEC\_ALC\_DIG\_CON9[6] to 0x1, to enable the ALC module

4.Set ACODEC\_ADC\_ANA\_CON11[1:0], (ACODEC\_ADC\_ANA\_CON11+0x40)[1:0],

(ACODEC\_ADC\_ANA\_CON11+0x80)[1:0] and (ACODEC\_ADC\_ANA\_CON11+0xc0)[1:0] to 0x3, to enable the ALC module to control the gain of PGA.

5.Observe the current ALC output gain by reading ACODEC\_ALC\_DIG\_CON12[4:0]. Note1. expect the step4, other step should add a offset address to correspond channel as follow:

add offset 0x000 for left channel ALC1;

add offset 0x040 for right channel ALC2;

add offset 0x0c0 for left channel ALC3;

add offset 0x100 for right channel ALC4;

add offset 0x180 for left channel ALC5;

add offset 0x1c0 for right channel ALC6;

add offset 0x240 for left channel ALC7;

add offset 0x280 for right channel ALC8.

### 8.6.12 Disable ALC

1. Set ACODEC\_ALC\_DIG\_CON9[6] to 0x0, to disable the ALC module, then the ALC output gain will keep to the last vale.

2. Set ACODEC\_ADC\_ANA\_CON11[1:0], (ACODEC\_ADC\_ANA\_CON11+0x40)[1:0],

(ACODEC\_ADC\_ANA\_CON11+0x80)[1:0] and (ACODEC\_ADC\_ANA\_CON11+0xc0)[1:0] to 0x0, to disable the ALC module to control the gain of PGA.

Note1. expect the step2, other step should add a offset address as follow:

to correspond channel:

add offset 0x000 for left channel ALC1;

add offset 0x040 for right channel ALC2;

add offset 0x0c0 for left channel ALC3;

add offset 0x100 for right channel ALC4;

add offset 0x180 for left channel ALC5;

add offset 0x1c0 for right channel ALC6;

add offset 0x240 for left channel ALC7;

add offset 0x280 for right channel ALC8.

#### **8.6.13** Enable Headset Insert

1. Set ACODEC\_DAC\_ANA\_CON0[1] to 0x1, to enable the headset insert detection Note1. When the voltage of PAD HPDET> 8\*AVDD/9, the output value of the pin\_hpdet will be set to 0x1 and assert a interrupt.

8.6.14 Disable Headset Insert

1. Set ACODEC\_DAC\_ANA\_CON0[1] to 0x0, to disable the headset insert detection.

### 8.6.15 LOW POWER

This section describes the application of the low power in the Audio Codec. The following will introduce the two application mode of the low power.

#### light power down

The DAC take the gated clock technique which can reduce power. You can enable or disable the gated clock by configure the register ACODEC\_GLB\_CON[5:4]. When the register ACODEC\_GLB\_CON[5] and ACODEC\_GLB\_CON[4] set 1, the Audio Codec clock which is in the ADC path and DAC path will be cut off, which make the digital part in the low power state. If you want the Audio Codec work in the normal mode immediately, please configure the ACODEC\_GLB\_CON[5:4] to 2'b00.

#### deep power down

If you want the Audio Codec to go to the deep power down mode, please refer to following steps.

1. Close ALC according to the section disable ALC

2. Close DAC and ADC according to the section disable DAC and disable DAC.

3. Disable the MICBIAS according to the section disable MICBIAS.

4. Power off the codec according to the section power off.

However, once the Audio Codec enters this mode, if you want to return to the normal mode, please refer to the following steps.

1. Power up the codec according to the section power on.

- 2. Enable the MICBIAS according to the section enable MICBIAS.
- 3. Enable the DAC and ADC according to the section enable DAC and enable ADC.
- 4. Enable ALC according to the section enable ALC.

# **Chapter 9 DMA Controller (DMAC)**

# 9.1 Overview

This device supports 2 Direct Memory Access (DMA) Controllers, DMAC0 and DMAC1. Both of these two DMAC support transfers between memory and memory, peripheral and memory. DMAC is under Non-secure state after reset, and the secure state can be changed by configuring SGRF module.

DMAC0 supports the following features:

- Supports Trustzone technology
- Supports 12 peripheral request
- Up to 64bits data size
- 6 channel at the same time
- Up to burst 16
- 12 interrupts output and 1 abort output
- Supports 32 MFIFO depth

Following table shows the DMAC0 request mapping scheme.

Table 9-1 DMAC0 Request Mapping Table

| Req number | Source   | Polarity   |
|------------|----------|------------|
| 0          | SPI0 tx  | High level |
| 1          | SPI0 rx  | High level |
| 2          | SPI1 tx  | High level |
| 3          | SPI1 rx  | High level |
| 4          | UART0 tx | High level |
| 5          | UART0 rx | High level |
| 6          | UART1 tx | High level |
| 7          | UART1 rx | High level |
| 8          | UART2 tx | High level |
| 9          | UART2 rx | High level |
| 10         | UART3 tx | High level |
| 11         | UART3 rx | High level |

DMAC1 supports the following features:

- Supports Trustzone technology
- Supports 20 peripheral request
- Up to 64bits data size
- 8 channel at the same time
- Up to burst 16
- 16 interrupts output and 1 abort output
- Supports 128 MFIFO depth

Following table shows the DMAC1 request mapping scheme.

Table 9-2 DMAC1 Request Mapping Table

| Req number | Source               | Polarity   |
|------------|----------------------|------------|
| 0          | I2S/TDM/PCM_8CH_0 tx | High level |
| 1          | I2S/TDM/PCM_8CH_0 rx | High level |
| 2          | I2S/TDM/PCM_8CH_1 tx | High level |
| 3          | I2S/TDM/PCM_8CH_1 rx | High level |
| 4          | I2S/TDM/PCM_8CH_2 tx | High level |
| 5          | I2S/TDM/PCM_8CH_2 rx | High level |
| 6          | I2S/TDM/PCM_8CH_3 tx | High level |
| 7          | I2S/TDM/PCM_8CH_3 rx | High level |
| 8          | I2S/PCM_2CH_0 tx     | High level |
| 9          | I2S/PCM_2CH_0 rx     | High level |
| 10         | I2S/PCM_2CH_1 tx     | High level |
| 11         | I2S/PCM_2CH_1 rx     | High level |

| Req number | Source          | Polarity   |
|------------|-----------------|------------|
| 12         | PDM_8CH rx      | High level |
| 13         | SPDIF_8CH_TX tx | High level |
| 14         | SPDIF_8CH_RX rx | High level |
| 15         | PWM_4CH rx      | High level |
| 16         | SPI2 tx         | High level |
| 17         | SPI2 rx         | High level |
| 18         | UART4 tx        | High level |
| 19         | UART4 rx        | High level |

DMAC supports incrementing-address burst and fixed-address burst. But in the case of access SPI and UART at byte or halfword size, DMAC only support fixed-address burst and the address must be aligned to word.

# 9.2 Block Diagram

Following figure shows the block diagram of DMAC.



Fig. 9-1 Block diagram of DMAC

As the DMAC supports Trustzone technology, so dual APB interfaces enable the operation of the DMAC to be partitioned into the secure state and Non-secure state. You can use the APB interfaces to access status registers and also directly execute instructions in the DMAC. The default interface after reset is Non-secure apb interface.

# 9.3 Function Description

# 9.3.1 Introduction

The DMAC contains an instruction processing block that enables it to process program code that controls a DMA transfer. The program code is stored in a region of system memory that the DMAC accesses using its AXI interface. The DMAC stores instructions temporarily in a cache.

DMAC0 supports 6 channels and DMAC1 supports 8 channels, each channel capable of supporting a single concurrent thread of DMA operation. In addition, a single DMA manager thread exists, and you can use it to initialize the DMA channel threads. The DMAC executes up to one instruction for each AXI clock cycle. To ensure that it regularly executes each active thread, it alternates by processing the DMA manager thread and then a DMA channel thread. It uses a round-robin process when selecting the next active DMA channel thread to execute.

The DMAC uses variable-length instructions that consist of one to six bytes. It provides a separate Program Counter (PC) register for each DMA channel. When a thread requests an

instruction from an address, the cache performs a look-up. If a cache hit occurs, then the cache immediately provides the data. Otherwise, the thread is stalled while the DMAC uses the AXI interface to perform a cache line fill. If an instruction is greater than 4 bytes, or spans the end of a cache line, the DMAC performs multiple cache accesses to fetch the instruction.

When a cache line fill is in progress, the DMAC enables other threads to access the cache, but if another cache miss occurs, this stalls the pipeline until the first line fill is complete. When a DMA channel thread executes a load or store instruction, the DMAC adds the instruction to the relevant read or write queue. The DMAC uses these queues as an instruction storage buffer prior to it issuing the instructions on the AXI bus. The DMAC also contains a Multi First-In-First-Out (MFIFO) data buffer that it uses to store data that it reads, or writes, during a DMA transfer.

# 9.3.2 Operating states

Following figure shows the operating states for the DMA manager thread and DMA channel threads.



Fig. 9-2 DMAC operation states

Notes: arcs with no letter designator indicate state transitions for the DMA manager and DMA channel threads, otherwise use is restricted as follows:

C DMA channel threads only.

M DMA manager thread only.

After the DMAC exits from reset, it sets all DMA channel threads to the stopped state, and the status of boot\_from\_pc(tie-off interface of dmac) controls the DMA manager thread state:

boot\_from\_pc is LOW :DMA manager thread moves to the Stopped state. boot\_from\_pc is HIGH :DMA manager thread moves to the Executing state.

# 9.4 Register Description

# 9.4.1 Registers Summary

| Name          | Offset | Size | Reset<br>Value | Description                            |
|---------------|--------|------|----------------|----------------------------------------|
| DMA DSR       | 0x0000 | W    | 0x00000000     | DMA Manager Status Register            |
| DMA DPC       | 0x0004 | W    | 0x00000000     | DMA Program Counter Register           |
| DMA_INTEN     | 0x0020 | W    | 0x00000000     | Interrupt Enable Register              |
| DMA EVENT RIS | 0x0024 | W    | 0x00000000     | Event-Interrupt Raw Status<br>Register |
| DMA INTMIS    | 0x0028 | W    | 0x00000000     | Interrupt Status Register              |
| DMA INTCLR    | 0x002c | W    | 0x00000000     | Interrupt Clear Register               |

| Name      | Offset | Size | Reset<br>Value | Description                          |
|-----------|--------|------|----------------|--------------------------------------|
| DMA FSRD  | 0x0030 | W    | 0×00000000     | Fault Status DMA Manager<br>Register |
| DMA_FSRC  | 0x0034 | w    | 0×00000000     | Fault Status DMA Channel<br>Register |
| DMA FTRD  | 0x0038 | W    | 0x0000000      | Fault Type DMA Manager Register      |
| DMA_FTR0  | 0x0040 | W    | 0x0000000      | Fault Type DMA Channel Register      |
| DMA_FTR1  | 0x0044 | W    | 0x0000000      | Fault Type DMA Channel Register      |
| DMA_FTR2  | 0x0048 | W    | 0x0000000      | Fault Type DMA Channel Register      |
| DMA_FTR3  | 0x004c | W    | 0x0000000      | Fault Type DMA Channel Register      |
| DMA FTR4  | 0x0050 | W    | 0x0000000      | Fault Type DMA Channel Register      |
| DMA_FTR5  | 0x0054 | W    | 0x0000000      | Fault Type DMA Channel Register      |
| DMA_FTR6  | 0x0058 | W    | 0x0000000      | Fault Type DMA Channel Register      |
| DMA FTR7  | 0x005c | W    | 0x0000000      | Fault Type DMA Channel Register      |
| DMA_CSR0  | 0x0100 | W    | 0x0000000      | Channel Status Registers             |
| DMA CPCO  | 0x0104 | W    | 0x0000000      | Channel Program Counter<br>Registers |
| DMA CSR1  | 0x0108 | W    | 0x0000000      | Channel Status Registers             |
| DMA CPC1  | 0x010c | W    | 0×00000000     | Channel Program Counter<br>Registers |
| DMA CSR2  | 0x0110 | W    | 0x0000000      | Channel Status Registers             |
| DMA_CPC2  | 0x0114 | w    | 0×00000000     | Channel Program Counter<br>Registers |
| DMA CSR3  | 0x0118 | W    | 0x0000000      |                                      |
| DMA_CPC3  | 0x011c | W    | 0×00000000     | Channel Program Counter<br>Registers |
| DMA CSR4  | 0x0120 | W    | 0x0000000      | Channel Status Registers             |
| DMA_CPC4  | 0x0124 | W    | 0×00000000     | Channel Program Counter<br>Registers |
| DMA CSR5  | 0x0128 | W    | 0x0000000      | Channel Status Registers             |
| DMA_CPC5  | 0x012c | W    | 0×00000000     | Channel Program Counter<br>Registers |
| DMA CSR6  | 0x0130 | W    | 0x0000000      | Channel Status Registers             |
| DMA CPC6  | 0x0134 | w    | 0×00000000     | Channel Program Counter<br>Registers |
| DMA_CSR7  | 0x0138 | W    | 0x0000000      | Channel Status Registers             |
| DMA CPC7  | 0x013c | w    | 0x00000000     | Channel Program Counter<br>Registers |
| DMA_SAR0  | 0x0400 | W    | 0x00000000     | Source Address Registers             |
| DMA DARO  | 0x0404 | W    | -              | Destination Address Registers        |
| DMA_CCR0  | 0x0408 | W    |                | Channel Control Registers            |
| DMA_LC0_0 | 0x040c | W    |                | Loop Counter 0 Registers             |
| DMA LC1 0 | 0x0410 | W    |                | Loop Counter 1 Registers             |
| DMA_SAR1  | 0x0420 | W    |                | Source Address Registers             |

| Name                 | Offset | Size | Reset<br>Value | Description                   |
|----------------------|--------|------|----------------|-------------------------------|
| DMA_DAR1             | 0x0424 | W    | 0x0000000      | Destination Address Registers |
| DMA CCR1             | 0x0428 | W    | 0x00000000     | Channel Control Registers     |
| DMA LCO 1            | 0x042c | W    | 0x00000000     | Loop Counter 0 Registers      |
| DMA LC1 1            | 0x0430 | W    | 0x00000000     | Loop Counter 1 Registers      |
| DMA SAR2             | 0x0440 | W    | 0x00000000     | Source Address Registers      |
| DMA_DAR2             | 0x0444 | W    | 0x00000000     | Destination Address Registers |
| DMA CCR2             | 0x0448 | W    | 0x00000000     | Channel Control Registers     |
| DMA LCO 2            | 0x044c | W    | 0x00000000     | Loop Counter 0 Registers      |
| DMA LC1 2            | 0x0450 | W    | 0x00000000     | Loop Counter 1 Registers      |
| DMA SAR3             | 0x0460 | W    | 0x00000000     | Source Address Registers      |
| DMA DAR3             | 0x0464 | W    | 0x00000000     | Destination Address Registers |
| DMA_CCR3             | 0x0468 | W    | 0x00000000     | Channel Control Registers     |
| DMA LCO 3            | 0x046c | W    | 0x00000000     | Loop Counter 0 Registers      |
| DMA_LC1_3            | 0x0470 | W    | 0x00000000     | Loop Counter 1 Registers      |
| DMA SAR4             | 0x0480 | W    | 0x00000000     | Source Address Registers      |
| DMA DAR4             | 0x0484 | W    | 0x00000000     | Destination Address Registers |
| DMA_CCR4             | 0x0488 | W    | 0x00000000     | Channel Control Registers     |
| DMA LCO 4            | 0x048c | W    | 0x00000000     | Loop Counter 0 Registers      |
| DMA LC1 4            | 0x0490 | W    | 0x00000000     | Loop Counter 1 Registers      |
| DMA SAR5             | 0x04a0 | W    | 0x00000000     | Source Address Registers      |
| DMA DAR5             | 0x04a4 | W    | 0x00000000     | Destination Address Registers |
| DMA_CCR5             | 0x04a8 | W    | 0x00000000     | Channel Control Registers     |
| DMA LCO 5            | 0x04ac | W    | 0x00000000     | Loop Counter 0 Registers      |
| DMA LC1 5            | 0x04b0 | W    | 0x00000000     | Loop Counter 1 Registers      |
| DMA_SAR6             | 0x04c0 | W    | 0x00000000     | Source Address Registers      |
| <u>DMA DAR6</u>      | 0x04c4 | W    | 0x00000000     | Destination Address Registers |
| DMA CCR6             | 0x04c8 | W    | 0x00000000     | Channel Control Registers     |
| DMA LCO 6            | 0x04cc | W    | 0x0000000      | Loop Counter 0 Registers      |
| DMA LC1 6            | 0x04d0 | W    | 0x00000000     | Loop Counter 1 Registers      |
| DMA_SAR7             | 0x04e0 | W    | 0x0000000      | Source Address Registers      |
| DMA DAR7             | 0x04e4 | W    | 0x00000000     | Destination Address Registers |
| DMA CCR7             | 0x04e8 | W    | 0x00000000     | Channel Control Registers     |
| DMA_LC0_7            | 0x04ec | W    | 0x00000000     | Loop Counter 0 Registers      |
| <u>DMA LC1 7</u>     | 0x04f0 | W    | 0x00000000     | Loop Counter 1 Registers      |
| <u>DMA DBGSTATUS</u> | 0x0d00 | W    | 0x00000000     | Debug Status Register         |
| DMA DBGCMD           | 0x0d04 | W    | 0x0000000      | Debug Command Register        |
| DMA DBGINSTO         | 0x0d08 | W    | 0x0000000      | Debug Instruction-0 Register  |
| DMA_DBGINST1         | 0x0d0c | W    | 0x0000000      | Debug Instruction-1 Register  |
| DMA CRO              | 0x0e00 | W    | 0x00047051     | Configuration Register 0      |
| DMA CR1              | 0x0e04 | W    | 0x0000057      | Configuration Register 1      |
| DMA CR2              | 0x0e08 | W    | 0x0000000      | Configuration Register 2      |
| DMA CR3              | 0x0e0c | W    | 0x00000000     | Configuration Register 3      |

| Name     | Offset | Size | Reset<br>Value | Description              |
|----------|--------|------|----------------|--------------------------|
| DMA_CR4  | 0x0e10 | W    | 0x0000006      | Configuration Register 4 |
| DMA CRDn | 0x0e14 | W    | 0x02094733     | Configuration Register   |
| DMA WD   | 0x0e80 | W    | 0x00000000     | DMA Watchdog Register    |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# 9.4.2 Detail Register Description

### DMA DSR

Address: Operational Base + offset (0x0000)

| Bit   | Attr | <b>Reset Value</b> | Description                                        |
|-------|------|--------------------|----------------------------------------------------|
| 31:10 | RO   | 0x0                | reserved                                           |
|       |      |                    | dns                                                |
| 9     | RO   | 0x0                | 1'b0: DMA manager operates in the Secure state     |
|       |      |                    | 1'b1: DMA manager operates in the Non-secure state |
|       |      |                    | wakeup_event                                       |
|       |      |                    | 5'b00000: event[0]                                 |
| 8:4   | RO   | 0x00               | 5'b00001: event[1]                                 |
| 0.4   | KO   |                    | 5'b00010: event[2]                                 |
|       |      |                    |                                                    |
|       |      |                    | 5'b11111: event[31]                                |
|       |      |                    | dma_status                                         |
|       |      | RO 0x0             | 4'b0000: Stopped                                   |
|       |      |                    | 4'b0001: Executing                                 |
| 3:0   | RO   |                    | 4'b0010: Cache miss                                |
| 5.0   |      |                    | 4'b0011: Updating PC                               |
|       |      |                    | 4'b0100: Waiting for event                         |
|       |      |                    | 4'b0101-4'b1110: reserved                          |
|       |      |                    | 4'b1111: Faulting                                  |

### DMA\_DPC

Address: Operational Base + offset (0x0004)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:0 | RO   |                    | pc_mgr<br>Program counter for the DMA manager thread |

### DMA\_INTEN

Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:0 | RW   | 0×00000000         | event_irq_select<br>Bit [N]<br>1'b0: If the DMAC executes DMASEV for the event-interrupt<br>resource N then the DMAC signals event N to all of the threads.<br>Set bit [N] to 0 if your system design does not use irq[N] to<br>signal an interrupt request<br>1'b1: If the DMAC executes DMASEV for the event-interrupt<br>resource N then the DMAC sets irq[N] HIGH. Set bit [N] to 1 if<br>your system designer requires irq[N] to signal an interrupt<br>request |  |  |  |

### DMA\_EVENT\_RIS

Address: Operational Base + offset (0x0024)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                         |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000         | dmasev_active<br>Bit [N]<br>1'b0: Event N is inactive or irq[N] is LOW<br>1'b1: Event N is active or irq[N] is HIGH |

### DMA\_INTMIS

Address: Operational Base + offset (0x0028)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                        |
|------|------|--------------------|------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000         | irq_status<br>Bit [N]<br>1'b0: Interrupt N is inactive and therefore irq[N] is LOW |
|      |      |                    | 1'b1: Interrupt N is active and therefore irq[N] is HIGH                           |

### DMA INTCLR

Address: Operational Base + offset (0x002c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                          |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | wo   | 0×00000000         | <pre>irq_clr Bit [N] 1'b0: The status of irq[N] does not change 1'b1: The DMAC sets irq[N] LOW if the INTEN Register programs the DMAC to signal an interrupt. Otherwise, the status of irq[N] does not change</pre> |

### DMA FSRD

Address: Operational Base + offset (0x0030)

| Bit  | Attr | <b>Reset Value</b> | Description                                               |
|------|------|--------------------|-----------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                  |
|      |      |                    | fs_mgr                                                    |
| 0    | RO   | 0x0                | 1'b0: the DMA manager thread is not in the Faulting state |
|      |      |                    | 1'b1: the DMA manager thread is in the Faulting state     |

### DMA FSRC

Address: Operational Base + offset (0x0034)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                      |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                                                                                                         |
| 7:0  | RO   | 0×00               | fault_status<br>Bit [N]<br>1'b0: No fault is present on DMA channel N.<br>1'b1: DMA channel N is in the Faulting or Faulting completing<br>state |

#### DMA\_FTRD

Address: Operational Base + offset (0x0038)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                         |
|-------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                            |
| 30    | RO   | 0×0                | dbg_instr<br>memory or from the debug interface:<br>1'b0: instruction that generated an abort was read from system<br>memory<br>1'b1: instruction that generated an abort was read from the<br>debug interface                                                                      |
| 29:17 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                            |
| 16    | RO   | 0×0                | instr_fetch_err<br>performs an instruction fetch:<br>1'b0: OKAY response<br>1'b1: EXOKAY, SLVERR, or DECERR response                                                                                                                                                                |
| 15:6  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                            |
| 5     | RO   | 0×0                | mgr_evnt_err<br>1'b0: the DMA manager has appropriate security to execute<br>DMAWFE or DMASEV<br>1'b1: a DMA manager thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFE to wait for a secure event<br>o DMASEV to create a secure event or secure interrupt |
| 4     | RO   | 0×0                | dmago_err<br>1'b0: the DMA manager has appropriate security to execute<br>DMAGO<br>1'b1: a DMA manager thread in the Non-secure state attempted<br>to execute DMAGO to create a DMA channel operating in the<br>Secure state                                                        |
| 3:2   | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                            |
| 1     | RO   | 0×0                | operand_invalid<br>the configuration of the DMAC:<br>1'b0: valid operand<br>1'b1: invalid operand                                                                                                                                                                                   |

| Bit | Attr | <b>Reset Value</b> | Description                              |
|-----|------|--------------------|------------------------------------------|
| 0   | RW   |                    | undef_instr<br>1'b0: defined instruction |
| U   |      |                    | 1'b1: undefined instruction              |

Address: Operational Base + offset (0x0040)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                  |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RO   | 0×0                | lockup_err<br>1'b0: DMA channel has adequate resources<br>1'b1: DMA channel has locked-up because of insufficient<br>resources<br>This fault is an imprecise abort.                                                                                                                                          |
| 30    | RO   | 0×0                | dbg_instr<br>memory or from the debug interface:<br>1'b0: instruction that generated an abort was read from system<br>memory<br>1'b1: instruction that generated an abort was read from the<br>debug interface<br>This fault is an imprecise abort but the bit is only valid when a<br>precise abort occurs. |
| 29:19 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                     |
| 18    | RO   | 0×0                | data_read_err<br>thread performs a data read:<br>1'b0: OKAY response<br>1'b1: EXOKAY, SLVERR, or DECERR response<br>This fault is an imprecise abort.                                                                                                                                                        |
| 17    | RO   | 0×0                | data_write_err<br>thread performs a data write:<br>1'b0: OKAY response<br>1'b1: EXOKAY, SLVERR, or DECERR response<br>This fault is an imprecise abort.                                                                                                                                                      |
| 16    | RO   | 0×0                | instr_fetch_err<br>thread performs an instruction fetch:<br>1'b0: OKAY response<br>1'b1: EXOKAY, SLVERR, or DECERR response<br>This fault is a precise abort.                                                                                                                                                |
| 15:14 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                     |
| 13    | RO   | 0x0                | st_data_unavailable<br>1'b0: MFIFO contains all the data to enable the DMAST to<br>complete<br>1'b1: previous DMALDs have not put enough data in the MFIFO<br>to enable the DMAST to complete<br>This fault is a precise abort.                                                                              |

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0×0                | mfifo_err<br>DMALD<br>1'b0: MFIFO contains sufficient space<br>1'b1: MFIFO is too small to hold the data that DMALD requires<br>DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to<br>complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | RO   | 0×0                | ch_rdwr_err<br>to perform a secure read or secure write:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6    | RO   | 0×0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security<br>permissions:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFP to wait for a secure peripheral<br>o DMALDP or DMASTP to notify a secure peripheral<br>o DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5    | RO   | 0×0                | ch_event_err<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFE to wait for a secure event<br>o DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                  |
| 4:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1    | RO   | 0×0                | operand_invalid<br>valid for the configuration of the DMAC:<br>1'b0: valid operand<br>1'b1: invalid operand<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                            |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      | 0×0                | undef_instr                    |
| 0   | RO   |                    | 1'b0: defined instruction      |
| 0   | ĸŪ   |                    | 1'b1: undefined instruction    |
|     |      |                    | This fault is a precise abort. |

# DMA FTR1

Address: Operational Base + offset (0x0044)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
|       |      |                    | lockup_err                                                        |
|       |      |                    | 1'b0: DMA channel has adequate resources                          |
| 31    | RO   | 0x0                | 1'b1: DMA channel has locked-up because of insufficient           |
|       |      |                    | resources                                                         |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | dbg_instr                                                         |
|       |      |                    | memory or from the debug interface:                               |
|       |      |                    | 1'b0: instruction that generated an abort was read from system    |
| 30    | RO   | 0x0                | memory                                                            |
| 30    | кU   | UXU                | 1'b1: instruction that generated an abort was read from the       |
|       |      |                    | debug interface                                                   |
|       |      |                    | This fault is an imprecise abort but the bit is only valid when a |
|       |      |                    | precise abort occurs.                                             |
| 29:19 | RO   | 0x0                | reserved                                                          |
|       |      |                    | data_read_err                                                     |
|       |      | 0×0                | thread performs a data read:                                      |
| 18    | RO   |                    | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | data_write_err                                                    |
|       |      |                    | thread performs a data write:                                     |
| 17    | RO   | 0x0                | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | instr_fetch_err                                                   |
|       |      |                    | thread performs an instruction fetch:                             |
| 16    | RO   | 0 0x0              | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is a precise abort.                                    |
| 15:14 | RO   | 0x0                | reserved                                                          |
|       |      |                    | st_data_unavailable                                               |
|       |      |                    | 1'b0: MFIFO contains all the data to enable the DMAST to          |
| 13    | RO   | 0x0                | complete                                                          |
| 10    | κU   | .O UXU             | 1'b1: previous DMALDs have not put enough data in the MFIFO       |
|       |      |                    | to enable the DMAST to complete                                   |
|       |      |                    | This fault is a precise abort.                                    |

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0×0                | mfifo_err<br>DMALD<br>1'b0: MFIFO contains sufficient space<br>1'b1: MFIFO is too small to hold the data that DMALD requires<br>DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to<br>complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | RO   | 0×0                | <ul> <li>ch_rdwr_err</li> <li>to perform a secure read or secure write:</li> <li>1'b0: a DMA channel thread in the Non-secure state is not</li> <li>violating the security permissions</li> <li>1'b1: a DMA channel thread in the Non-secure state attempted</li> <li>to perform a secure read or secure write</li> <li>This fault is a precise abort.</li> </ul>                                                                                        |
| 6    | RO   | 0×0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security<br>permissions:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFP to wait for a secure peripheral<br>o DMALDP or DMASTP to notify a secure peripheral<br>o DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5    | RO   | 0×0                | ch_event_err<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFE to wait for a secure event<br>o DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                  |
| 4:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1    | RO   | 0×0                | operand_invalid<br>valid for the configuration of the DMAC:<br>1'b0: valid operand<br>1'b1: invalid operand<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                            |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      | 0×0                | undef_instr                    |
| 0   | RO   |                    | 1'b0: defined instruction      |
| U   | ĸŪ   |                    | 1'b1: undefined instruction    |
|     |      |                    | This fault is a precise abort. |

Address: Operational Base + offset (0x0048)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
|       |      |                    | lockup_err                                                        |
|       |      |                    | 1'b0: DMA channel has adequate resources                          |
| 31    | RO   | 0x0                | 1'b1: DMA channel has locked-up because of insufficient           |
|       |      |                    | resources                                                         |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | dbg_instr                                                         |
|       |      |                    | memory or from the debug interface:                               |
|       |      |                    | 1'b0: instruction that generated an abort was read from system    |
| 30    | RO   | 0x0                | memory                                                            |
| 30    | кU   | UXU                | 1'b1: instruction that generated an abort was read from the       |
|       |      |                    | debug interface                                                   |
|       |      |                    | This fault is an imprecise abort but the bit is only valid when a |
|       |      |                    | precise abort occurs.                                             |
| 29:19 | RO   | 0x0                | reserved                                                          |
|       |      |                    | data_read_err                                                     |
|       |      | 0×0                | thread performs a data read:                                      |
| 18    | RO   |                    | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | data_write_err                                                    |
|       |      |                    | thread performs a data write:                                     |
| 17    | RO   | 0x0                | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | instr_fetch_err                                                   |
|       |      |                    | thread performs an instruction fetch:                             |
| 16    | RO   | 0 0x0              | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is a precise abort.                                    |
| 15:14 | RO   | 0x0                | reserved                                                          |
|       |      |                    | st_data_unavailable                                               |
|       |      |                    | 1'b0: MFIFO contains all the data to enable the DMAST to          |
| 13    | RO   | 0x0                | complete                                                          |
| 10    | κU   | .O UXU             | 1'b1: previous DMALDs have not put enough data in the MFIFO       |
|       |      |                    | to enable the DMAST to complete                                   |
|       |      |                    | This fault is a precise abort.                                    |

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0×0                | mfifo_err<br>DMALD<br>1'b0: MFIFO contains sufficient space<br>1'b1: MFIFO is too small to hold the data that DMALD requires<br>DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to<br>complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | RO   | 0×0                | ch_rdwr_err<br>to perform a secure read or secure write:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6    | RO   | 0×0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security<br>permissions:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFP to wait for a secure peripheral<br>o DMALDP or DMASTP to notify a secure peripheral<br>o DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5    | RO   | 0×0                | ch_event_err<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFE to wait for a secure event<br>o DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                  |
| 4:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1    | RO   | 0×0                | operand_invalid<br>valid for the configuration of the DMAC:<br>1'b0: valid operand<br>1'b1: invalid operand<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                            |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      | 0×0                | undef_instr                    |
| 0   | RO   |                    | 1'b0: defined instruction      |
| U   | ĸŬ   |                    | 1'b1: undefined instruction    |
|     |      |                    | This fault is a precise abort. |

Address: Operational Base + offset (0x004c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
|       |      |                    | lockup_err                                                        |
|       |      |                    | 1'b0: DMA channel has adequate resources                          |
| 31    | RO   | 0x0                | 1'b1: DMA channel has locked-up because of insufficient           |
|       |      |                    | resources                                                         |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | dbg_instr                                                         |
|       |      |                    | memory or from the debug interface:                               |
|       |      |                    | 1'b0: instruction that generated an abort was read from system    |
| 30    | RO   | 0x0                | memory                                                            |
| 50    | κυ   | 0.00               | 1'b1: instruction that generated an abort was read from the       |
|       |      |                    | debug interface                                                   |
|       |      |                    | This fault is an imprecise abort but the bit is only valid when a |
|       |      |                    | precise abort occurs.                                             |
| 29:19 | RO   | 0x0                | reserved                                                          |
|       |      |                    | data_read_err                                                     |
|       |      | 0x0                | thread performs a data read:                                      |
| 18    | RO   |                    | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | data_write_err                                                    |
|       |      |                    | thread performs a data write:                                     |
| 17    | RO   | 0x0                | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | instr_fetch_err                                                   |
|       |      |                    | thread performs an instruction fetch:                             |
| 16    | RO   | 0x0                | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is a precise abort.                                    |
| 15:14 | RO   | 0x0                | reserved                                                          |
|       |      |                    | st_data_unavailable                                               |
|       |      |                    | 1'b0: MFIFO contains all the data to enable the DMAST to          |
| 13    | RO   | 0~0                | complete                                                          |
| 13    | κŪ   |                    | 1'b1: previous DMALDs have not put enough data in the MFIFO       |
|       |      |                    | to enable the DMAST to complete                                   |
|       |      |                    | This fault is a precise abort.                                    |

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0×0                | mfifo_err<br>DMALD<br>1'b0: MFIFO contains sufficient space<br>1'b1: MFIFO is too small to hold the data that DMALD requires<br>DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to<br>complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | RO   | 0×0                | <ul> <li>ch_rdwr_err</li> <li>to perform a secure read or secure write:</li> <li>1'b0: a DMA channel thread in the Non-secure state is not</li> <li>violating the security permissions</li> <li>1'b1: a DMA channel thread in the Non-secure state attempted</li> <li>to perform a secure read or secure write</li> <li>This fault is a precise abort.</li> </ul>                                                                                        |
| 6    | RO   | 0×0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security<br>permissions:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFP to wait for a secure peripheral<br>o DMALDP or DMASTP to notify a secure peripheral<br>o DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5    | RO   | 0×0                | ch_event_err<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFE to wait for a secure event<br>o DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                  |
| 4:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1    | RO   | 0×0                | operand_invalid<br>valid for the configuration of the DMAC:<br>1'b0: valid operand<br>1'b1: invalid operand<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                            |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      | 0×0                | undef_instr                    |
| 0   | RO   |                    | 1'b0: defined instruction      |
| U   | ĸŬ   |                    | 1'b1: undefined instruction    |
|     |      |                    | This fault is a precise abort. |

Address: Operational Base + offset (0x0050)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
|       |      |                    | lockup_err                                                        |
|       |      |                    | 1'b0: DMA channel has adequate resources                          |
| 31    | RO   | 0x0                | 1'b1: DMA channel has locked-up because of insufficient           |
|       |      |                    | resources                                                         |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | dbg_instr                                                         |
|       |      |                    | memory or from the debug interface:                               |
|       |      |                    | 1'b0: instruction that generated an abort was read from system    |
| 30    | RO   | 0x0                | memory                                                            |
| 50    | ĸŪ   | 0.00               | 1'b1: instruction that generated an abort was read from the       |
|       |      |                    | debug interface                                                   |
|       |      |                    | This fault is an imprecise abort but the bit is only valid when a |
|       |      |                    | precise abort occurs.                                             |
| 29:19 | RO   | 0x0                | reserved                                                          |
|       |      |                    | data_read_err                                                     |
|       |      | 0×0                | thread performs a data read:                                      |
| 18    | RO   |                    | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | data_write_err                                                    |
|       |      |                    | thread performs a data write:                                     |
| 17    | RO   | 0x0                | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | instr_fetch_err                                                   |
|       |      |                    | thread performs an instruction fetch:                             |
| 16    | RO   | O 0x0              | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is a precise abort.                                    |
| 15:14 | RO   | 0x0                | reserved                                                          |
|       |      |                    | st_data_unavailable                                               |
|       |      |                    | 1'b0: MFIFO contains all the data to enable the DMAST to          |
| 13    | RO   | 0x0                | complete                                                          |
| 10    | κU   | U UXU              | 1'b1: previous DMALDs have not put enough data in the MFIFO       |
|       |      |                    | to enable the DMAST to complete                                   |
|       |      |                    | This fault is a precise abort.                                    |

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0×0                | mfifo_err<br>DMALD<br>1'b0: MFIFO contains sufficient space<br>1'b1: MFIFO is too small to hold the data that DMALD requires<br>DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to<br>complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | RO   | 0×0                | ch_rdwr_err<br>to perform a secure read or secure write:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6    | RO   | 0×0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security<br>permissions:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFP to wait for a secure peripheral<br>o DMALDP or DMASTP to notify a secure peripheral<br>o DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5    | RO   | 0×0                | ch_event_err<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFE to wait for a secure event<br>o DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                  |
| 4:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1    | RO   | 0×0                | operand_invalid<br>valid for the configuration of the DMAC:<br>1'b0: valid operand<br>1'b1: invalid operand<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                            |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      | 0×0                | undef_instr                    |
| 0   | RO   |                    | 1'b0: defined instruction      |
| U   | ĸŪ   |                    | 1'b1: undefined instruction    |
|     |      |                    | This fault is a precise abort. |

Address: Operational Base + offset (0x0054)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
|       |      |                    | lockup_err                                                        |
|       |      |                    | 1'b0: DMA channel has adequate resources                          |
| 31    | RO   | 0x0                | 1'b1: DMA channel has locked-up because of insufficient           |
|       |      |                    | resources                                                         |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | dbg_instr                                                         |
|       |      |                    | memory or from the debug interface:                               |
|       |      |                    | 1'b0: instruction that generated an abort was read from system    |
| 30    | RO   | 0x0                | memory                                                            |
| 50    | NO.  | 0.00               | 1'b1: instruction that generated an abort was read from the       |
|       |      |                    | debug interface                                                   |
|       |      |                    | This fault is an imprecise abort but the bit is only valid when a |
|       |      |                    | precise abort occurs.                                             |
| 29:19 | RO   | 0x0                | reserved                                                          |
|       |      |                    | data_read_err                                                     |
|       |      | 0x0                | thread performs a data read:                                      |
| 18    | RO   |                    | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | data_write_err                                                    |
|       |      |                    | thread performs a data write:                                     |
| 17    | RO   | 0x0                | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | instr_fetch_err                                                   |
|       |      |                    | thread performs an instruction fetch:                             |
| 16    | RO   | 0x0                | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is a precise abort.                                    |
| 15:14 | RO   | 0x0                | reserved                                                          |
|       |      |                    | st_data_unavailable                                               |
|       |      |                    | 1'b0: MFIFO contains all the data to enable the DMAST to          |
| 10    |      | 0.20               | complete                                                          |
| 13    | RO   |                    | 1'b1: previous DMALDs have not put enough data in the MFIFO       |
|       |      |                    | to enable the DMAST to complete                                   |
|       |      |                    | This fault is a precise abort.                                    |

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0×0                | mfifo_err<br>DMALD<br>1'b0: MFIFO contains sufficient space<br>1'b1: MFIFO is too small to hold the data that DMALD requires<br>DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to<br>complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | RO   | 0×0                | ch_rdwr_err<br>to perform a secure read or secure write:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6    | RO   | 0×0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security<br>permissions:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFP to wait for a secure peripheral<br>o DMALDP or DMASTP to notify a secure peripheral<br>o DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5    | RO   | 0×0                | ch_event_err<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFE to wait for a secure event<br>o DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                  |
| 4:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1    | RO   | 0×0                | operand_invalid<br>valid for the configuration of the DMAC:<br>1'b0: valid operand<br>1'b1: invalid operand<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                            |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      | 0×0                | undef_instr                    |
| 0   | RO   |                    | 1'b0: defined instruction      |
| 0   | ĸŪ   |                    | 1'b1: undefined instruction    |
|     |      |                    | This fault is a precise abort. |

Address: Operational Base + offset (0x0058)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
|       |      |                    | lockup_err                                                        |
|       |      |                    | 1'b0: DMA channel has adequate resources                          |
| 31    | RO   | 0x0                | 1'b1: DMA channel has locked-up because of insufficient           |
|       |      |                    | resources                                                         |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | dbg_instr                                                         |
|       |      |                    | memory or from the debug interface:                               |
|       |      |                    | 1'b0: instruction that generated an abort was read from system    |
| 30    | RO   | 0x0                | memory                                                            |
| 50    | ĸŪ   | 0.00               | 1'b1: instruction that generated an abort was read from the       |
|       |      |                    | debug interface                                                   |
|       |      |                    | This fault is an imprecise abort but the bit is only valid when a |
|       |      |                    | precise abort occurs.                                             |
| 29:19 | RO   | 0x0                | reserved                                                          |
|       |      |                    | data_read_err                                                     |
|       |      | 0×0                | thread performs a data read:                                      |
| 18    | RO   |                    | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      | 0x0                | data_write_err                                                    |
|       |      |                    | thread performs a data write:                                     |
| 17    | RO   |                    | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | instr_fetch_err                                                   |
|       |      |                    | thread performs an instruction fetch:                             |
| 16    | RO   | 0x0                | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is a precise abort.                                    |
| 15:14 | RO   | 0x0                | reserved                                                          |
|       |      |                    | st_data_unavailable                                               |
|       |      |                    | 1'b0: MFIFO contains all the data to enable the DMAST to          |
| 13    | RO   | 0x0                | complete                                                          |
| 10    | κU   |                    | 1'b1: previous DMALDs have not put enough data in the MFIFO       |
|       |      |                    | to enable the DMAST to complete                                   |
|       |      |                    | This fault is a precise abort.                                    |

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0×0                | mfifo_err<br>DMALD<br>1'b0: MFIFO contains sufficient space<br>1'b1: MFIFO is too small to hold the data that DMALD requires<br>DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to<br>complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | RO   | 0×0                | ch_rdwr_err<br>to perform a secure read or secure write:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6    | RO   | 0×0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security<br>permissions:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFP to wait for a secure peripheral<br>o DMALDP or DMASTP to notify a secure peripheral<br>o DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5    | RO   | 0×0                | ch_event_err<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFE to wait for a secure event<br>o DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                  |
| 4:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1    | RO   | 0×0                | operand_invalid<br>valid for the configuration of the DMAC:<br>1'b0: valid operand<br>1'b1: invalid operand<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                            |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      | 0×0                | undef_instr                    |
| 0   | RO   |                    | 1'b0: defined instruction      |
| U   | ĸŪ   |                    | 1'b1: undefined instruction    |
|     |      |                    | This fault is a precise abort. |

# DMA FTR7

Address: Operational Base + offset (0x005c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
|       |      |                    | lockup_err                                                        |
|       |      |                    | 1'b0: DMA channel has adequate resources                          |
| 31    | RO   | 0x0                | 1'b1: DMA channel has locked-up because of insufficient           |
|       |      |                    | resources                                                         |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | dbg_instr                                                         |
|       |      |                    | memory or from the debug interface:                               |
|       |      |                    | 1'b0: instruction that generated an abort was read from system    |
| 30    | RO   | 0x0                | memory                                                            |
| 50    | Ň    | 0.00               | 1'b1: instruction that generated an abort was read from the       |
|       |      |                    | debug interface                                                   |
|       |      |                    | This fault is an imprecise abort but the bit is only valid when a |
|       |      |                    | precise abort occurs.                                             |
| 29:19 | RO   | 0x0                | reserved                                                          |
|       |      |                    | data_read_err                                                     |
|       |      | 0×0                | thread performs a data read:                                      |
| 18    | RO   |                    | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | data_write_err                                                    |
|       |      |                    | thread performs a data write:                                     |
| 17    | RO   | 0x0                | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is an imprecise abort.                                 |
|       |      |                    | instr_fetch_err                                                   |
|       |      |                    | thread performs an instruction fetch:                             |
| 16    | RO   | 0x0                | 1'b0: OKAY response                                               |
|       |      |                    | 1'b1: EXOKAY, SLVERR, or DECERR response                          |
|       |      |                    | This fault is a precise abort.                                    |
| 15:14 | RO   | 0x0                | reserved                                                          |
|       |      |                    | st_data_unavailable                                               |
|       |      |                    | 1'b0: MFIFO contains all the data to enable the DMAST to          |
|       |      |                    | complete                                                          |
| 13    | RO   | RO 0x0             | 1'b1: previous DMALDs have not put enough data in the MFIFO       |
|       |      |                    | to enable the DMAST to complete                                   |
|       |      |                    | This fault is a precise abort.                                    |
|       |      |                    |                                                                   |

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RO   | 0×0                | mfifo_err<br>DMALD<br>1'b0: MFIFO contains sufficient space<br>1'b1: MFIFO is too small to hold the data that DMALD requires<br>DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to<br>complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | RO   | 0×0                | <ul> <li>ch_rdwr_err</li> <li>to perform a secure read or secure write:</li> <li>1'b0: a DMA channel thread in the Non-secure state is not</li> <li>violating the security permissions</li> <li>1'b1: a DMA channel thread in the Non-secure state attempted</li> <li>to perform a secure read or secure write</li> <li>This fault is a precise abort.</li> </ul>                                                                                        |
| 6    | RO   | 0×0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security<br>permissions:<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFP to wait for a secure peripheral<br>o DMALDP or DMASTP to notify a secure peripheral<br>o DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5    | RO   | 0×0                | ch_event_err<br>1'b0: a DMA channel thread in the Non-secure state is not<br>violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted<br>to execute either:<br>o DMAWFE to wait for a secure event<br>o DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                  |
| 4:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1    | RO   | 0×0                | operand_invalid<br>valid for the configuration of the DMAC:<br>1'b0: valid operand<br>1'b1: invalid operand<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                            |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      | 0x0                | undef_instr                    |
| 0   | RO   |                    | 1'b0: defined instruction      |
| 0   |      |                    | 1'b1: undefined instruction    |
|     |      |                    | This fault is a precise abort. |

Address: Operational Base + offset (0x0100)

| Bit   |    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21    | RO | 0x0         | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                                                                                     |
| 20:16 | RO | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    | RO | 0×0         | dmawfp_periph<br>1'b0: DMAWFP executed with the periph operand not set<br>1'b1: DMAWFP executed with the periph operand set                                                                                                                                                                                                                                                                                                     |
| 14    | RO | 0x0         | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                                                                                            |
| 13:9  | RO | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8:4   | RO | 0×00        | <ul> <li>wakeup_number</li> <li>indicate the event or peripheral number that the channel is</li> <li>waiting for:</li> <li>5'b00000: DMA channel is waiting for event, or peripheral, 0</li> <li>5'b00001: DMA channel is waiting for event, or peripheral, 1</li> <li>5'b00010: DMA channel is waiting for event, or peripheral, 2</li> <li></li> <li>5'b11111: DMA channel is waiting for event, or peripheral, 31</li> </ul> |
| 3:0   | RO | 0×0         | channel_status<br>4'b000: Stopped<br>4'b001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>b1010-b1101 = reserved<br>b1110 = Faulting completing<br>b1111 = Faulting                                                                                      |

### DMA\_CPC0

### RK3308 TRM-Part1

### Address: Operational Base + offset (0x0104)

| Bit  | Attr | <b>Reset Value</b> | Description                                             |
|------|------|--------------------|---------------------------------------------------------|
| 31:0 | RO   | 02000000000        | pc_chnl<br>Program counter for the DMA channel 0 thread |

### DMA CSR1

Address: Operational Base + offset (0x0108)

| Bit   |    | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|----|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21    | RO | 0x0                | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                                                                                     |
| 20:16 | RO | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    | RO | 0x0                | dmawfp_periph<br>1'b0: DMAWFP executed with the periph operand not set<br>1'b1: DMAWFP executed with the periph operand set                                                                                                                                                                                                                                                                                                     |
| 14    | RO | 0x0                | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                                                                                            |
| 13:9  | RO | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8:4   | RO | 0x00               | <ul> <li>wakeup_number</li> <li>indicate the event or peripheral number that the channel is</li> <li>waiting for:</li> <li>5'b00000: DMA channel is waiting for event, or peripheral, 0</li> <li>5'b00001: DMA channel is waiting for event, or peripheral, 1</li> <li>5'b00010: DMA channel is waiting for event, or peripheral, 2</li> <li></li> <li>5'b11111: DMA channel is waiting for event, or peripheral, 31</li> </ul> |
| 3:0   | RO | 0×0                | channel_status<br>4'b000: Stopped<br>4'b001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>b1010-b1101 = reserved<br>b1110 = Faulting completing<br>b1111 = Faulting                                                                                      |

### DMA\_CPC1

Address: Operational Base + offset (0x010c)

| Bit  | Attr    | <b>Reset Value</b> | Description                                  |
|------|---------|--------------------|----------------------------------------------|
| 31.0 | 31:0 RO |                    | pc_chnl                                      |
| 51.0 |         |                    | Program counter for the DMA channel 1 thread |

Address: Operational Base + offset (0x0110)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21    | RO   | 0×0                | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                                                                                     |
| 20:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    | RO   | 0x0                | dmawfp_periph<br>1'b0: DMAWFP executed with the periph operand not set<br>1'b1: DMAWFP executed with the periph operand set                                                                                                                                                                                                                                                                                                     |
| 14    | RO   | 0x0                | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                                                                                            |
| 13:9  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8:4   | RO   | 0×00               | <ul> <li>wakeup_number</li> <li>indicate the event or peripheral number that the channel is</li> <li>waiting for:</li> <li>5'b00000: DMA channel is waiting for event, or peripheral, 0</li> <li>5'b00001: DMA channel is waiting for event, or peripheral, 1</li> <li>5'b00010: DMA channel is waiting for event, or peripheral, 2</li> <li></li> <li>5'b11111: DMA channel is waiting for event, or peripheral, 31</li> </ul> |
| 3:0   | RO   | 0×0                | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>b1010-b1101 = reserved<br>b1110 = Faulting completing<br>b1111 = Faulting                                                                                    |

# DMA CPC2

Address: Operational Base + offset (0x0114)

| Bit  | Attr    | <b>Reset Value</b> | Description                                  |
|------|---------|--------------------|----------------------------------------------|
| 31.0 | 31:0 RO |                    | pc_chnl                                      |
| 51.0 |         |                    | Program counter for the DMA channel 2 thread |

Address: Operational Base + offset (0x0118)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21    | RO   | 0×0                | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                                                                                     |
| 20:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    | RO   | 0×0                | dmawfp_periph<br>1'b0: DMAWFP executed with the periph operand not set<br>1'b1: DMAWFP executed with the periph operand set                                                                                                                                                                                                                                                                                                     |
| 14    | RO   | 0x0                | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                                                                                            |
| 13:9  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8:4   | RO   | 0x00               | <ul> <li>wakeup_number</li> <li>indicate the event or peripheral number that the channel is</li> <li>waiting for:</li> <li>5'b00000: DMA channel is waiting for event, or peripheral, 0</li> <li>5'b00001: DMA channel is waiting for event, or peripheral, 1</li> <li>5'b00010: DMA channel is waiting for event, or peripheral, 2</li> <li></li> <li>5'b11111: DMA channel is waiting for event, or peripheral, 31</li> </ul> |
| 3:0   | RO   | 0×0                | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>b1010-b1101 = reserved<br>b1110 = Faulting completing<br>b1111 = Faulting                                                                                    |

# DMA CPC3

Address: Operational Base + offset (0x011c)

| Bit  | Attr | <b>Reset Value</b> | Description                                  |
|------|------|--------------------|----------------------------------------------|
| 31:0 | RO   |                    | pc_chnl                                      |
|      |      |                    | Program counter for the DMA channel 3 thread |

Address: Operational Base + offset (0x0120)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21    | RO   | 0x0                | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                                                                                     |
| 20:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    | RO   | 0x0                | dmawfp_periph<br>1'b0: DMAWFP executed with the periph operand not set<br>1'b1: DMAWFP executed with the periph operand set                                                                                                                                                                                                                                                                                                     |
| 14    | RO   | 0x0                | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                                                                                            |
| 13:9  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8:4   | RO   | 0×00               | <ul> <li>wakeup_number</li> <li>indicate the event or peripheral number that the channel is</li> <li>waiting for:</li> <li>5'b00000: DMA channel is waiting for event, or peripheral, 0</li> <li>5'b00001: DMA channel is waiting for event, or peripheral, 1</li> <li>5'b00010: DMA channel is waiting for event, or peripheral, 2</li> <li></li> <li>5'b11111: DMA channel is waiting for event, or peripheral, 31</li> </ul> |
| 3:0   | RO   | 0×0                | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>b1010-b1101 = reserved<br>b1110 = Faulting completing<br>b1111 = Faulting                                                                                    |

# DMA CPC4

Address: Operational Base + offset (0x0124)

| Bit  | Attr | <b>Reset Value</b> | Description                                  |
|------|------|--------------------|----------------------------------------------|
| 31:0 | RO   |                    | pc_chnl                                      |
|      | -    |                    | Program counter for the DMA channel 4 thread |

Address: Operational Base + offset (0x0128)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21    | RO   | 0x0                | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                                                                                     |
| 20:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    | RO   | 0×0                | dmawfp_periph<br>1'b0: DMAWFP executed with the periph operand not set<br>1'b1: DMAWFP executed with the periph operand set                                                                                                                                                                                                                                                                                                     |
| 14    | RO   | 0x0                | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                                                                                            |
| 13:9  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8:4   | RO   | 0x00               | <ul> <li>wakeup_number</li> <li>indicate the event or peripheral number that the channel is</li> <li>waiting for:</li> <li>5'b00000: DMA channel is waiting for event, or peripheral, 0</li> <li>5'b00001: DMA channel is waiting for event, or peripheral, 1</li> <li>5'b00010: DMA channel is waiting for event, or peripheral, 2</li> <li></li> <li>5'b11111: DMA channel is waiting for event, or peripheral, 31</li> </ul> |
| 3:0   | RO   | 0×0                | channel_status<br>4'b000: Stopped<br>4'b001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>b1010-b1101 = reserved<br>b1110 = Faulting completing<br>b1111 = Faulting                                                                                      |

# DMA CPC5

Address: Operational Base + offset (0x012c)

| Bit  | Attr | <b>Reset Value</b> | Description                                  |
|------|------|--------------------|----------------------------------------------|
| 31:0 | RO   |                    | pc_chnl                                      |
| 51.0 |      |                    | Program counter for the DMA channel 5 thread |

Address: Operational Base + offset (0x0130)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21    | RO   | 0x0                | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                                                                                     |
| 20:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    | RO   | 0x0                | dmawfp_periph<br>1'b0: DMAWFP executed with the periph operand not set<br>1'b1: DMAWFP executed with the periph operand set                                                                                                                                                                                                                                                                                                     |
| 14    | RO   | 0x0                | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                                                                                            |
| 13:9  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8:4   | RO   | 0×00               | <ul> <li>wakeup_number</li> <li>indicate the event or peripheral number that the channel is</li> <li>waiting for:</li> <li>5'b00000: DMA channel is waiting for event, or peripheral, 0</li> <li>5'b00001: DMA channel is waiting for event, or peripheral, 1</li> <li>5'b00010: DMA channel is waiting for event, or peripheral, 2</li> <li></li> <li>5'b11111: DMA channel is waiting for event, or peripheral, 31</li> </ul> |
| 3:0   | RO   | 0×0                | channel_status<br>4'b000: Stopped<br>4'b001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>b1010-b1101 = reserved<br>b1110 = Faulting completing<br>b1111 = Faulting                                                                                      |

# DMA CPC6

Address: Operational Base + offset (0x0134)

| Bit  | Attr    | <b>Reset Value</b> | Description                                  |
|------|---------|--------------------|----------------------------------------------|
| 31.0 | 31:0 RO |                    | pc_chnl                                      |
| 51.0 |         |                    | Program counter for the DMA channel 6 thread |

# DMA CSR7

Address: Operational Base + offset (0x0138)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21    | RO   | 0x0                | cns<br>1'b0: DMA channel operates in the Secure state<br>1'b1: DMA channel operates in the Non-secure state                                                                                                                                                                                                                                                                                                                     |
| 20:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15    | RO   | 0x0                | dmawfp_periph<br>1'b0: DMAWFP executed with the periph operand not set<br>1'b1: DMAWFP executed with the periph operand set                                                                                                                                                                                                                                                                                                     |
| 14    | RO   | 0x0                | dmawfp_b_ns<br>1'b0: DMAWFP executed with the single operand set<br>1'b1: DMAWFP executed with the burst operand set                                                                                                                                                                                                                                                                                                            |
| 13:9  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8:4   | RO   | 0x00               | <ul> <li>wakeup_number</li> <li>indicate the event or peripheral number that the channel is</li> <li>waiting for:</li> <li>5'b00000: DMA channel is waiting for event, or peripheral, 0</li> <li>5'b00001: DMA channel is waiting for event, or peripheral, 1</li> <li>5'b00010: DMA channel is waiting for event, or peripheral, 2</li> <li></li> <li>5'b11111: DMA channel is waiting for event, or peripheral, 31</li> </ul> |
| 3:0   | RO   | 0×0                | channel_status<br>4'b0000: Stopped<br>4'b0001: Executing<br>4'b0010: Cache miss<br>4'b0011: Updating PC<br>4'b0100: Waiting for event<br>4'b0101: At barrier<br>4'b0110: reserved<br>4'b0111: Waiting for peripheral<br>4'b1000: Killing<br>4'b1001: Completing<br>b1010-b1101 = reserved<br>b1110 = Faulting completing<br>b1111 = Faulting                                                                                    |

**DMA\_CPC7** Address: Operational Base + offset (0x013c)

| Bit  | Attr | <b>Reset Value</b> | Description                                             |
|------|------|--------------------|---------------------------------------------------------|
| 31:0 | RO   |                    | pc_chnl<br>Program counter for the DMA channel 7 thread |

# DMA SARO

Address: Operational Base + offset (0x0400)

| В  | Bit | Attr | <b>Reset Value</b> | Description                                              |
|----|-----|------|--------------------|----------------------------------------------------------|
| 31 | :0  | RO   | 0_00000000         | src_addr<br>Address of the source data for DMA channel 0 |

# DMA DARO

Address: Operational Base + offset (0x0404)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
| 31:0 | RO   | 0200000000         | dst_addr<br>Address of the Destinationdata for DMA channel 0 |

### DMA\_CCR0

Address: Operational Base + offset (0x0408)

| Bit   | Attr | <b>Reset Value</b> | Description              |
|-------|------|--------------------|--------------------------|
| 31:28 | RO   | 0x0                | reserved                 |
|       |      |                    | dst_cache_ctrl           |
|       |      |                    | Bit [27]                 |
|       |      |                    | 1'b0: AWCACHE[3] is LOW  |
|       |      |                    | 1'b1: AWCACHE[3] is HIGH |
| 27:25 | PO   | 0x0                | Bit [26]                 |
| 27.25 | κυ   | 0.00               | 1'b0: AWCACHE[1] is LOW  |
|       |      |                    | 1'b1: AWCACHE[1] is HIGH |
|       |      |                    | Bit [25]                 |
|       |      |                    | 1'b0: AWCACHE[0] is LOW  |
|       |      |                    | 1'b1: AWCACHE[0] is HIGH |
|       |      |                    | dst_prot_ctrl            |
|       |      |                    | Bit [24]                 |
|       |      |                    | 1'b0: AWPROT[2] is LOW   |
|       |      |                    | 1'b1: AWPROT[2] is HIGH  |
| 24:22 | PO   | 0x0                | Bit [23]                 |
| 24.22 | κυ   |                    | 1'b0: AWPROT[1] is LOW   |
|       |      |                    | 1'b1: AWPROT[1] is HIGH  |
|       |      |                    | Bit [22]                 |
|       |      |                    | 1'b0: AWPROT[0] is LOW   |
|       |      |                    | 1'b1: AWPROT[0] is HIGH  |

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:18 | RO   | 0×0                | dst_burst_len<br>the destination data:<br>4'b0000: 1 data transfer<br>4'b0001: 2 data transfers<br>4'b0010: 3 data transfers<br><br>4'b1111: 16 data transfers<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size.                                                           |
| 17:15 | RO   | 0×0                | dst_burst_size<br>3'b000: writes 1 byte per beat<br>3'b001: writes 2 bytes per beat<br>3'b010: writes 4 bytes per beat<br>3'b011: writes 8 bytes per beat<br>3'b100: writes 16 bytes per beat<br>3'b101-3'b111: reserved<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size. |
| 14    | RO   | 0×0                | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>AWBURST[0] HIGH.                                                                                                                                                                                                                                           |
| 13:11 | RO   | 0×0                | src_cache_ctrl<br>Bit [13]<br>1'b0: ARCACHE[2] is LOW<br>1'b1: ARCACHE[2] is HIGH<br>Bit [12]<br>1'b0: ARCACHE[1] is LOW<br>1'b1: ARCACHE[1] is HIGH<br>Bit [11]<br>1'b0: ARCACHE[0] is LOW<br>1'b1: ARCACHE[0] is HIGH                                                                                                                                                                    |
| 10:8  | RO   | 0×0                | src_prot_ctrl<br>Bit [10]<br>1'b0: ARPROT[2] is LOW<br>1'b1: ARPROT[2] is HIGH<br>Bit [9]<br>1'b0: ARPROT[1] is LOW<br>1'b1: ARPROT[1] is HIGH<br>Bit [8]<br>1'b0: ARPROT[0] is LOW<br>1'b1: ARPROT[0] is HIGH                                                                                                                                                                             |

| Bit | Attr | <b>Reset Value</b> | Description                                                  |
|-----|------|--------------------|--------------------------------------------------------------|
|     |      |                    | src_burst_len                                                |
|     |      |                    | 4'b0000: 1 data transfer                                     |
|     |      |                    | 4'b0001: 2 data transfers                                    |
|     |      |                    | 4'b0010: 3 data transfers                                    |
| 7:4 | RO   | 0x0                |                                                              |
|     |      |                    | 4'b1111: 16 data transfers                                   |
|     |      |                    | The total number of bytes that the DMAC reads into the MFIFO |
|     |      |                    | when it executes a DMALD instruction is the product of       |
|     |      |                    | src_burst_len and src_burst_size.                            |
|     |      | 0×0                | src_burst_size                                               |
|     |      |                    | 3'b000: reads 1 byte per beat                                |
|     |      |                    | 3'b001: reads 2 bytes per beat                               |
|     |      |                    | 3'b010: reads 4 bytes per beat                               |
| 3:1 | RO   |                    | 3'b011: reads 8 bytes per beat                               |
| 5.1 |      |                    | 3'b100: reads 16 bytes per beat                              |
|     |      |                    | 3'b101-3'b111: reserved                                      |
|     |      |                    | The total number of bytes that the DMAC reads into the MFIFO |
|     |      |                    | when it executes a DMALD instruction is the product of       |
|     |      |                    | src_burst_len and src_burst_size.                            |
|     |      |                    | src_inc                                                      |
| 0   | RO   | 0×0                | 1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.  |
|     |      |                    | 1'b1: Incrementing-address burst. The DMAC signals           |
|     |      |                    | ARBURST[0] HIGH.                                             |

Address: Operational Base + offset (0x040c)

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:8 | RO   | 0x0                | reserved                  |
| 7:0  | RO   | 0x00               | loop_counter_iterations   |
| 7.0  | κυ   | 0,00               | Loop counter 0 iterations |

### DMA\_LC1\_0

Address: Operational Base + offset (0x0410)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                             |
| 7:0  | RO   | 0x00               | loop_counter_iterations<br>Loop counter 1 iterations |

# DMA SAR1

# Address: Operational Base + offset (0x0420)

| Bit  | Attr | <b>Reset Value</b>         | Description                                              |
|------|------|----------------------------|----------------------------------------------------------|
| 31:0 | RO   | $0 \times 0 0 0 0 0 0 0 0$ | src_addr<br>Address of the source data for DMA channel 1 |

### DMA DAR1

Address: Operational Base + offset (0x0424)

| Bit  | Attr | <b>Reset Value</b>         | Description                                                  |
|------|------|----------------------------|--------------------------------------------------------------|
| 31:0 | RO   | $0 \times 0 0 0 0 0 0 0 0$ | dst_addr<br>Address of the Destinationdata for DMA channel 1 |

# DMA CCR1

Address: Operational Base + offset (0x0428)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                      |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                         |
| 27:25 | RO   | 0×0                | dst_cache_ctrl<br>Bit [27]<br>1'b0: AWCACHE[3] is LOW<br>1'b1: AWCACHE[3] is HIGH<br>Bit [26]<br>1'b0: AWCACHE[1] is LOW<br>1'b1: AWCACHE[1] is HIGH<br>Bit [25]<br>1'b0: AWCACHE[0] is LOW<br>1'b1: AWCACHE[0] is HIGH                                                                                                          |
| 24:22 | RO   | 0×0                | dst_prot_ctrl<br>Bit [24]<br>1'b0: AWPROT[2] is LOW<br>1'b1: AWPROT[2] is HIGH<br>Bit [23]<br>1'b0: AWPROT[1] is LOW<br>1'b1: AWPROT[1] is HIGH<br>Bit [22]<br>1'b0: AWPROT[0] is LOW<br>1'b1: AWPROT[0] is HIGH                                                                                                                 |
| 21:18 | RO   | 0×0                | dst_burst_len<br>the destination data:<br>4'b0000: 1 data transfer<br>4'b0001: 2 data transfers<br>4'b0010: 3 data transfers<br><br>4'b1111: 16 data transfers<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size. |

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:15 | RO   | 0×0                | dst_burst_size<br>3'b000: writes 1 byte per beat<br>3'b001: writes 2 bytes per beat<br>3'b010: writes 4 bytes per beat<br>3'b011: writes 8 bytes per beat<br>3'b100: writes 16 bytes per beat<br>3'b101-3'b111: reserved<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size. |
| 14    | RO   | 0×0                | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>AWBURST[0] HIGH.                                                                                                                                                                                                                                           |
| 13:11 | RO   | 0×0                | src_cache_ctrl<br>Bit [13]<br>1'b0: ARCACHE[2] is LOW<br>1'b1: ARCACHE[2] is HIGH<br>Bit [12]<br>1'b0: ARCACHE[1] is LOW<br>1'b1: ARCACHE[1] is HIGH<br>Bit [11]<br>1'b0: ARCACHE[0] is LOW<br>1'b1: ARCACHE[0] is HIGH                                                                                                                                                                    |
| 10:8  | RO   | 0×0                | src_prot_ctrl<br>Bit [10]<br>1'b0: ARPROT[2] is LOW<br>1'b1: ARPROT[2] is HIGH<br>Bit [9]<br>1'b0: ARPROT[1] is LOW<br>1'b1: ARPROT[1] is HIGH<br>Bit [8]<br>1'b0: ARPROT[0] is LOW<br>1'b1: ARPROT[0] is HIGH                                                                                                                                                                             |
| 7:4   | RO   | 0×0                | <pre>src_burst_len 4'b0000: 1 data transfer 4'b0001: 2 data transfers 4'b0010: 3 data transfers 4'b1111: 16 data transfers The total number of bytes that the DMAC reads into the MFIFO when it executes a DMALD instruction is the product of src_burst_len and src_burst_size.</pre>                                                                                                     |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                        |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1 | RO   | 0×0                | <pre>src_burst_size 3'b000: reads 1 byte per beat 3'b001: reads 2 bytes per beat 3'b010: reads 4 bytes per beat 3'b011: reads 8 bytes per beat 3'b100: reads 16 bytes per beat 3'b101-3'b111: reserved The total number of bytes that the DMAC reads into the MFIFO when it executes a DMALD instruction is the product of src_burst_len and src_burst_size.</pre> |
| 0   | RO   | 0×0                | src_inc<br>1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>ARBURST[0] HIGH.                                                                                                                                                                                                                   |

Address: Operational Base + offset (0x042c)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                             |
| 7:0  | RO   | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

### DMA\_LC1\_1

Address: Operational Base + offset (0x0430)

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:8 | RO   | 0x0                | reserved                  |
| 7:0  | RO   | )  0x00            | loop_counter_iterations   |
| 7:0  |      |                    | Loop counter 1 iterations |

# DMA\_SAR2

Address: Operational Base + offset (0x0440)

| Bit  | Attr | <b>Reset Value</b>         | Description                                              |
|------|------|----------------------------|----------------------------------------------------------|
| 31:0 | RO   | $0 \times 0 0 0 0 0 0 0 0$ | src_addr<br>Address of the source data for DMA channel 2 |

# DMA\_DAR2

Address: Operational Base + offset (0x0444)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
| 31:0 | RO   | 0_00000000         | dst_addr<br>Address of the Destinationdata for DMA channel 2 |

### DMA\_CCR2

Address: Operational Base + offset (0x0448)

| Bit   | Attr | Reset Value | Description                                                                                                       |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                                                                                          |
|       |      |             | dst cache ctrl                                                                                                    |
|       |      |             | <br>Bit [27]                                                                                                      |
|       |      |             | 1'b0: AWCACHE[3] is LOW                                                                                           |
|       |      |             | 1'b1: AWCACHE[3] is HIGH                                                                                          |
|       |      |             | Bit [26]                                                                                                          |
| 27:25 | RO   | 0x0         | 1'b0: AWCACHE[1] is LOW                                                                                           |
|       |      |             | 1'b1: AWCACHE[1] is HIGH                                                                                          |
|       |      |             | Bit [25]                                                                                                          |
|       |      |             | 1'b0: AWCACHE[0] is LOW                                                                                           |
|       |      |             | 1'b1: AWCACHE[0] is HIGH                                                                                          |
|       |      |             | dst_prot_ctrl                                                                                                     |
|       |      |             | Bit [24]                                                                                                          |
|       |      |             | 1'b0: AWPROT[2] is LOW                                                                                            |
|       |      |             | 1'b1: AWPROT[2] is HIGH                                                                                           |
| 24.22 |      | 00          | Bit [23]                                                                                                          |
| 24:22 | RO   | 0x0         | 1'b0: AWPROT[1] is LOW                                                                                            |
|       |      |             | 1'b1: AWPROT[1] is HIGH                                                                                           |
|       |      |             | Bit [22]                                                                                                          |
|       |      |             | 1'b0: AWPROT[0] is LOW                                                                                            |
|       |      |             | 1'b1: AWPROT[0] is HIGH                                                                                           |
|       |      |             | dst_burst_len                                                                                                     |
|       |      |             | the destination data:                                                                                             |
|       |      |             | 4'b0000: 1 data transfer                                                                                          |
|       |      |             | 4'b0001: 2 data transfers                                                                                         |
| 21:18 | RO   | 0x0         | 4'b0010: 3 data transfers                                                                                         |
| 21110 | i co | 0,00        |                                                                                                                   |
|       |      |             | 4'b1111: 16 data transfers                                                                                        |
|       |      |             | The total number of bytes that the DMAC writes out of the MFIFO                                                   |
|       |      |             | when it executes a DMAST instruction is the product of                                                            |
|       |      |             | dst_burst_len and dst_burst_size.                                                                                 |
|       |      |             | dst_burst_size                                                                                                    |
|       |      |             | 3'b000: writes 1 byte per beat                                                                                    |
|       |      |             | 3'b001: writes 2 bytes per beat                                                                                   |
|       |      |             | 3'b010: writes 4 bytes per beat                                                                                   |
| 17:15 | RO   | 0x0         | 3'b011: writes 8 bytes per beat                                                                                   |
|       |      |             | 3'b100: writes 16 bytes per beat                                                                                  |
|       |      |             | 3'b101-3'b111: reserved                                                                                           |
|       |      |             | The total number of bytes that the DMAC writes out of the MFIFO                                                   |
|       |      |             | when it executes a DMAST instruction is the product of                                                            |
|       |      |             | dst_burst_len and dst_burst_size.                                                                                 |
|       |      |             | dst_inc                                                                                                           |
| 14    | RO   | 0x0         | 1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals |
|       |      |             |                                                                                                                   |
|       |      |             | AWBURST[0] HIGH.                                                                                                  |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:11 | RO   | 0×0         | src_cache_ctrl<br>Bit [13]<br>1'b0: ARCACHE[2] is LOW<br>1'b1: ARCACHE[2] is HIGH<br>Bit [12]<br>1'b0: ARCACHE[1] is LOW<br>1'b1: ARCACHE[1] is HIGH<br>Bit [11]<br>1'b0: ARCACHE[0] is LOW<br>1'b1: ARCACHE[0] is HIGH                                                                                                                                                            |
| 10:8  | RO   | 0×0         | src_prot_ctrl<br>Bit [10]<br>1'b0: ARPROT[2] is LOW<br>1'b1: ARPROT[2] is HIGH<br>Bit [9]<br>1'b0: ARPROT[1] is LOW<br>1'b1: ARPROT[1] is HIGH<br>Bit [8]<br>1'b0: ARPROT[0] is LOW<br>1'b1: ARPROT[0] is HIGH                                                                                                                                                                     |
| 7:4   | RO   | 0×0         | <pre>src_burst_len 4'b0000: 1 data transfer 4'b0001: 2 data transfers 4'b0010: 3 data transfers 4'b1111: 16 data transfers The total number of bytes that the DMAC reads into the MFIFO when it executes a DMALD instruction is the product of src_burst_len and src_burst_size.</pre>                                                                                             |
| 3:1   | RO   | 0×0         | src_burst_size<br>3'b000: reads 1 byte per beat<br>3'b001: reads 2 bytes per beat<br>3'b010: reads 4 bytes per beat<br>3'b011: reads 8 bytes per beat<br>3'b100: reads 16 bytes per beat<br>3'b101-3'b111: reserved<br>The total number of bytes that the DMAC reads into the MFIFO<br>when it executes a DMALD instruction is the product of<br>src_burst_len and src_burst_size. |
| 0     | RO   | 0×0         | src_inc<br>1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>ARBURST[0] HIGH.                                                                                                                                                                                                                                   |

# DMA LC0 2

## RK3308 TRM-Part1

### Address: Operational Base + offset (0x044c)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                             |
| 7:0  | RO   | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

## DMA\_LC1\_2

Address: Operational Base + offset (0x0450)

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:8 | RO   | 0x0                | reserved                  |
| 7:0  | RO   | O 0x00             | loop_counter_iterations   |
| 7:0  |      |                    | Loop counter 1 iterations |

### DMA SAR3

Address: Operational Base + offset (0x0460)

| Bit  | Attr | <b>Reset Value</b> | Description                                              |
|------|------|--------------------|----------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | src_addr<br>Address of the source data for DMA channel 3 |

### DMA DAR3

Address: Operational Base + offset (0x0464)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | dst_addr<br>Address of the Destinationdata for DMA channel 3 |

### DMA\_CCR3

Address: Operational Base + offset (0x0468)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                             |
|-------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0                | reserved                                                                                                                                                                                                                |
| 27:25 | RO   | 0×0                | dst_cache_ctrl<br>Bit [27]<br>1'b0: AWCACHE[3] is LOW<br>1'b1: AWCACHE[3] is HIGH<br>Bit [26]<br>1'b0: AWCACHE[1] is LOW<br>1'b1: AWCACHE[1] is HIGH<br>Bit [25]<br>1'b0: AWCACHE[0] is LOW<br>1'b1: AWCACHE[0] is HIGH |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:22 | RO   | 0×0         | dst_prot_ctrl<br>Bit [24]<br>1'b0: AWPROT[2] is LOW<br>1'b1: AWPROT[2] is HIGH<br>Bit [23]<br>1'b0: AWPROT[1] is LOW<br>1'b1: AWPROT[1] is HIGH<br>Bit [22]<br>1'b0: AWPROT[0] is LOW<br>1'b1: AWPROT[0] is HIGH                                                                                                                                                                           |
| 21:18 | RO   | 0×0         | dst_burst_len<br>the destination data:<br>4'b0000: 1 data transfer<br>4'b0001: 2 data transfers<br>4'b0010: 3 data transfers<br><br>4'b1111: 16 data transfers<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size.                                                           |
| 17:15 | RO   | 0×0         | dst_burst_size<br>3'b000: writes 1 byte per beat<br>3'b001: writes 2 bytes per beat<br>3'b010: writes 4 bytes per beat<br>3'b011: writes 8 bytes per beat<br>3'b100: writes 16 bytes per beat<br>3'b101-3'b111: reserved<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size. |
| 14    | RO   | 0×0         | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>AWBURST[0] HIGH.                                                                                                                                                                                                                                           |
| 13:11 | RO   | 0×0         | src_cache_ctrl<br>Bit [13]<br>1'b0: ARCACHE[2] is LOW<br>1'b1: ARCACHE[2] is HIGH<br>Bit [12]<br>1'b0: ARCACHE[1] is LOW<br>1'b1: ARCACHE[1] is HIGH<br>Bit [11]<br>1'b0: ARCACHE[0] is LOW<br>1'b1: ARCACHE[0] is HIGH                                                                                                                                                                    |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                        |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8 | RO   | 0×0         | src_prot_ctrl<br>Bit [10]<br>1'b0: ARPROT[2] is LOW<br>1'b1: ARPROT[2] is HIGH<br>Bit [9]<br>1'b0: ARPROT[1] is LOW<br>1'b1: ARPROT[1] is HIGH<br>Bit [8]<br>1'b0: ARPROT[0] is LOW<br>1'b1: ARPROT[0] is HIGH                                                                                                                                                                     |
| 7:4  | RO   | 0×0         | <pre>src_burst_len 4'b0000: 1 data transfer 4'b0001: 2 data transfers 4'b0010: 3 data transfers 4'b1111: 16 data transfers The total number of bytes that the DMAC reads into the MFIFO when it executes a DMALD instruction is the product of src_burst_len and src_burst_size.</pre>                                                                                             |
| 3:1  | RO   | 0×0         | src_burst_size<br>3'b000: reads 1 byte per beat<br>3'b001: reads 2 bytes per beat<br>3'b010: reads 4 bytes per beat<br>3'b011: reads 8 bytes per beat<br>3'b100: reads 16 bytes per beat<br>3'b101-3'b111: reserved<br>The total number of bytes that the DMAC reads into the MFIFO<br>when it executes a DMALD instruction is the product of<br>src_burst_len and src_burst_size. |
| 0    | RO   | 0×0         | src_inc<br>1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>ARBURST[0] HIGH.                                                                                                                                                                                                                                   |

Address: Operational Base + offset (0x046c)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                             |
| 7:0  | RO   | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

# DMA LC1 3

Address: Operational Base + offset (0x0470)

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:8 | RO   | 0x0                | reserved                  |
| 7:0  | RO   | 0x00               | loop_counter_iterations   |
| 7:0  |      |                    | Loop counter 1 iterations |

# DMA SAR4

Address: Operational Base + offset (0x0480)

| Bit  | Attr | <b>Reset Value</b> | Description                                              |
|------|------|--------------------|----------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | src_addr<br>Address of the source data for DMA channel 4 |

# DMA DAR4

Address: Operational Base + offset (0x0484)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
| 31:0 | RO   | 0×00000000         | dst_addr<br>Address of the Destinationdata for DMA channel 4 |

### DMA\_CCR4

Address: Operational Base + offset (0x0488)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                             |
|-------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0                | reserved                                                                                                                                                                                                                |
| 27:25 | RO   | 0×0                | dst_cache_ctrl<br>Bit [27]<br>1'b0: AWCACHE[3] is LOW<br>1'b1: AWCACHE[3] is HIGH<br>Bit [26]<br>1'b0: AWCACHE[1] is LOW<br>1'b1: AWCACHE[1] is HIGH<br>Bit [25]<br>1'b0: AWCACHE[0] is LOW<br>1'b1: AWCACHE[0] is HIGH |
| 24:22 | RO   | 0x0                | dst_prot_ctrl<br>Bit [24]<br>1'b0: AWPROT[2] is LOW<br>1'b1: AWPROT[2] is HIGH<br>Bit [23]<br>1'b0: AWPROT[1] is LOW<br>1'b1: AWPROT[1] is HIGH<br>Bit [22]<br>1'b0: AWPROT[0] is LOW<br>1'b1: AWPROT[0] is HIGH        |

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:18 | RO   | 0×0                | dst_burst_len<br>the destination data:<br>4'b0000: 1 data transfer<br>4'b0001: 2 data transfers<br>4'b0010: 3 data transfers<br><br>4'b1111: 16 data transfers<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size.                                                           |
| 17:15 | RO   | 0×0                | dst_burst_size<br>3'b000: writes 1 byte per beat<br>3'b001: writes 2 bytes per beat<br>3'b010: writes 4 bytes per beat<br>3'b011: writes 8 bytes per beat<br>3'b100: writes 16 bytes per beat<br>3'b101-3'b111: reserved<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size. |
| 14    | RO   | 0×0                | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>AWBURST[0] HIGH.                                                                                                                                                                                                                                           |
| 13:11 | RO   | 0×0                | src_cache_ctrl<br>Bit [13]<br>1'b0: ARCACHE[2] is LOW<br>1'b1: ARCACHE[2] is HIGH<br>Bit [12]<br>1'b0: ARCACHE[1] is LOW<br>1'b1: ARCACHE[1] is HIGH<br>Bit [11]<br>1'b0: ARCACHE[0] is LOW<br>1'b1: ARCACHE[0] is HIGH                                                                                                                                                                    |
| 10:8  | RO   | 0×0                | src_prot_ctrl<br>Bit [10]<br>1'b0: ARPROT[2] is LOW<br>1'b1: ARPROT[2] is HIGH<br>Bit [9]<br>1'b0: ARPROT[1] is LOW<br>1'b1: ARPROT[1] is HIGH<br>Bit [8]<br>1'b0: ARPROT[0] is LOW<br>1'b1: ARPROT[0] is HIGH                                                                                                                                                                             |

| Bit | Attr | <b>Reset Value</b> | Description                                                  |
|-----|------|--------------------|--------------------------------------------------------------|
|     |      |                    | src_burst_len                                                |
|     |      |                    | 4'b0000: 1 data transfer                                     |
|     |      |                    | 4'b0001: 2 data transfers                                    |
|     |      |                    | 4'b0010: 3 data transfers                                    |
| 7:4 | RO   | 0x0                |                                                              |
|     |      |                    | 4'b1111: 16 data transfers                                   |
|     |      |                    | The total number of bytes that the DMAC reads into the MFIFO |
|     |      |                    | when it executes a DMALD instruction is the product of       |
|     |      |                    | src_burst_len and src_burst_size.                            |
|     |      | D 0x0              | src_burst_size                                               |
|     |      |                    | 3'b000: reads 1 byte per beat                                |
|     |      |                    | 3'b001: reads 2 bytes per beat                               |
|     |      |                    | 3'b010: reads 4 bytes per beat                               |
| 3:1 | RO   |                    | 3'b011: reads 8 bytes per beat                               |
| 511 |      |                    | 3'b100: reads 16 bytes per beat                              |
|     |      |                    | 3'b101-3'b111: reserved                                      |
|     |      |                    | The total number of bytes that the DMAC reads into the MFIFO |
|     |      |                    | when it executes a DMALD instruction is the product of       |
|     |      |                    | src_burst_len and src_burst_size.                            |
|     |      |                    | src_inc                                                      |
| 0   | RO   | RO 0x0             | 1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.  |
| -   |      |                    | 1'b1: Incrementing-address burst. The DMAC signals           |
|     |      |                    | ARBURST[0] HIGH.                                             |

Address: Operational Base + offset (0x048c)

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:8 | RO   | 0x0                | reserved                  |
| 7:0  | RO   | 0x00               | loop_counter_iterations   |
| 7.0  | κυ   | 0,00               | Loop counter 0 iterations |

### <u>DMA\_LC1\_4</u>

Address: Operational Base + offset (0x0490)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                             |
| 7:0  | RO   | 0x00               | loop_counter_iterations<br>Loop counter 1 iterations |

# DMA SAR5

# Address: Operational Base + offset (0x04a0)

| Bit  | Attr | <b>Reset Value</b> | Description                                              |
|------|------|--------------------|----------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | src_addr<br>Address of the source data for DMA channel 5 |

### DMA DAR5

Address: Operational Base + offset (0x04a4)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
| 31:0 | RO   | 0~0000000          | dst_addr<br>Address of the Destinationdata for DMA channel 5 |

# DMA CCR5

Address: Operational Base + offset (0x04a8)

|       |    | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                      |
|-------|----|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO | 0x0                | reserved                                                                                                                                                                                                                                                                                                                         |
| 27:25 | RO | 0×0                | dst_cache_ctrl<br>Bit [27]<br>1'b0: AWCACHE[3] is LOW<br>1'b1: AWCACHE[3] is HIGH<br>Bit [26]<br>1'b0: AWCACHE[1] is LOW<br>1'b1: AWCACHE[1] is HIGH<br>Bit [25]<br>1'b0: AWCACHE[0] is LOW<br>1'b1: AWCACHE[0] is HIGH                                                                                                          |
| 24:22 | RO | 0×0                | dst_prot_ctrl<br>Bit [24]<br>1'b0: AWPROT[2] is LOW<br>1'b1: AWPROT[2] is HIGH<br>Bit [23]<br>1'b0: AWPROT[1] is LOW<br>1'b1: AWPROT[1] is HIGH<br>Bit [22]<br>1'b0: AWPROT[0] is LOW<br>1'b1: AWPROT[0] is HIGH                                                                                                                 |
| 21:18 | RO | 0×0                | dst_burst_len<br>the destination data:<br>4'b0000: 1 data transfer<br>4'b0001: 2 data transfers<br>4'b0010: 3 data transfers<br><br>4'b1111: 16 data transfers<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size. |

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:15 | RO   | 0×0                | dst_burst_size<br>3'b000: writes 1 byte per beat<br>3'b001: writes 2 bytes per beat<br>3'b010: writes 4 bytes per beat<br>3'b011: writes 8 bytes per beat<br>3'b100: writes 16 bytes per beat<br>3'b101-3'b111: reserved<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size. |
| 14    | RO   | 0×0                | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>AWBURST[0] HIGH.                                                                                                                                                                                                                                           |
| 13:11 | RO   | 0×0                | src_cache_ctrl<br>Bit [13]<br>1'b0: ARCACHE[2] is LOW<br>1'b1: ARCACHE[2] is HIGH<br>Bit [12]<br>1'b0: ARCACHE[1] is LOW<br>1'b1: ARCACHE[1] is HIGH<br>Bit [11]<br>1'b0: ARCACHE[0] is LOW<br>1'b1: ARCACHE[0] is HIGH                                                                                                                                                                    |
| 10:8  | RO   | 0×0                | src_prot_ctrl<br>Bit [10]<br>1'b0: ARPROT[2] is LOW<br>1'b1: ARPROT[2] is HIGH<br>Bit [9]<br>1'b0: ARPROT[1] is LOW<br>1'b1: ARPROT[1] is HIGH<br>Bit [8]<br>1'b0: ARPROT[0] is LOW<br>1'b1: ARPROT[0] is HIGH                                                                                                                                                                             |
| 7:4   | RO   | 0×0                | <pre>src_burst_len 4'b0000: 1 data transfer 4'b0001: 2 data transfers 4'b0010: 3 data transfers 4'b1111: 16 data transfers The total number of bytes that the DMAC reads into the MFIFO when it executes a DMALD instruction is the product of src_burst_len and src_burst_size.</pre>                                                                                                     |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                        |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1 | RO   | 0×0                | <pre>src_burst_size 3'b000: reads 1 byte per beat 3'b001: reads 2 bytes per beat 3'b010: reads 4 bytes per beat 3'b011: reads 8 bytes per beat 3'b100: reads 16 bytes per beat 3'b101-3'b111: reserved The total number of bytes that the DMAC reads into the MFIFO when it executes a DMALD instruction is the product of src_burst_len and src_burst_size.</pre> |
| 0   | RO   | 0×0                | src_inc<br>1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>ARBURST[0] HIGH.                                                                                                                                                                                                                   |

Address: Operational Base + offset (0x04ac)

| Bit  | Attr | <b>Reset Value</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Description               |
|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| 31:8 | RO   | 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | reserved                  |
| 7:0  | RO   | $()   () \times () ()   () \times () () \times () ()   () \times () () \times () () \times () ()   () \times () () \times () () \times () ()   () \times () () \times () () \times () ()   () \times () () \times () () \times () ()   () \times () () \times () () \times () () \times () () () \times () () () \times () () \times () () \times () () () \times () () () () () \times () () () () () () () () () () () () () $ | loop_counter_iterations   |
|      |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Loop counter 0 iterations |

### DMA\_LC1\_5

Address: Operational Base + offset (0x04b0)

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:8 | RO   | 0x0                | reserved                  |
| 7:0  | RO   | 0x00               | loop_counter_iterations   |
| 7:0  |      |                    | Loop counter 1 iterations |

### DMA\_SAR6

Address: Operational Base + offset (0x04c0)

| Bit  | Attr | <b>Reset Value</b>         | Description                                              |
|------|------|----------------------------|----------------------------------------------------------|
| 31:0 | RO   | $0 \times 0 0 0 0 0 0 0 0$ | src_addr<br>Address of the source data for DMA channel 6 |

# DMA\_DAR6

Address: Operational Base + offset (0x04c4)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
| 31:0 | RO   | 0_00000000         | dst_addr<br>Address of the Destinationdata for DMA channel 6 |

### DMA\_CCR6

Address: Operational Base + offset (0x04c8)

| Bit   | Attr | Reset Value | Description                                                                                                       |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------|
| 31:28 |      | 0x0         | reserved                                                                                                          |
| 01120 |      |             | dst_cache_ctrl                                                                                                    |
|       |      |             | Bit [27]                                                                                                          |
|       |      |             | 1'b0: AWCACHE[3] is LOW                                                                                           |
|       |      |             | 1'b1: AWCACHE[3] is HIGH                                                                                          |
|       |      |             | Bit [26]                                                                                                          |
| 27:25 | RO   | 0x0         | 1'b0: AWCACHE[1] is LOW                                                                                           |
|       |      |             | 1'b1: AWCACHE[1] is HIGH                                                                                          |
|       |      |             | Bit [25]                                                                                                          |
|       |      |             | 1'b0: AWCACHE[0] is LOW                                                                                           |
|       |      |             | 1'b1: AWCACHE[0] is HIGH                                                                                          |
|       |      |             | dst_prot_ctrl                                                                                                     |
|       |      |             | Bit [24]                                                                                                          |
|       |      |             | 1'b0: AWPROT[2] is LOW                                                                                            |
|       |      |             | 1'b1: AWPROT[2] is HIGH                                                                                           |
|       |      |             | Bit [23]                                                                                                          |
| 24:22 | RO   | 0x0         | 1'b0: AWPROT[1] is LOW                                                                                            |
|       |      |             | 1'b1: AWPROT[1] is HIGH                                                                                           |
|       |      |             | Bit [22]                                                                                                          |
|       |      |             | 1'b0: AWPROT[0] is LOW                                                                                            |
|       |      |             | 1'b1: AWPROT[0] is HIGH                                                                                           |
|       |      |             | dst_burst_len                                                                                                     |
|       |      |             | the destination data:                                                                                             |
|       |      |             | 4'b0000: 1 data transfer                                                                                          |
|       |      |             | 4'b0001: 2 data transfers                                                                                         |
| 21:18 | ÞO   | 0x0         | 4'b0010: 3 data transfers                                                                                         |
| 21.10 | κο   | 0.00        |                                                                                                                   |
|       |      |             | 4'b1111: 16 data transfers                                                                                        |
|       |      |             | The total number of bytes that the DMAC writes out of the MFIFO                                                   |
|       |      |             | when it executes a DMAST instruction is the product of                                                            |
|       |      |             | dst_burst_len and dst_burst_size.                                                                                 |
|       |      |             | dst_burst_size                                                                                                    |
|       |      |             | 3'b000: writes 1 byte per beat                                                                                    |
|       |      |             | 3'b001: writes 2 bytes per beat                                                                                   |
|       |      |             | 3'b010: writes 4 bytes per beat                                                                                   |
| 17:15 | RO   | 0x0         | 3'b011: writes 8 bytes per beat                                                                                   |
|       |      |             | 3'b100: writes 16 bytes per beat                                                                                  |
|       |      |             | 3'b101-3'b111: reserved                                                                                           |
|       |      |             | The total number of bytes that the DMAC writes out of the MFIFO                                                   |
|       |      |             | when it executes a DMAST instruction is the product of                                                            |
|       |      |             | dst_burst_len and dst_burst_size.                                                                                 |
|       |      |             | dst_inc                                                                                                           |
| 14    | RO   | 0x0         | 1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals |
|       |      |             |                                                                                                                   |
|       |      |             | AWBURST[0] HIGH.                                                                                                  |

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:11 | RO   | 0×0                | src_cache_ctrl<br>Bit [13]<br>1'b0: ARCACHE[2] is LOW<br>1'b1: ARCACHE[2] is HIGH<br>Bit [12]<br>1'b0: ARCACHE[1] is LOW<br>1'b1: ARCACHE[1] is HIGH<br>Bit [11]<br>1'b0: ARCACHE[0] is LOW<br>1'b1: ARCACHE[0] is HIGH                                                                                                                                                            |
| 10:8  | RO   | 0×0                | src_prot_ctrl<br>Bit [10]<br>1'b0: ARPROT[2] is LOW<br>1'b1: ARPROT[2] is HIGH<br>Bit [9]<br>1'b0: ARPROT[1] is LOW<br>1'b1: ARPROT[1] is HIGH<br>Bit [8]<br>1'b0: ARPROT[0] is LOW<br>1'b1: ARPROT[0] is HIGH                                                                                                                                                                     |
| 7:4   | RO   | 0×0                | <pre>src_burst_len 4'b0000: 1 data transfer 4'b0001: 2 data transfers 4'b0010: 3 data transfers 4'b1111: 16 data transfers The total number of bytes that the DMAC reads into the MFIFO when it executes a DMALD instruction is the product of src_burst_len and src_burst_size.</pre>                                                                                             |
| 3:1   | RO   | 0×0                | src_burst_size<br>3'b000: reads 1 byte per beat<br>3'b001: reads 2 bytes per beat<br>3'b010: reads 4 bytes per beat<br>3'b011: reads 8 bytes per beat<br>3'b100: reads 16 bytes per beat<br>3'b101-3'b111: reserved<br>The total number of bytes that the DMAC reads into the MFIFO<br>when it executes a DMALD instruction is the product of<br>src_burst_len and src_burst_size. |
| 0     | RO   | 0x0                | src_inc<br>1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>ARBURST[0] HIGH.                                                                                                                                                                                                                                   |

## RK3308 TRM-Part1

### Address: Operational Base + offset (0x04cc)

| Attr | <b>Reset Value</b> | Description                                          |
|------|--------------------|------------------------------------------------------|
| RO   | 0x0                | reserved                                             |
| RO   | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |
|      | RO                 | RO 0x00                                              |

## DMA\_LC1\_6

Address: Operational Base + offset (0x04d0)

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:8 | RO   | 0x0                | reserved                  |
| 7:0  | RO   | 0x00               | loop_counter_iterations   |
| 7.0  |      | 0,00               | Loop counter 1 iterations |

# DMA SAR7

Address: Operational Base + offset (0x04e0)

| Bit  | Attr | <b>Reset Value</b> | Description                                              |
|------|------|--------------------|----------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | src_addr<br>Address of the source data for DMA channel 7 |

### DMA DAR7

Address: Operational Base + offset (0x04e4)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | dst_addr<br>Address of the Destinationdata for DMA channel 7 |

### DMA\_CCR7

Address: Operational Base + offset (0x04e8)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                             |
|-------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0                | reserved                                                                                                                                                                                                                |
| 27:25 | RO   | 0×0                | dst_cache_ctrl<br>Bit [27]<br>1'b0: AWCACHE[3] is LOW<br>1'b1: AWCACHE[3] is HIGH<br>Bit [26]<br>1'b0: AWCACHE[1] is LOW<br>1'b1: AWCACHE[1] is HIGH<br>Bit [25]<br>1'b0: AWCACHE[0] is LOW<br>1'b1: AWCACHE[0] is HIGH |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:22 | RO   | 0×0         | dst_prot_ctrl<br>Bit [24]<br>1'b0: AWPROT[2] is LOW<br>1'b1: AWPROT[2] is HIGH<br>Bit [23]<br>1'b0: AWPROT[1] is LOW<br>1'b1: AWPROT[1] is HIGH<br>Bit [22]<br>1'b0: AWPROT[0] is LOW<br>1'b1: AWPROT[0] is HIGH                                                                                                                                                                           |
| 21:18 | RO   | 0×0         | dst_burst_len<br>the destination data:<br>4'b0000: 1 data transfer<br>4'b0001: 2 data transfers<br>4'b0010: 3 data transfers<br><br>4'b1111: 16 data transfers<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size.                                                           |
| 17:15 | RO   | 0×0         | dst_burst_size<br>3'b000: writes 1 byte per beat<br>3'b001: writes 2 bytes per beat<br>3'b010: writes 4 bytes per beat<br>3'b011: writes 8 bytes per beat<br>3'b100: writes 16 bytes per beat<br>3'b101-3'b111: reserved<br>The total number of bytes that the DMAC writes out of the MFIFO<br>when it executes a DMAST instruction is the product of<br>dst_burst_len and dst_burst_size. |
| 14    | RO   | 0×0         | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>AWBURST[0] HIGH.                                                                                                                                                                                                                                           |
| 13:11 | RO   | 0×0         | src_cache_ctrl<br>Bit [13]<br>1'b0: ARCACHE[2] is LOW<br>1'b1: ARCACHE[2] is HIGH<br>Bit [12]<br>1'b0: ARCACHE[1] is LOW<br>1'b1: ARCACHE[1] is HIGH<br>Bit [11]<br>1'b0: ARCACHE[0] is LOW<br>1'b1: ARCACHE[0] is HIGH                                                                                                                                                                    |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                        |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8 | RO   | 0×0         | src_prot_ctrl<br>Bit [10]<br>1'b0: ARPROT[2] is LOW<br>1'b1: ARPROT[2] is HIGH<br>Bit [9]<br>1'b0: ARPROT[1] is LOW<br>1'b1: ARPROT[1] is HIGH<br>Bit [8]<br>1'b0: ARPROT[0] is LOW<br>1'b1: ARPROT[0] is HIGH                                                                                                                                                                     |
| 7:4  | RO   | 0×0         | <pre>src_burst_len 4'b0000: 1 data transfer 4'b0001: 2 data transfers 4'b0010: 3 data transfers 4'b1111: 16 data transfers The total number of bytes that the DMAC reads into the MFIFO when it executes a DMALD instruction is the product of src_burst_len and src_burst_size.</pre>                                                                                             |
| 3:1  | RO   | 0×0         | src_burst_size<br>3'b000: reads 1 byte per beat<br>3'b001: reads 2 bytes per beat<br>3'b010: reads 4 bytes per beat<br>3'b011: reads 8 bytes per beat<br>3'b100: reads 16 bytes per beat<br>3'b101-3'b111: reserved<br>The total number of bytes that the DMAC reads into the MFIFO<br>when it executes a DMALD instruction is the product of<br>src_burst_len and src_burst_size. |
| 0    | RO   | 0×0         | src_inc<br>1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals<br>ARBURST[0] HIGH.                                                                                                                                                                                                                                   |

**DMA\_LC0\_7** Address: Operational Base + offset (0x04ec)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                             |
| 7:0  | RO   | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

# DMA LC1 7

Address: Operational Base + offset (0x04f0)

### RK3308 TRM-Part1

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:8 | RO   | 0x0                | reserved                  |
| 7:0  |      | 10x00              | loop_counter_iterations   |
| 7:0  | RO   |                    | Loop counter 1 iterations |

### DMA DBGSTATUS

Address: Operational Base + offset (0x0d00)

| Bit  | Attr | <b>Reset Value</b> | Description |
|------|------|--------------------|-------------|
| 31:1 | RO   | 0x0                | reserved    |
|      |      |                    | dbgstatus   |
| 0    | RO   | 0x0                | 1'b0: idle  |
|      |      |                    | 1'b1: busy  |

### DMA\_DBGCMD

Address: Operational Base + offset (0x0d04)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                   |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x0                | reserved                                                                                                                                      |
| 1:0  | wo   | 0x0                | dbgcmd<br>2'b00: execute the instruction that the DBGINST [1:0] Registers<br>contain<br>2'b01: reserved<br>2'b10: reserved<br>2'b11: reserved |

# DMA DBGINSTO

Address: Operational Base + offset (0x0d08)

| Bit   | Attr | <b>Reset Value</b> | Description              |
|-------|------|--------------------|--------------------------|
| 31:24 | wo   | 0x00               | instruction_byte1        |
| 51.21 |      | 0,00               | Instruction byte 1       |
| 23:16 | wo   | 0x00               | instruction_byte0        |
| 25.10 | vvO  | 0,00               | Instruction byte 0       |
| 15:11 | RO   | 0x0                | reserved                 |
|       |      | 0×0                | channel_number           |
|       |      |                    | 3'b000: DMA channel 0    |
| 10:8  | wo   |                    | 3'b001: DMA channel 1    |
| 10.8  | WU   |                    | 3'b010: DMA channel 2    |
|       |      |                    |                          |
|       |      |                    | 3'b111: DMA channel 7    |
| 7:1   | RO   | 0x0                | reserved                 |
|       |      |                    | debug_thread             |
| 0     | WO   | 0x0                | 1'b0: DMA manager thread |
|       |      |                    | 1'b1: DMA channel        |

### DMA\_DBGINST1

Address: Operational Base + offset (0x0d0c)

| Bit   | Attr | <b>Reset Value</b>  | Description        |      |                    |
|-------|------|---------------------|--------------------|------|--------------------|
| 21.24 | WO   | 0 0 00              | instruction_byte5  |      |                    |
| 31:24 | WU   | 0x00                | Instruction byte 5 |      |                    |
| 22.10 | wo   | $NO = O \times O O$ | instruction_byte4  |      |                    |
| 23:16 | WÜ   |                     | Instruction byte 4 |      |                    |
| 1     | wo   | /O  0x00            | instruction_byte3  |      |                    |
| 15:8  | WÜ   |                     | Instruction byte 3 |      |                    |
| 7.0   | wo   |                     | instruction_byte2  |      |                    |
| 7:0   | WO   | WO                  | wo ju              | 0x00 | Instruction byte 2 |

# DMA\_CR0

Address: Operational Base + offset (0x0e00)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                         |  |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:22 | RO   | 0x0                | reserved                                                                                                                                                                                                                                            |  |
| 21:17 | RO   | 0x02               | num_events<br>5'b00000: 1 interrupt output, irq[0]<br>5'b00001: 2 interrupt outputs, irq[1:0]<br>5'b00010: 3 interrupt outputs, irq[2:0]<br><br>5'b111111: 32 interrupt outputs_irq[31:0]                                                           |  |
| 16:12 | RO   | 0×07               | 5'b11111: 32 interrupt outputs, irq[31:0]<br>num_periph_req<br>5'b00000: 1 peripheral request interface<br>5'b00001: 2 peripheral request interfaces<br>5'b00010: 3 peripheral request interfaces<br><br>5'b11111: 32 peripheral request interfaces |  |
| 11:7  | RO   | 0x0                | reserved                                                                                                                                                                                                                                            |  |
| 6:4   | RO   | 0x5                | num_chnls<br>3'b000: 1 DMA channel<br>3'b001: 2 DMA channels<br>3'b010: 3 DMA channels<br><br>3'b111: 8 DMA channels                                                                                                                                |  |
| 3     | RO   | 0x0                | reserved                                                                                                                                                                                                                                            |  |
| 2     | RO   | 0×0                | mgr_ns_at_rst<br>1'b0: boot_manager_ns was LOW<br>1'b1: boot_manager_ns was HIGH                                                                                                                                                                    |  |
| 1     | RO   | 0x0                | boot_en<br>1'b0: boot_from_pc was LOW<br>1'b1: boot_from_pc was HIGH                                                                                                                                                                                |  |
| 0     | RO   | 0x1                | 1'b1: boot_from_pc was HIGH<br>periph_req<br>1'b0: the DMAC does not provide a peripheral request interface<br>1'b1: the DMAC provides the number of peripheral request<br>interfaces that the num_periph_req field specifies                       |  |

# DMA\_CR1

Address: Operational Base + offset (0x0e04)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                 |  |
|------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:8 | RO   | 0x0                | reserved                                                                                                                                                    |  |
| 7:4  | RO   | 0x5                | num_i_cache_lines<br>4'b0000: 1 i-cache line<br>4'b0001: 2 i-cache lines<br>4'b0010: 3 i-cache lines<br><br>4'b1111: 16 i-cache lines                       |  |
| 3    | RO   | 0x0                | reserved                                                                                                                                                    |  |
| 2:0  | RO   | 0x7                | reserved<br>i_cache_len<br>3'b000-3'b001: reserved<br>3'b010: 4 bytes<br>3'b011: 8 bytes<br>3'b100: 16 bytes<br>3'b101: 32 bytes<br>3'b110-3'b111: reserved |  |

### DMA CR2

Address: Operational Base + offset (0x0e08)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                           |  |
|------|------|--------------------|---------------------------------------------------------------------------------------|--|
| 31:0 | RO   | 0x00000000         | boot_addr<br>Provides the value of boot_addr[31:0] when the DMAC exited<br>from reset |  |

# DMA CR3

Address: Operational Base + offset (0x0e0c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                  |  |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:0 | RO   | 0x00000000         | ins<br>Bit [N]<br>1'b0: Assigns event <n> or irq[N] to the Secure state<br/>1'b1: Assigns event<n> or irq[N] to the Non-secure state</n></n> |  |

### DMA\_CR4

Address: Operational Base + offset (0x0e10)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                   |  |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:0 | RO   |                    | pns<br>Bit [N]<br>1'b0: Assigns peripheral request interface N to the Secure state<br>1'b1: Assigns peripheral request interface N to the Non-secure<br>state |  |

### DMA\_CRDn

Address: Operational Base + offset (0x0e14)

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                              |  |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:30 | RO   | 0x0                | reserved                                                                                                                                 |  |
| 29:20 | RO   | 0x020              | ata_buffer_dep<br>0'b000000000: 1 line<br>0'b00000001: 2 lines<br>0'b11111111: 1024 lines                                                |  |
| 19:16 | RO   | 0x9                | rd_q_dep<br>4'b0000: 1 line<br>4'b0001: 2 lines<br><br>4'b1111: 16 lines                                                                 |  |
| 15    | RO   | 0x0                | reserved                                                                                                                                 |  |
| 14:12 | RO   | 0x4                | rd_cap<br>3'b000: 1<br>3'b001: 2<br><br>3'b111: 8                                                                                        |  |
| 11:8  | RO   | 0x7                | wr_q_dep<br>4'b0000: 1 line<br>4'b0001: 2 lines<br><br>4'b1111: 16 lines                                                                 |  |
| 7     | RO   | 0x0                | reserved                                                                                                                                 |  |
| 6:4   | RO   | 0x3                | wr_cap<br>3'b000: 1<br>3'b001: 2<br><br>3'b111: 8                                                                                        |  |
| 3     | RO   | 0x0                | reserved                                                                                                                                 |  |
| 2:0   | RO   | 0x3                | eserved<br>ata_width<br>'b000: reserved<br>'b001: reserved<br>'b010: 32-bit<br>'b011: 64-bit<br>'b100: 128-bit<br>'b101-3'b111: reserved |  |

**DMA WD** Address: Operational Base + offset (0x0e80)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                            |  |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:1 | RO   | 0x0                | reserved                                                                                                                                               |  |
| 0    | RW   | 0x0                | reserved<br>wd_irq_only<br>1'b0: the DMAC aborts all of the contributing DMA channels and<br>sets irq_abort HIGH<br>1'b1: the DMAC sets irq_abort HIGH |  |

# 9.5 Timing Diagram

Following picture shows the relationship between dma\_req and dma\_ack.



Fig. 9-3 DMAC request and acknowledge timing

# 9.6 Interface Description

DMAC has the following tie-off signals. It can be configured by SGRF register. (Please refer to the chapter to find how to configure) Table 9-3 DMAC0 boot interface

| Interface       | Reset value | Control source       |
|-----------------|-------------|----------------------|
| boot_addr       | 0x0         | SGRF_DMAC_CON6[19:0] |
| boot_from_pc    | 0x0         | SGRF_DMAC_CON7[0]    |
| boot_manager_ns | 0x1         | SGRF_DMAC_CON7[1]    |
| boot_irq_ns     | 0xfff       | SGRF_DMAC_CON4[11:0] |
| boot_periph_ns  | 0xfff       | SGRF_DMAC_CON5[11:0] |

| Table 9-4 DMAC1 boot interface |  |
|--------------------------------|--|

| Interface       | Reset value | Control source        |
|-----------------|-------------|-----------------------|
| boot_addr       | 0x0         | SGRF_DMAC_CON10[19:0] |
| boot_from_pc    | 0x0         | SGRF_DMAC_CON7[2]     |
| boot_manager_ns | 0x1         | SGRF_DMAC_CON7[3]     |
| boot_irq_ns     | 0xffff      | SGRF_DMAC_CON8[15:0]  |
| boot_periph_ns  | 0xfffff     | SGRF_DMAC_CON9[19:0]  |

### boot\_addr

Configures the address location that contains the first instruction the DMAC executes, when it exits from reset.

### boot\_from\_pc

Controls the location in which the DMAC executes its initial instruction, after it exits from reset:

0 = DMAC waits for an instruction from either APB interface

1 = DMA manager thread executes the instruction that is located at the address that

### boot\_manager\_ns

When the DMAC exits from reset, this signal controls the security state of the DMA manager thread:

0 = assigns DMA manager to the Secure state

1 = assigns DMA manager to the Non-secure state.

### boot\_irq\_ns

Controls the security state of an event-interrupt resource, when the DMAC exits from reset: boot\_irq\_ns[x] is LOW

The DMAC assigns event<x> or irq[x] to the Secure state.

boot\_irq\_ns[x] is HIGH

The DMAC assigns event  $\langle x \rangle$  or irq[x] to the Non-secure state.

### boot\_periph\_ns

Controls the security state of a peripheral request interface, when the DMAC exits from reset:

boot\_periph\_ns[x] is LOW

The DMAC assigns peripheral request interface x to the Secure state.

boot\_periph\_ns[x] is HIGH

The DMAC assigns peripheral request interface x to the Non-secure state.

# 9.7 Application Notes

# 9.7.1 Using the APB slave interfaces

You must ensure that you use the appropriate APB interface, depending on the security state in which the boot\_manager\_ns initializes the DMAC to operate. For example, if the DMAC is in the secure state, you must issue the instruction using the secure APB interface, otherwise the DMAC ignores the instruction. You can use the secure APB interface, or the non-secure APB interface, to start or restart a DMA channel when the DMAC is in the Non-secure state. The necessary steps to start a DMA channel thread using the debug instruction registers as following:

- 1. Create a program for the DMA channel.
- 2. Store the program in a region of system memory.
- 3. Poll the DBGSTATUS Register to ensure that debug is idle, that is, the dbgstatus bit is 0.
- 4. Write to the DBGINSTO Register and enter the:
- Instruction byte 0 encoding for DMAGO.
- Instruction byte 1 encoding for DMAGO.
- Debug thread bit to 0. This selects the DMA manager thread.

5. Write to the DBGINST1 Register with the DMAGO instruction byte [5:2] data, see Debug Instruction-1 Register o. You must set these four bytes to the address of the first instruction in the program, that was written to system memory in step 2.

6. Writing zero to the DBGCMD Register. The DMAC starts the DMA channel thread and sets the dbgstatus bit to 1.

# 9.7.2 Security usage

### DMA manager thread is in the secure state

If the DNS bit is 0, the DMA manager thread operates in the secure state and it only performs secure instruction fetches. When a DMA manager thread in the secure state processes:

### DMAGO

It uses the status of the ns bit, to set the security state of the DMA channel thread by writing to the CNS bit for that channel.

### DMAWFE

It halts execution of the thread until the event occurs. When the event occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding INS bit.

### DMASEV

It sets the corresponding bit in the INT\_EVENT\_RIS Register, irrespective of the security state of the corresponding INS bit.

### DMA manager thread is in the Non-secure state

If the DNS bit is 1, the DMA manager thread operates in the Non-secure state, and it only performs non-secure instruction fetches. When a DMA manager thread in the Non-secure state processes:

### DMAGO

The DMAC uses the status of the ns bit, to control if it starts a DMA channel thread. If:

ns = 0

The DMAC does not start a DMA channel thread and instead it:

1. Executes a NOP.

- 2. Sets the FSRD Register, see Fault Status DMA Manager
- 3. Sets the dmago\_err bit in the FTRD Register, see Fault Type DMA Manager Register.
- 4. Moves the DMA manager to the Faulting state.

ns = 1

The DMAC starts a DMA channel thread in the Non-secure state and programs the CNS bit to be non-secure.

### DMAWFE

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it waits for the event. If:

INS = 0

The event is in the Secure state. The DMAC:

1. Executes a NOP.

- 2. Sets the FSRD Register, see Fault Status DMA Manager Register.
- 3. Sets the mgr\_evnt\_err bit in the FTRD Register, see Fault Type DMA Manager Register.
- 4. Moves the DMA manager to the Faulting state.

### INS = 1

The event is in the Non-secure state. The DMAC halts execution of the thread and waits for the event to occur.

### DMASEV

The DMAC uses the status of the corresponding INS bit, in the CR3Register, to control if it creates the event-interrupt. If:

### INS = 0

The event-interrupt resource is in the secure state. The DMAC:

- 1. Executes a NOP.
- 2. Sets the FSRD Register, see Fault Status DMA Manager Register.

3. Sets the mgr\_evnt\_err bit in the FTRD Register, see Fault Type DMA Manager Register.

- 4. Moves the DMA manager to the Faulting state.
- INS = 1

The event-interrupt resource is in the Non-secure state. The DMAC creates the event-interrupt.

### DMA channel thread is in the secure state

When the CNS bit is 0, the DMA channel thread is programmed to operate in the Secure state and it only performs secure instruction fetches.

When a DMA channel thread in the secure state processes the following instructions: **DMAWFE** 

The DMAC halts execution of the thread until the event occurs. When the event occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding INS bit, in the CR3 Register.

### DMASEV

The DMAC creates the event-interrupt, irrespective of the security state of the corresponding INS bit, in the CR3 Register.

### DMAWFP

The DMAC halts execution of the thread until the peripheral signals a DMA request. When this occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding PNS bit, in the CR4 Register.

### DMALDP, DMASTP

The DMAC sends a message to the peripheral to communicate that data transfer is complete, irrespective of the security state of the corresponding PNS bit, in the CR4 Register.

### DMAFLUSHP

The DMAC clears the state of the peripheral and sends a message to the peripheral to resend its level status, irrespective of the security state of the corresponding PNS bit, in the CR4 Register.

When a DMA channel thread is in the Secure state, it enables the DMAC to perform secure and non-secure AXI accesses

### DMA channel thread is in the Non-secure state

When the CNS bit is 1, the DMA channel thread is programmed to operate in the Non-secure

state and it only performs non-secure instruction fetches.

When a DMA channel thread in the Non-secure state processes the following instructions: **DMAWFE** 

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it waits for the event. If:

INS = 0

The event is in the Secure state. The DMAC:

1. Executes a NOP.

2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.

3. Sets the ch\_evnt\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.

4. Moves the DMA channel to the Faulting completing state.

INS = 1

The event is in the Non-secure state. The DMAC halts execution of the thread and waits for the event to occur.

### DMASEV

The DMAC uses the status of the corresponding INS bit, in the CR3 Register, to control if it creates the event. If:

INS = 0

The event-interrupt resource is in the Secure state. The DMAC:

1. Executes a NOP.

2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.

3. Sets the ch\_evnt\_err bit in the FTRn Register, see Fault Type DMA Channel Registers .

4. Moves the DMA channel to the Faulting completing state.

INS = 1

The event-interrupt resource is in the Non-secure state. The DMAC creates the event-interrupt.

### DMAWFP

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it waits for the peripheral to signal a request. If:

PNS = 0

The peripheral is in the Secure state. The DMAC:

1. Executes a NOP.

2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.

3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.

4. Moves the DMA channel to the Faulting completing state.

PNS = 1

The peripheral is in the Non-secure state. The DMAC halts execution of the thread and waits for the peripheral to signal a request.

### DMALDP, DMASTP

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it sends an acknowledgement to the peripheral. If:

PNS = 0

The peripheral is in the secure state. The DMAC:

1. Executes a NOP.

2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.

3. Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.

4. Moves the DMA channel to the Faulting completing state.

PNS = 1

The peripheral is in the Non-secure state. The DMAC sends a message to the peripheral to communicate when the data transfer is complete.

### DMAFLUSHP

The DMAC uses the status of the corresponding PNS bit, in the CR4 Register, to control if it sends a flush request to the peripheral. If:

PNS = 0

The peripheral is in the secure state. The DMAC:

1. Executes a NOP.

2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.

Sets the ch\_periph\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.
 Moves the DMA channel to the Faulting completing state.

PNS = 1

The peripheral is in the Non-secure state. The DMAC clears the state of the peripheral and sends a message to the peripheral to resend its level status.

When a DMA channel thread is in the Non-secure state, and a DMAMOV CCR instruction attempts to program the channel to perform a secure AXI transaction, the DMAC:

1. Executes a DMANOP.

2. Sets the appropriate bit in the FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.

3. Sets the ch\_rdwr\_err bit in the FTRn Register, see Fault Type DMA Channel Registers.

4. Moves the DMA channel thread to the Faulting completing state.

# 9.7.3 Programming restrictions

### Fixed unaligned bursts

The DMAC does not support fixed unaligned bursts. If you program the following conditions, the DMAC treats this as a programming error:

Unaligned read

- src\_inc field is 0 in the CCRn Register
- the SARn Register contains an address that is not aligned to the size of data that the src\_burst\_size field contain

Unaligned write

- dst\_inc field is 0 in the CCRn Register
- the DARn Register contains an address that is not aligned to the size of data that the dst\_burst\_size field contains

### Endian swap size restrictions

If you program the endian\_swap\_size field in the CCRn Register, to enable a DMA channel to perform an endian swap then you must set the corresponding SARn Register and the corresponding DARn Register to contain an address that is aligned to the value that the endian\_swap\_size field contains.

Updating DMA channel control registers during a DMA cycle restrictions

Prior to the DMAC executing a sequence of DMALD and DMAST instructions, the values you program in to the CCRn Register, SARn Register, and DARn Register control the data byte lane manipulation that the DMAC performs when it transfers the data from the source address to the destination address. You'd better not update these registers during a DMA cycle.

### **Resource sharing between DMA channels**

DMA channel programs share the MFIFO data storage resource. You must not start a set of concurrently running DMA channel programs with a resource requirement that exceeds the configured size of the MFIFO. If you exceed this limit then the DMAC might lock up and generate a Watchdog abort.

# 9.7.4 Unaligned transfers may be corrupted

For a configuration with more than one channel, if any of channels 1 to 7 is performing transfers between certain types of misaligned source and destination addresses, then the output data may be corrupted by the action of channel 0.

Data corruption might occur if all of the following are true:

1. Two beats of AXI read data are received for one of channels 1 to 7.

2. Source and destination address alignments mean that each read data beat is

splited across two lines in the data buffer (see Splitting data, below).

3. There is one idle cycle between the two read data beats.

4. Channel 0 performs an operation that updates channel control information during this idle cycle (see Updates to channel control information, below)

### Splitting data

Depending upon the programmed values for the DMA transfer, one beat of read data from the AXI interface need to be splited across two lines in the internal data buffer. This occurs when the read data beat contains data bytes which will be written to addresses that wrap around at the AXI interface data width, so that these bytes could not be transferred by a single AXI write data beat of the full interface width.

Most applications of DMA-330 do not split data in this way, so are NOT vulnerable to data corruption from this defect.

The following cases are NOT vulnerable to data corruption because they do not split data:

- Byte lane offset between source and destination addresses is 0 when source and destination addresses have the same byte lane alignment, the offset is 0 and a wrap operation that splits data cannot occur.
- Byte lane offset between source and destination addresses is a multiple of source size Table 9-5 Source size in CCRn

| Source size in CCRn | Allowed offset between SARn and DARn |
|---------------------|--------------------------------------|
| SS8                 | any offset allowed.                  |
| SS16                | 0,2,4,6,8,10,12,14                   |
| SS32                | 0,4,8,12                             |
| SS64                | 0,8                                  |

# 9.7.5 Interrupt shares between channel

As the DMAC does not record which channel (or list of channels) have asserted an interrupt. So it will depend on your program and whether any of the visible information for that program can be used to determine progress, and help identify the interrupt source. There are 4 likely information sources that can be used to determine the progress made by

- a program:
- Program counter (PC)
- Source address
- Destination address
- Loop counters (LC)

For example, a program might emit an interrupt each time that it iterates around a loop. In this case, the interrupt service routine (ISR) would need to store the loop value of each channel when it is called, and then compare against the new value when it is next called. A change in value would indicate that the program has progressed.

The ISR must be carefully written to ensure that no interrupts are lost. The sequence of operations is as follows:

- 1. Disable interrupts
- 2. Immediately clear the interrupt in DMA-330
- 3. Check the relevant registers for both channels to determine which must be serviced
- 4. Take appropriate action for the channels
- 5. Re-enable interrupts and exit ISR

# 9.7.6 Instruction sets

| Mnemonic  | Instruction                 | Thread usage |
|-----------|-----------------------------|--------------|
| DMAADDH   | Add Halfword                | С            |
| DMAEND    | End                         | M/C          |
| DMAFLUSHP | Flush and notify Peripheral | С            |
| DMAGO     | Go                          | Μ            |
| DMAKILL   | Kill                        | С            |
| DMALD     | Load                        | С            |

Table 9-6 DMAC Instruction sets

| Mnemonic | Instruction                 | Thread usage |  |  |
|----------|-----------------------------|--------------|--|--|
| DMALDP   | Load Peripheral             | С            |  |  |
| DMALP    | Loop                        | С            |  |  |
| DMALPEND | Loop End                    | С            |  |  |
| DMALPFE  | Loop Forever                | С            |  |  |
| DMAMOV   | Move                        | С            |  |  |
| DMANOP   | No operation                | M/C          |  |  |
| DMARMB   | Read Memory Barrier         | С            |  |  |
| DMASEV   | Send Event                  | M/C          |  |  |
| DMAST    | Store                       | C            |  |  |
| DMASTP   | Store and notify Peripheral | С            |  |  |
| DMASTZ   | Store Zero                  | С            |  |  |
| DMAWFE   | Wait For Event M            | M/C          |  |  |
| DMAWFP   | Wait For Peripheral         | С            |  |  |
| DMAWMB   | Write Memory Barrier        | С            |  |  |
| DMAADNH  | Add Negative Halfword       | С            |  |  |

Notes: Thread usage: C=DMA channel, M=DMA manager

# 9.7.7 Assembler directives

In this document, only DMMADNH instruction is took as an example to show the way the instruction assembled. For the other instructions, please refer to pl330\_trm.pdf.

### DMAADNH

Add Negative Halfword adds an immediate negative 16-bit value to the SARn Register or DARn Register, for the DMA channel thread. This enables the DMAC to support 2D DMA operations, or reading or writing an area of memory in a different order to naturally incrementing addresses. See Source Address Registers and Destination Address Registers. The immediate unsigned 16-bit value is one-extended to 32 bits, to create a value that is the two's complement representation of a negative number between -65536 and -1, before the DMAC adds it to the address using 32-bit addition. The DMAC discards the carry bit so that addresses wrap from 0xFFFFFFF to 0x00000000. The net effect is to subtract between 65536 and 1 from the current value in the Source or Destination Address Register. Following table shows the instruction encoding.

Table 9-7 DMAC instruction encoding

| Table 9 7 Divide instruction cheoding |          |   |   |   |   |   |   |    |   |
|---------------------------------------|----------|---|---|---|---|---|---|----|---|
| Imm[15:8]                             | Imm[7:0] | 0 | 1 | 0 | 1 | 1 | 1 | ra | 0 |
|                                       |          |   |   |   |   |   |   |    |   |

### Assembler syntax

DMAADNH <address\_register>, <16-bit immediate>

where:

<address\_register>

Selects the address register to use. It must be either:

SAR

SARn Register and sets ra to 0.

DAR

DARn Register and sets ra to 1.

<16-bit immediate>

The immediate value to be added to the <address\_register>.

You should specify the 16-bit immediate as the number that is to be represented in the instruction encoding. For example, DMAADNH DAR, 0xFFF0 causes the value 0xFFFFFF0 to be added to the current value of the Destination Address Register, effectively subtracting 16 from the DAR.

You can only use this instruction in a DMA channel thread.

# **Chapter 10 Generic Interrupt Controller (GIC)**

# **10.1 Overview**

There is a generic interrupt controller(GIC400) in RK3308 which generates physical interrupts to Cortex-A35. It has two interfaces, the distributor interface connects to the interrupt source, and the CPU interface connects to Cortex-A35. The details of CPU interface connectivity are shown in the following table.

| CPU Interface Number | Connectivity |
|----------------------|--------------|
| CPU interface 0      | CPU0         |
| CPU interface 1      | CPU1         |
| CPU interface 2      | CPU2         |
| CPU interface 3      | CPU3         |

Table 10-1 CPU interface connectivity

It supports the following features:

- Supports 128 hardware interrupt inputs
- Masking of any interrupts
- Prioritization of interrupts
- Distribution of the interrupts to the target Cortex-A35 processor(s)
- Generation of interrupts by software
- Supports Security Extensions

# 10.2 Block Diagram

The generic interrupt controller comprises with:



Fig. 10-1 Block Diagram

# **10.3 Function Description**

Please refer to the document <code>``IHI0048B\_gic\_architecture\_specification.pdf''</code> for the detailed function description.

# Chapter 11 Power Management Unit (PMU)

# **11.1 Overview**

In order to meet low power requirements, a power management unit (PMU) is designed for controlling power resources in RK3308. The RK3308 PMU is dedicated for managing the power of the whole chip.

# 11.1.1 Features

- Support 2 voltage domains: VD\_CORE, VD\_LOGIC
- Support power off VD\_CORE only
- 4 Power domains in VD\_CORE: PD\_CPU\_0/1/2/3
- PD\_CPU\_0/1/2/3 support CPU auto power down, support SCU auto power down
- There is no independent power domain in the VD\_LOGIC
- Support DDR self-refresh, auto-gating and retention
- Support wakeup sources
  - SDMMC detect
  - SDMMC detect interrupt
  - VAD interrupt
  - GPIO interrupt
  - USB detect interrupt
  - Interrupt of all timers
  - ARM interrupt
  - Interrupt output from GIC
  - Timeout
- Support Flush L2 by software and hardware
- Support NIU idle interface (idle request, ack and status)
- Support PMU debug through IO or UART interface

# 11.2 Block Diagram

# 11.2.1 Voltage partition

RK3308



Fig. 11-1 RK3308 Power Domain Partition

The above diagram describes voltage domain partition.

| Voltage Domain | Blocks  | Description                                  |
|----------------|---------|----------------------------------------------|
| VD_CORE        | PD_CPU0 | CPU Core 0 with NEON and FPU                 |
|                | PD_CPU1 | CPU Core 1 with NEON and FPU                 |
|                | PD_CPU2 | CPU Core 2 with NEON and FPU                 |
|                | PD_CPU3 | CPU Core 3 with NEON and FPU                 |
| VD_LOGIC       |         | DDR_CTRL, DDR_STDBY and DDR_MONITOR,         |
|                |         | GMAC, SFC, EMMC, NAND and SDIO, USB_OTG and  |
|                |         | USB_HOST, CRYPTO, DCF, DMAC, GIC, I2S, PDM,  |
|                |         | INTMEM, ROM, OTP, KEYREADER, CRU, CPU_BOOST, |

Table 11-1 RK3308 Power Domain and Voltage Domain Summary

| Voltage Domain | Blocks | Description                                    |
|----------------|--------|------------------------------------------------|
|                |        | GRF, I2C, WDT, TIMER, TSADC, SARADC, SPI, PWM, |
|                |        | GPIO, UART, DCF, PLL and ANALOG PHYs, PMU, VOP |

# 11.2.2 PMU block diagram

The following figure is the PMU block diagram. The PMU includes the 3 following sections:

- APB interface and register, which can accept the system configuration
- Low Power State Control, which generate low power control signals.
- Power Switch Control, which control all power domain switch



Fig. 11-2 PMU Block Diagram

# **11.3 Function Description**

First of all, we define two operation modes of PMU, normal mode and low power mode. When operating at normal mode, that means software can manage power sources directly by accessing PMU register.

For example, Cortex-A35 CPU can write PMU\_PWRDN\_CON register to determine that power off/on which power domain independently.

When operating at low power mode, software manages power sources indirectly through FSM (Finite States Machine) in PMU and those settings always not take effect immediately. That means software also can configure PMU registers to power down/up some power resources, but these setting will not be executed immediately after configuration. They will delay to execute after FSM running in particular phase.

To entering low power mode, after setting some power configurations, the

PMU\_PWRMODE\_COMMON\_CON\_LO[0] bit must be set 1 to enable PMU FSM. Then Cortex-A35 CPU needs to execute a WFI command to perform ready signal. After PMU detects all Cortex-A35 CPUs in WFI status, then the FSM will be fetched. And the specific power sources will be controlled during specific status in FSM. So the low power mode is a "delay affect" way to handle power sources inside the RK3308 chip.

# **11.4 Register Description**

| Name                                 | Offset | Size | Reset<br>Value | Description                      |
|--------------------------------------|--------|------|----------------|----------------------------------|
| PMU_WAKEUP_CFG                       | 0x0010 | W    | 0x00000000     | Wakeup source config register    |
| PMU PWRDN CON                        | 0x0018 | W    | 0x00000000     | Power down control register      |
| PMU_PWRDN_ST                         | 0x0020 | W    | 0x00000000     | Power status register            |
| PMU_PWRMODE_CORE_C                   | 0x0024 | W    | 0x00000000     | Core power mode register         |
| PMU_PWRMODE_COMMO<br>N_CON_LO        | 0x002c | W    | 0x00000000     | Power mode register low 16 bits  |
| <u>PMU_PWRMODE_COMMO</u><br>N_CON_HI | 0x0030 | W    | 0x00000000     | Power mode register high 16 bits |

# 11.4.1 Registers Summary

| Name                                     | Offset | Size | Reset<br>Value | Description                                |
|------------------------------------------|--------|------|----------------|--------------------------------------------|
| PMU SFT CON LO                           | 0x0034 | W    | 0x0000000      | Software control register low 16 bits      |
| PMU_SFT_CON_HI                           | 0x0038 | W    | 0x00000000     | Software control register high 16 bits     |
| PMU INT CON LO                           | 0x003c | W    | 0x0000000      | Interrupt control register low 16 bits     |
| <u>PMU INT CON HI</u>                    | 0x0040 | W    | 0x0000000      | Interrupt control register high 16<br>bits |
| <u>PMU INT ST</u>                        | 0x0044 | W    | 0x00000000     | Interrupt status register                  |
| PMU CORE PWR ST                          | 0x0060 | W    | 0x0000000      | PD_CORE status register                    |
| PMU BUS IDLE REQ                         | 0x0064 | W    | 0x0000000      | Idle request register                      |
| PMU_BUS_IDLE_ST                          | 0x006c | W    | 0x0000000      | Idle status register                       |
| PMU POWER ST                             | 0x0070 | W    | 0x0000000      | Power state register                       |
| PMU_OSC_CNT_LO                           | 0x0074 | W    | 0x00005dc0     | Oscillator counter low 16 bits             |
| PMU OSC CNT HI                           | 0x0078 | W    | 0x0000000      | Oscillator counter high 16 bits            |
| PMU PLLLOCK CNT LO                       | 0x007c | W    | 0x00005dc0     | PLL lock counter low 16 bits               |
| PMU_PLLLOCK_CNT_HI                       | 0x0080 | W    | 0x0000000      | PLL lock counter high 16 bits              |
| <u>PMU DDRIO PWRON CN</u><br>T_LO        | 0x0094 | W    | 0x00005dc0     | DDR IO power counter low 16 bits           |
| <u>PMU DDRIO PWRON CN</u><br><u>T_HI</u> | 0x0098 | W    | 0×00000000     | DDR IO power counter high 16<br>bits       |
| PMU_DDR_SREF_ST                          | 0x00a4 | W    | 0x0000003      | DDR self-refresh status register           |
| PMU SYS REGO LO                          | 0x00a8 | W    | 0x0000000      | System register0 low 16 bits               |
| PMU_SYS_REG0_HI                          | 0x00ac | W    | 0x0000000      | System register0 high 16 bits              |
| PMU_SYS_REG1_LO                          | 0x00b0 | W    | 0x0000000      | System register1 low 16 bits               |
| PMU SYS REG1 HI                          | 0x00b4 | W    | 0x0000000      | System register1 high 16 bits              |
| PMU_SYS_REG2_LO                          | 0x00b8 | W    | 0x0000000      | System register2 low 16 bits               |
| PMU SYS REG2 HI                          | 0x00bc | W    | 0x00000000     | System register2 high 16 bits              |
| PMU SYS REG3 LO                          | 0x00c0 | W    | 0x00000000     | System register3 low 16 bits               |
| PMU_SYS_REG3_HI                          | 0x00c4 | W    | 0x00000000     | System register3 high 16 bits              |
| PMU CORE PWRDN CNT                       | 0x00c8 | W    | 0x00005dc0     | Vd_core power down count low 16 bits       |
| <u>PMU CORE PWRDN CNT</u><br>HI          | 0x00cc | w    | 0x00000000     | Vd_core power down count high 16 bits      |
| <u>PMU CORE PWRUP CNT</u>                | 0x00d0 | W    | 0x00005dc0     | Vd_core power up count low 16<br>bits      |
| <u>PMU CORE PWRUP CNT</u><br>HI          | 0x00d4 | w    | 0x00000000     | Vd_core power up count low 16<br>bits      |
| PMU TIMEOUT CNT LO                       | 0x00d8 | W    | 0x00005dc0     | Time out count low 16 bits                 |
| PMU_TIMEOUT_CNT_HI                       | 0x00dc | W    | 0x000000000    | Time out count high 16 bits                |
| PMU_CPU0APM_CON                          | 0x00e0 | W    | 0x00000000     | CPU0 apm control register                  |
| PMU CPU1APM CON                          | 0x00e4 | W    | 0x00000000     | CPU1 apm control register                  |
| PMU_CPU2APM_CON                          | 0x00e8 | W    | 0x000000000    | CPU2 apm control register                  |

| Name                           | Offset                                                                                     | Size | Reset<br>Value | Description                      |  |  |  |  |
|--------------------------------|--------------------------------------------------------------------------------------------|------|----------------|----------------------------------|--|--|--|--|
| PMU_CPU3APM_CON                | 0x00ec                                                                                     | W    | 0x00000000     | CPU3 apm control register        |  |  |  |  |
| PMU INFO TX CON                | 0x00f0                                                                                     | W    | 0x00000000     | PMU info output control register |  |  |  |  |
| Nataa (Ciza B Duta (Q hita) aa | Notor: Size: P. Bute (8 bite) access HW Half WORD (16 bite) access W WORD (22 bite) access |      |                |                                  |  |  |  |  |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# 11.4.2 Detail Register Description

# PMU\_WAKEUP\_CFG

Address: Operational Base + offset (0x0010)

| Bit   |              | <b>Reset Value</b> | Description                           |
|-------|--------------|--------------------|---------------------------------------|
| 21.10 |              |                    | write_mask                            |
| 31:16 | RW           | 0x0000             | 16 bits write mask for lsb 15-0       |
| 15:9  | RO           | 0x0                | reserved                              |
|       |              |                    | wakeup_timeout_en                     |
| •     | <b>D</b> 147 |                    | pmu timeout wakeup enable             |
| 8     | RW           | 0x0                | 1'b0: disable                         |
|       |              |                    | 1'b1: enable                          |
|       |              |                    | wakeup_usbdev_en                      |
| 7     | עעם          | 0.40               | usb wakeup enable                     |
| 7     | RW           | 0x0                | 1'b0: disable                         |
|       |              |                    | 1'b1: enable                          |
|       |              |                    | wakeup_timer_en                       |
| 6     | RW           | 0.20               | timer wakeup enable                   |
| 0     | RW           | 0×0                | 1'b0: disable                         |
|       |              |                    | 1'b1: enable                          |
|       |              | W 0×0              | wakeup_sdmmc_grf_irq_en               |
|       |              |                    | sdmmc grf irq enable, should set GRF. |
|       |              |                    | DETECT_GRF_SDMMC_DETECT_CON.          |
| 5     | RW           |                    | sdmmc_detectn_pos_irq_enable or       |
|       |              |                    | sdmmc_detectn_neg_irq_enable to "1"   |
|       |              |                    | 1'b0: disable                         |
|       |              |                    | 1'b1: enable                          |
|       |              |                    | wakeup_sdmmc_en                       |
| 4     | RW           | 0x0                | sdmmc io wakeup enable                |
|       | 1            | 0,0                | 1'b0: disable                         |
|       |              |                    | 1'b1: enable                          |
|       |              |                    | wakeup_vad_en                         |
| 3     | RW           | 0x0                | vad interrupt wakeup enable           |
| 5     |              | 0.00               | 1'b0: disable                         |
|       |              |                    | 1'b1: enable                          |
|       |              |                    | wakeup_gpio0_int_en                   |
| 2     | RW           | 0x0                | gpio0 interrupt wakeup enable         |
| -     |              |                    | 1'b0: disable                         |
|       |              |                    | 1'b1: enable                          |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                |
|-----|------|--------------------|------------------------------------------------------------------------------------------------------------|
| 1   | RW   | 0×0                | wakeup_arm_int_en<br>arm interrupt before entering gic as wakeup source<br>1'b0: disable<br>1'b1: enable   |
| 0   | RW   |                    | wakeup_int_cluster_en<br>cluster interrupt generated by gic wakeup enable<br>1'b0: disable<br>1'b1: enable |

# PMU\_PWRDN\_CON

Address: Operational Base + offset (0x0018)

| Bit   | Attr  | <b>Reset Value</b> | Description                     |
|-------|-------|--------------------|---------------------------------|
| 31:16 |       | 0×0000             | write_mask                      |
| 51.10 | RVV   | 00000              | 16 bits write mask for lsb 15-0 |
| 15:5  | RO    | 0x0                | reserved                        |
|       |       |                    | pd_scu_pwrdwn_en                |
| 4     | RW    | 0x0                | pd_scu power down enable        |
| 4     | r vv  | 0.00               | 1'b0: disable                   |
|       |       |                    | 1'b1: enable                    |
|       |       |                    | pd_a35_3_pwrdwn_en              |
| 3     | D\\/  | RW 0x0             | pd_a35_3 power down enable      |
| 5     | r vv  |                    | 1'b0: disable                   |
|       |       |                    | 1'b1: enable                    |
|       |       |                    | pd_a35_2_pwrdwn_en              |
| 2     | RW    | 0x0                | pd_a35_2 power down enable      |
| 2     |       | KW UXU             | 1'b0: disable                   |
|       |       |                    | 1'b1: enable                    |
|       |       |                    | pd_a35_1_pwrdwn_en              |
| 1     | RW    | 0x0                | pd_a35_1 power down enable      |
| 1     | 12.00 | 0.0                | 1'b0: disable                   |
|       |       |                    | 1'b1: enable                    |
|       |       |                    | pd_a35_0_pwrdwn_en              |
| 0     | RW    | 0x0                | pd_a35_0 power down enable      |
| 0     |       |                    | 1'b0: disable                   |
|       |       |                    | 1'b1: enable                    |

# <u>PMU\_PWRDN\_ST</u>

Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description               |
|------|------|--------------------|---------------------------|
| 31:5 | RO   | 0x0                | reserved                  |
|      |      |                    | pd_scu_pwr_status         |
| 4    | RW   | 0x0                | 1'b0: pd_scu is power on  |
|      |      |                    | 1'b1: pd_scu is power off |

| Bit | Attr | Reset Value | Description                 |
|-----|------|-------------|-----------------------------|
|     |      |             | pd_a35_3_pwr_status         |
| 3   | RW   | 0x0         | 1'b0: pd_a35_3 is power on  |
|     |      |             | 1'b1: pd_a35_3 is power off |
|     |      |             | pd_a35_2_pwr_status         |
| 2   | RW   | 0x0         | 1'b0: pd_a35_2 is power on  |
|     |      |             | 1'b1: pd_a35_2 is power off |
|     |      |             | pd_a35_1_pwr_status         |
| 1   | RW   | 0x0         | 1'b0: pd_a35_1 is power on  |
|     |      |             | 1'b1: pd_a35_1 is power off |
|     |      |             | pd_a35_0_pwr_status         |
| 0   | RO   | 0x0         | 1'b0: pd_a35_0 is power on  |
|     |      |             | 1'b1: pd_a35_0 is power off |

**PMU PWRMODE CORE CON** Address: Operational Base + offset (0x0024)

| Bit   | Attr | <b>Reset Value</b> | Description                                         |
|-------|------|--------------------|-----------------------------------------------------|
| 31:16 | עע   | 0x0000             | write_mask                                          |
| 51:10 | KW   | 0x0000             | 16 bits write mask for lsb 15-0                     |
| 15:12 | RO   | 0x0                | reserved                                            |
|       |      |                    | vpll1_pd_en                                         |
| 11    | RW   | 0x0                | VPLL1 power down enable in low power mode           |
| 11    | r vv | 0.00               | 1'b0: disable                                       |
|       |      |                    | 1'b1: enable                                        |
|       |      |                    | vpll0_pd_en                                         |
| 10    | RW   | 0x0                | VPLL0 power down enable in low power mode           |
| 10    | r vv | 0.00               | 1'b0: disable                                       |
|       |      |                    | 1'b1: enable                                        |
|       |      | V 0×0              | dpll_pd_en                                          |
| 9     | RW   |                    | DPLL power down enable in low power mode            |
| 5     |      |                    | 1'b0: disable                                       |
|       |      |                    | 1'b1: enable                                        |
|       |      |                    | apll_pd_en                                          |
| 8     | RW   | 0x0                | APLL power down enable in low power mode            |
| 0     |      |                    | 1'b0: disable                                       |
|       |      |                    | 1'b1: enable                                        |
|       |      |                    | I2_flush_en                                         |
| 7     | RW   | W 0x0              | 1'b0: not flush L2 in low power mode                |
|       |      |                    | 1'b1: flush L2 in low power mode                    |
|       |      |                    | I2_idle_en                                          |
| 6     | RW   | 0x0                | 1'b0: not wait for L2 idle when in low power mode   |
|       |      |                    | 1'b1: wait for L2 idle in low power mode            |
|       |      |                    | scu_pd_en                                           |
| 5     | RW   | 0x0                | 1'b0: not power down scu(vd_core) in low power mode |
|       |      |                    | 1'b1: power down scu(vd_core) in low power mode     |

| Bit | Attr | <b>Reset Value</b> | Description                                 |
|-----|------|--------------------|---------------------------------------------|
|     |      |                    | clr_core                                    |
| 4   | RW   | 0x0                | 1'b0: not clear core niu in low power mode  |
|     |      |                    | 1'b1: clear core niu in low power mode      |
|     |      |                    | cpu0_pd_en                                  |
| 3   | RW   | 0x0                | 1'b0: not power down cpu0 in low power mode |
|     |      |                    | 1'b1: power down cpu0 in low power mode     |
|     |      | RW 0×0             | pmu_sleep_pol                               |
| 2   |      |                    | pmu_sleep polarity                          |
| 2   | RW   |                    | 1'b0: high active                           |
|     |      |                    | 1'b1: low active                            |
|     |      |                    | clk_core_src_gate_en                        |
| 1   | RW   | 0x0                | 1'b0: core clock not gating when power mode |
|     |      |                    | 1'b1: core clock gating when power mode     |
|     |      |                    | global_int_disable_cfg                      |
| 0   | RW   | 0x0                | 1'b0: global interrupt enable               |
|     |      |                    | 1'b1: global interrupt disable              |

# PMU PWRMODE COMMON CON LO

Address: Operational Base + offset (0x002c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
| 21.10 |      | 00000              | write_mask                                                        |
| 31:16 | RW   | 0x0000             | 16 bits write mask for lsb 15-0                                   |
|       |      |                    | clr_msch                                                          |
| 15    | RW   | 0x0                | 1'b0: not clear msch niu when in low power mode                   |
|       |      |                    | 1'b1: clear msch niu when in low power mode                       |
|       |      |                    | clr_voice                                                         |
| 14    | RW   | 0x0                | 1'b0: not clear voice niu when in low power mode                  |
|       |      |                    | 1'b1: clear voice niu when in low power mode                      |
|       |      |                    | clr_peri2bus                                                      |
| 10    |      | 0.40               | 1'b0: not clear peri2bus niu in low power mode                    |
| 13    | RW   | 0x0                | 1'b1: clear peri2bus niu in low power mode                        |
|       |      |                    | This bit should be same as the "clr_peri" and "clr_peri2msch"     |
|       |      |                    | clr_peri                                                          |
|       |      |                    | 1'b0: not clear peri niu in low power mode                        |
| 12    | RW   | 0x0                | 1'b1: clear peri niu in low power mode                            |
|       |      |                    | This bit should be same as the "clr_peri2bus" and                 |
|       |      |                    | "clr_peri2msch"                                                   |
|       |      |                    | clr_bus                                                           |
| 11    | RW   | 0x0                | 1'b0: not clear bus niu in low power mode                         |
|       |      |                    | 1'b1:clear bus niu in low power mode                              |
|       |      |                    | ddr_ret_de_req                                                    |
| 10    | RW   | 0x0                | set 1 to de-request for ddr io retention bit when exiting the low |
|       |      |                    | power mode                                                        |
|       |      |                    | ddrio_ret_en                                                      |
| 9     | RW   | 0x0                | 1'b0: ddr io retention disable in low power mode                  |
|       |      |                    | 1'b1: ddr io retention enable in low power mode                   |
|       |      |                    | ddrphy1x_clk_src_gate_en                                          |
| 8     | RW   | 0x0                | 1'b0: ddr phy 1x clock source gating disable in low power mode    |
|       |      |                    | 1'b1: ddr phy 1x clock source gating enable in low power mode     |
|       |      |                    | ddrphy4x_clk_src_gate_en                                          |
| 7     | RW   | 0x0                | 1'b0: ddr phy 4x clock source gating disable in low power mode    |
|       |      |                    | 1'b1: ddr phy 4x clock source gating enable in low power mode     |
|       |      |                    | sref_enter_en                                                     |
| 6     | RW   | 0x0                | 1'b0: ddr not enter self-refresh in low power mode                |
|       |      |                    | 1'b1: ddr enter self-refresh in low power mode                    |
|       |      |                    | osc_24m_dis                                                       |
| 5     | RW   | 0x0                | 1'b0: not disable 24MHz OSC in low power mode                     |
|       |      |                    | 1'b1: disable 24MHz OSC in low power mode                         |
|       |      |                    | lf_32k                                                            |
| 1     |      | 0x0                | clock switch to 32KHz clock in low power mode                     |
| 4     | RW   |                    | 1'b0: disable                                                     |
|       |      |                    | 1'b1: enable                                                      |

| 3 | RW | 0×0 | If_24m<br>clock switch to 24MHz clock in low power mode<br>1'b0: disable<br>1'b1: enable          |
|---|----|-----|---------------------------------------------------------------------------------------------------|
| 2 | RW | 0x0 | pll_pd_en<br>1'b0: not power down pll in low power mode<br>1'b1: power down pll in low power mode |
| 1 | RO | 0x0 | reserved                                                                                          |
| 0 | RW | 0×0 | power_mode_en<br>1'b0: low power mode disable<br>1'b1: low power mode enable                      |

**PMU PWRMODE COMMON CON HI** Address: Operational Base + offset (0x0030)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                     |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000             | write_mask<br>16 bits write mask for lsb 15-0                                                                                                                                   |
| 15:6  | RO   | 0x0                | reserved                                                                                                                                                                        |
| 5     | RW   | 0×0                | scu_apm_en<br>1'b0: vd_core auto power down disable<br>1'b1: vd_core auto power down enable                                                                                     |
| 4     | RW   | 0×0                | scu_auto_gating_en<br>1'b0: vd_core auto gating disable<br>1'b1: vd_core auto gating enable                                                                                     |
| 3     | RW   | 0x0                | pd_bus_clk_src_gate_en<br>clock gating bus niu when in low power mode<br>1'b0: not gating clock<br>1'b1: gating clock                                                           |
| 2     | RW   | 0x0                | pd_peri_clk_src_gate_en<br>clock gating peri niu when in low power mode<br>1'b0: not gating clock<br>1'b1: gating clock                                                         |
| 1     | RW   | 0×0                | wait_wakeup_begin<br>set "1" to start the wait wakeup state                                                                                                                     |
| 0     | RW   | 0×0                | clr_peri2msch<br>1'b0: peri2msch niu not clear in low power mode<br>1'b1: peri2msch niu clear in low power mode<br>This bit should be same as the "clr_peri2bus" and "clr_peri" |

# PMU\_SFT\_CON\_LO

Address: Operational Base + offset (0x0034)

| Bit   | Attr | <b>Reset Value</b> | Description                     |
|-------|------|--------------------|---------------------------------|
| 31:16 | עע   | 0x0000             | write_mask                      |
| 51.10 | ĸw   | 00000              | 16 bits write mask for lsb 15-0 |

| Bit | Attr | <b>Reset Value</b> | Description                                                     |
|-----|------|--------------------|-----------------------------------------------------------------|
|     |      |                    | dbgpwrup_cfg                                                    |
| 4 - |      |                    | debug power up status for cpu0                                  |
| 15  | RW   | 0x0                | 1'b0: power off                                                 |
|     |      |                    | 1'b1: power on                                                  |
|     |      |                    | osc_disable_cfg                                                 |
| 14  | RW   | 0x0                | osc disable software config                                     |
| 14  |      | 0.00               | 1'b0: osc work normally                                         |
|     |      |                    | 1'b1: osc disable                                               |
|     |      |                    | pmu_lf_24m_ena_cfg                                              |
| 13  | RW   | 0x0                | for software to switch pmu clock to 24MHz clock                 |
| 13  |      | 0.00               | 1'b0: normal working clock                                      |
|     |      |                    | 1'b1: switch to 24MHz clock                                     |
|     |      |                    | pmu_lf_32k_ena_cfg                                              |
| 12  | RW   | 0x0                | for software to switch pmu clock to 32KHz clock                 |
| 12  | 1    | 0,0                | 1'b0: normal working clock                                      |
|     |      |                    | 1'b1: switch to 32KHz clock                                     |
|     |      |                    | lf_24m_ena_cfg                                                  |
| 11  | RW   | 0x0                | for software to switch system clock (except pmu) to 24MHz clock |
|     | K VV | 0.00               | 1'b0: normal working clock                                      |
|     |      |                    | 1'b1: switch to 24MHz clock                                     |
|     |      |                    | lf_32k_ena_cfg                                                  |
| 10  | RW   | 0x0                | for software to switch system clock (except pmu) to 32KHz clock |
| 10  | 1    | 0,0                | 1'b0: normal working clock                                      |
|     |      |                    | 1'b1: switch to 32KHz clock                                     |
|     | RW   |                    | power_off_ddrio_cfg                                             |
| 9   |      | 0x0                | for software to ddr io power off                                |
| 5   |      | 0.00               | 1'b0: power on                                                  |
|     |      |                    | 1'b1: power off                                                 |
|     |      |                    | ddr_io_ret_cfg                                                  |
| 8   | RW   | 0x0                | for software to config ddr io retention                         |
|     |      |                    | 1'b0: not io retention                                          |
|     |      |                    | 1'b1: io retention                                              |
|     |      |                    | upctl_c_sysreq_cfg                                              |
| 7   | RW   | 0x0                | for software to config upctl to self-refresh                    |
|     |      |                    | 1'b0: not self-refresh request                                  |
|     |      |                    | 1'b1: self-refresh request                                      |
|     |      |                    | cluster_clk_src_gating_cfg                                      |
| 6   | RW   | 0x0                | for software to config cluster clock source gating              |
| -   |      |                    | 1'b0: not gate clock                                            |
|     |      |                    | 1'b1: gate clock                                                |
| 5   | RO   | 0x0                | reserved                                                        |
|     |      |                    | l2flushreq_cluster_cfg                                          |
| 4   | RW   | 0×0                | for software to config L2 flush                                 |
|     |      |                    | 1'b0: not flush                                                 |
|     |      |                    | 1'b1: flush                                                     |

| Bit | Attr | <b>Reset Value</b> | Description                            |
|-----|------|--------------------|----------------------------------------|
|     |      | 0x0                | vpll1_pd_cfg                           |
| 3   | RW   |                    | for software to config vpll1 power off |
| J   |      | 0.00               | 1'b0: power on                         |
|     |      |                    | 1'b1: power off                        |
|     |      |                    | vpll0_pd_cfg                           |
| 2   | RW   | 0x0                | for software to config vpll0 power off |
| 2   | ĸw   |                    | 1'b0: power on                         |
|     |      |                    | 1'b1: power off                        |
|     |      | V 0x0              | dpll_pd_cfg                            |
| 1   | RW   |                    | for software to config dpll power off  |
| 1   | ĸvv  |                    | 1'b0: power on                         |
|     |      |                    | 1'b1: power off                        |
|     |      |                    | apll_pd_cfg                            |
| 0   |      | RW 0x0             | for software to config apll power off  |
| 0   | KW   |                    | 1'b0: power on                         |
|     |      |                    | 1'b1: power off                        |

# PMU\_SFT\_CON\_HI

Address: Operational Base + offset (0x0038)

| Bit   | Attr | <b>Reset Value</b> | Description                                         |
|-------|------|--------------------|-----------------------------------------------------|
| 31:16 |      | 00000              | write_mask                                          |
| 51.10 | RVV  | 0x0000             | 16 bits write mask for lsb 15-0                     |
|       |      |                    | dbgpwrupreq_en                                      |
| 15    | RW   | 0x0                | cpu debug power up request enable                   |
| 15    |      |                    | 1'b0: request disable                               |
|       |      |                    | 1'b1: request enable                                |
|       | RW   | W 0×0              | dbgnopwrdwn_enable                                  |
| 14.11 |      |                    | cpu debug power down enable, bit[3:0] for cpu3-cpu0 |
| 14:11 |      |                    | 1'b0: power down disable                            |
|       |      |                    | 1'b1: power down enable                             |
| 10:0  | RO   | 0x0                | reserved                                            |

# PMU INT CON LO

Address: Operational Base + offset (0x003c)

| Bit   | Attr | <b>Reset Value</b> | Description                        |
|-------|------|--------------------|------------------------------------|
| 31:16 |      | 0x0000             | write_mask                         |
| 51.10 | RVV  |                    | 16 bits write mask for lsb 15-0    |
| 15:11 | RO   | 0x0                | reserved                           |
|       |      | RW 0×0             | wakeup_timeout_int_en              |
| 10    |      |                    | wakeup by timeout interrupt enable |
| 10    | ĸw   |                    | 1'b0: disable                      |
|       |      |                    | 1'b1: enable                       |

| Bit | Attr | <b>Reset Value</b> | Description                                 |
|-----|------|--------------------|---------------------------------------------|
|     |      |                    | wakeup_sdmmc_irq_int_en                     |
| ~   |      | 0.40               | wakeup by sdmmc detectn interrupt enable    |
| 9   | RW   | 0x0                | 1'b0: disable                               |
|     |      |                    | 1'b1: enable                                |
|     |      |                    | wakeup_sdmmc_detectn_en                     |
| 0   |      | 00                 | wakeup by sdmmc detectn enable              |
| 8   | RW   | 0x0                | 1'b0: disable                               |
|     |      |                    | 1'b1: enable                                |
|     |      |                    | wakeup_vad_int_en                           |
| _   |      |                    | wakeup by vad interrupt enable              |
| 7   | RW   | 0x0                | 1'b0: disable                               |
|     |      |                    | 1'b1: enable                                |
|     |      |                    | wakeup_gpio_int_int_en                      |
|     |      |                    | wakeup by gpio0 interrupt enable            |
| 6   | RW   | 0x0                | 1'b0: disable                               |
|     |      |                    | 1'b1: enable                                |
|     |      | 0×0                | wakeup_usbdev_int_en                        |
| -   |      |                    | wakeup by usb interrupt enable              |
| 5   | RW   |                    | 1'b0: disable                               |
|     |      |                    | 1'b1: enable                                |
|     |      |                    | wakeup_timer_int_en                         |
|     |      | 00                 | wakeup by timer interrupt enable            |
| 4   | RW   | 0x0                | 1'b0: disable                               |
|     |      |                    | 1'b1: enable                                |
|     |      |                    | wakeup_arm_int_int_en                       |
| 2   | RW   | 00                 | wakeup by arm interrupt enable              |
| 3   |      | 0x0                | 1'b0: disable                               |
|     |      |                    | 1'b1: enable                                |
|     |      |                    | wakeup_int_cluster_int_en                   |
| 2   |      | 00                 | wakeup by cluster interrupt enable          |
| 2   | RW   | 0x0                | 1'b0: disable                               |
|     |      |                    | 1'b1: enable                                |
|     |      |                    | pwrmode_wakeup_int_en                       |
| 4   |      | 00                 | wakeup from low power mode interrupt enable |
| 1   | RW   | 0x0                | 1'b0: disable                               |
|     |      |                    | 1'b1: enable                                |
|     |      |                    | pmu_int_en                                  |
|     |      |                    | pmu global interrupt enable                 |
| 0   | RO   | 0x0                | 1'b0: disable                               |
|     |      |                    |                                             |

**PMU INT CON HI** Address: Operational Base + offset (0x0040)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                           |
|-------|------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000             | write_mask<br>16 bits write mask for lsb 15-0                                                         |
| 15:5  | RO   | 0x0                | reserved                                                                                              |
| 4     | RW   | 0×0                | pd_scu_pwr_switch_int_en<br>pd_scu power switch interrupt enable<br>1'b0: disable<br>1'b1: enable     |
| 3     | RW   | 0x0                | pd_a35_3_pwr_switch_int_en<br>pd_a35_3 power switch interrupt enable<br>1'b0: disable<br>1'b1: enable |
| 2     | RW   | 0x0                | pd_a35_2_pwr_switch_int_en<br>pd_a35_2 power switch interrupt enable<br>1'b0: disable<br>1'b1: enable |
| 1     | RW   | 0x0                | pd_a35_1_pwr_switch_int_en<br>pd_a35_1 power switch interrupt enable<br>1'b0: disable<br>1'b1: enable |
| 0     | RW   | 0x0                | pd_a35_0_pwr_switch_int_en<br>pd_a35_0 power switch interrupt enable<br>1'b0: disable<br>1'b1: enable |

# <u>PMU\_INT\_ST</u>

Address: Operational Base + offset (0x0044)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 31:21 | RO   | 0x0                | reserved                               |
|       |      |                    | pd_scu_pwr_switch_status               |
| 20    | RW   | 0x0                | pd_scu power switch interrupt status   |
| 20    |      | 0.00               | 1'b0: no interrupt                     |
|       |      |                    | 1'b1: interrupt issue                  |
|       |      |                    | pd_a35_3_pwr_switch_status             |
| 19    | RW   | 0×0                | pd_a35_3 power switch interrupt status |
| 19    |      |                    | 1'b0: no interrupt                     |
|       |      |                    | 1'b1: interrupt issue                  |
|       |      | W 0×0              | pd_a35_2_pwr_switch_status             |
| 18    | DW   |                    | pd_a35_2 power switch interrupt status |
| 10    | K VV |                    | 1'b0: no interrupt                     |
|       |      |                    | 1'b1: interrupt issue                  |
|       |      |                    | pd_a35_1_pwr_switch_status             |
| 17    | RW   | 0×0                | pd_a35_1 power switch interrupt status |
| 11/   |      |                    | 1'b0: no interrupt                     |
|       |      |                    | 1'b1: interrupt issue                  |

| Bit    | Attr    | Reset Value | Description                                 |
|--------|---------|-------------|---------------------------------------------|
|        |         |             | pd_a35_0_pwr_switch_status                  |
|        |         |             | pd_a35_0 power switch interrupt status      |
| 16     | RW      | 0x0         | 1'b0: no interrupt                          |
|        |         |             | 1'b1: interrupt issue                       |
| 15:11  | RO      | 0x0         | reserved                                    |
|        |         |             | wakeup_timeout_status                       |
| 10     |         | 00          | wakeup by timeout interrupt status          |
| 10     | RW      | 0x0         | 1'b0: no interrupt                          |
|        |         |             | 1'b1: interrupt issue                       |
|        |         |             | wakeup_sdmmc_irq_status                     |
| 9      | RW      | 0x0         | wakeup by sdmmc detectn interrupt status    |
| 9      | RVV     | UXU         | 1'b0: no interrupt                          |
|        |         |             | 1'b1: interrupt issue                       |
|        |         |             | wakeup_sdmmc_status                         |
| 8      | RW      | 0x0         | wakeup by sdmmc detectn status              |
| 0      |         | 0.00        | 1'b0: no interrupt                          |
|        |         |             | 1'b1: interrupt issue                       |
|        |         | 0x0         | wakeup_vad_status                           |
| 7      | RW      |             | wakeup by vad interrupt status              |
| ,<br>, | I'' V V |             | 1'b0: no interrupt                          |
|        |         |             | 1'b1: interrupt issue                       |
|        | RW      | 0x0         | wakeup_gpio_int_status                      |
| 6      |         |             | wakeup by gpio0 interrupt status            |
| Ũ      |         |             | 1'b0: no interrupt                          |
|        |         |             | 1'b1: interrupt issue                       |
|        |         |             | wakeup_usbdev_status                        |
| 5      | RW      | 0x0         | wakeup by usb interrupt status              |
| •      |         |             | 1'b0: no interrupt                          |
|        |         |             | 1'b1: interrupt issue                       |
|        |         |             | wakeup_timer_status                         |
| 4      | RW      | 0x0         | wakeup by timer interrupt status            |
|        |         |             | 1'b0: no interrupt                          |
|        |         |             | 1'b1: interrupt issue                       |
|        |         |             | wakeup_arm_int_status                       |
| 3      | RW      | 0x0         | wakeup by arm interrupt status              |
|        |         |             | 1'b0: no interrupt                          |
|        |         |             | 1'b1: interrupt issue                       |
|        |         |             | wakeup_int_cluster_status                   |
| 2      | RW      | 0x0         | wakeup by cluster interrupt status          |
|        |         |             | 1'b0: no interrupt                          |
|        | -       |             | 1'b1: interrupt issue                       |
|        |         |             | pwrmode_wakeup_status                       |
| 1      | RW      | 0x0         | wakeup from low power mode interrupt status |
|        |         |             | 1'b0: no interrupt                          |
|        |         |             | 1'b1: interrupt issue                       |

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
| 0   | RO   | 0x0                | reserved    |

#### PMU CORE PWR ST

Address: Operational Base + offset (0x0060)

| Bit  | Attr | <b>Reset Value</b> | Description                                                         |
|------|------|--------------------|---------------------------------------------------------------------|
| 31:4 | RO   | 0x0                | reserved                                                            |
| 3    | RW   | 0x0                | cpu_standby_wfi<br>1'b0: cpu is not in wfi standby                  |
|      |      |                    | 1'b1: cpu is in wfi standby                                         |
| 2    | RW   | 0×0                | cpu_standby_wfe<br>1'b0: cpu is not in wfe standby                  |
|      |      |                    | 1'b1: cpu is in wfe standby                                         |
| 1    | RW   | 0x0                | I2_standby<br>1'b0: I2 is not in standby<br>1'b1: I2 is in standby  |
| 0    | RO   | 0×0                | l2flushdone<br>1'b0: L2 flush is not done<br>1'b1: L2 flush is done |

# PMU\_BUS\_IDLE\_REQ

Address: Operational Base + offset (0x0064)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                              |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000             | write_mask<br>16 bits write mask for lsb 15-0                                                            |
| 15:7  | RO   | 0x0                | reserved                                                                                                 |
| 6     | RW   | 0x0                | idle_req_peri2msch_cfg<br>peri2msch niu idle request<br>1'b0: not request<br>1'b1: request               |
| 5     | RW   | 0x0                | idle_req_msch_cfg<br>msch niu idle request<br>1'b0: not request<br>1'b1: request                         |
| 4     | RW   | 0×0                | idle_req_peri2bus_cfg<br>software config peri2bus niu idle request<br>1'b0: not request<br>1'b1: request |
| 3     | RW   | 0×0                | idle_req_peri_cfg<br>software config peri niu idle request<br>1'b0: not request<br>1'b1: request         |
| 2     | RW   | 0×0                | idle_req_voice_cfg<br>software config voice niu idle request<br>1'b0: not request<br>1'b1: request       |
| 1     | RW   | 0x0                | idle_req_core_cfg<br>software config core niu idle request<br>1'b0: not request<br>1'b1: request         |
| 0     | RW   | 0x0                | idle_req_bus_cfg<br>software config bus niu idle request<br>1'b0: not request<br>1'b1: request           |

# PMU BUS IDLE ST

Address: Operational Base + offset (0x006c)

| Bit   | Attr | Reset Value | Description               |
|-------|------|-------------|---------------------------|
| 31:23 | RO   | 0x0         | reserved                  |
|       |      |             | idle_peri2msch            |
| 22    |      | 0×0         | peri2msch niu idle status |
| 22    | RW   |             | 1'b0: niu not idle        |
|       |      |             | 1'b1: niu idle            |
|       |      |             | idle_msch                 |
| 21    | RW   |             | msch niu idle status      |
|       | K VV |             | 1'b0: niu not idle        |
|       |      |             | 1'b1: niu idle            |

| Bit  | Attr         | Reset Value | Description                                       |
|------|--------------|-------------|---------------------------------------------------|
|      |              |             | idle_peri2bus                                     |
| ~~   | <b>D</b> 144 |             | peri2bus niu idle status                          |
| 20   | RW           | 0×0         | 1'b0: niu not idle                                |
|      |              |             | 1'b1: niu idle                                    |
|      |              |             | idle_peri                                         |
| 10   |              | 0.40        | peri idle status                                  |
| 19   | RW           | 0x0         | 1'b0: niu not idle                                |
|      |              |             | 1'b1: niu idle                                    |
|      |              |             | idle_voice                                        |
| 18   | RW           | 0x0         | voice niu idle status                             |
| 10   | K VV         | UXU         | 1'b0: niu not idle                                |
|      |              |             | 1'b1: niu idle                                    |
|      |              |             | idle_core                                         |
| 17   | RW           | 0x0         | core niu idle status                              |
| 1/   | L AN         | 0.00        | 1'b0: niu not idle                                |
|      |              |             | 1'b1: niu idle                                    |
|      |              |             | idle_bus                                          |
| 16   | RW           | 0x0         | bus niu idle status                               |
| 10   |              | 0.00        | 1'b0: niu not idle                                |
|      |              |             | 1'b1: niu idle                                    |
| 15:7 | RO           | 0x0         | reserved                                          |
|      |              |             | idle_ack_peri2msch                                |
| 6    | RW           | 0x0         | peri2msch niu idle ack status                     |
| -    |              |             | 1'b0: niu not ack                                 |
|      |              |             | 1'b1: niu ack                                     |
|      |              |             | idle_ack_msch                                     |
| 5    | RW           | 0x0         | msch niu idle ack                                 |
|      |              |             | 1'b0: niu not ack                                 |
|      |              |             | 1'b1: niu ack                                     |
|      |              |             | idle_ack_peri2bus                                 |
| 4    | RW           | / 0×0       | peri2bus niu idle ack status<br>1'b0: niu not ack |
|      |              |             | 1'b1: niu ack                                     |
|      |              |             | idle_ack_peri                                     |
|      |              |             | peri niu idle ack status                          |
| 3    | RO           | 0x0         | 1'b0: niu not ack                                 |
|      |              |             | 1'b1: niu ack                                     |
|      |              |             | idle_ack_voice                                    |
|      |              |             | voice niu idle ack status                         |
| 2    | RO           | 0x0         | 1'b0: niu not ack                                 |
|      | 1            |             | 1'b1: niu ack                                     |
|      |              |             | idle_ack_core                                     |
|      | 1            |             | core niu idle ack status                          |
| 1    | RO           | 0x0         | 1'b0: niu not ack                                 |
|      | 1            |             | 1'b1: niu ack                                     |
|      | 1            |             |                                                   |

| Bit | Attr | <b>Reset Value</b> | Description                             |
|-----|------|--------------------|-----------------------------------------|
|     |      |                    | idle_ack_bus<br>bus niu idle ack status |
| 0   | RO   |                    | 1'b0: niu not ack<br>1'b1: niu ack      |

# PMU\_POWER\_ST

Address: Operational Base + offset (0x0070)

| Bit  | Attr | <b>Reset Value</b> | Description                                     |
|------|------|--------------------|-------------------------------------------------|
| 31:5 | RO   | 0x0                | reserved                                        |
| 4:0  | RO   | 0x00               | power_state<br>issue the low power state of pmu |

#### PMU\_OSC\_CNT\_LO

Address: Operational Base + offset (0x0074)

| Bit      | Attr | <b>Reset Value</b> | Description                     |
|----------|------|--------------------|---------------------------------|
| 21.16 DW | DW   | 0x0000             | write_mask                      |
| 51.10    | K VV |                    | 16 bits write mask for lsb 15-0 |
| 15:0     | RW   | 0x5dc0             | osc_cnt_lo                      |
| 15.0     | ĸw   | 0x5000             | osc counter[15:0]               |

#### PMU OSC CNT\_HI

Address: Operational Base + offset (0x0078)

| Bit   | Attr | <b>Reset Value</b> | Description                     |
|-------|------|--------------------|---------------------------------|
| 21.10 | RW   | 0x0000             | write_mask                      |
| 31:10 |      |                    | 16 bits write mask for lsb 15-0 |
| 15:4  | RO   | 0x0                | reserved                        |
| 2.0   | RW   | $W = 0 \times 0$   | osc_cnt_hi                      |
| 3:0   |      |                    | osc counter[19:16]              |

#### PMU PLLLOCK CNT LO

Address: Operational Base + offset (0x007c)

| Bit      | Attr | <b>Reset Value</b> | Description                     |
|----------|------|--------------------|---------------------------------|
| 31:16 RW |      | 0x0000             | write_mask                      |
| 51.10    | K VV |                    | 16 bits write mask for lsb 15-0 |
| 15.0     | DW   | 0vEde0             | plllock_cnt_lo                  |
| 15:0     | RW   | W 0x5dc0           | plllock counter[15:0]           |

# PMU PLLLOCK CNT HI

Address: Operational Base + offset (0x0080)

| Bit   | Attr | <b>Reset Value</b> | Description                     |
|-------|------|--------------------|---------------------------------|
| 21.10 | עעם  | 0x0000             | write_mask                      |
| 31:10 | RW   |                    | 16 bits write mask for lsb 15-0 |
| 15:4  | RO   | 0x0                | reserved                        |
|       | RW   | W DYO              | plllock_cnt_hi                  |
| 3:0   |      |                    | plllock counter[19:16]          |

#### PMU DDRIO PWRON CNT LO

Address: Operational Base + offset (0x0094)

| Bit   | Attr | <b>Reset Value</b> | Description                               |
|-------|------|--------------------|-------------------------------------------|
| 21.16 | DW   | 0x0000             | write_mask                                |
| 51.10 | RW   |                    | 16 bits write mask for lsb 15-0           |
| 1     |      |                    | ddrio_powerup_cnt_lo                      |
| 15:0  | RW   | W 0x5dc0           | ddrio power up waiting time counter[15:0] |

# PMU DDRIO PWRON CNT HI

Address: Operational Base + offset (0x0098)

| Bit   | Attr | <b>Reset Value</b> | Description                                                        |
|-------|------|--------------------|--------------------------------------------------------------------|
| 21.16 | RW   | 0x0000             | write_mask                                                         |
| 31:10 |      |                    | 16 bits write mask for lsb 15-0                                    |
| 15:4  | RO   | 0x0                | reserved                                                           |
| 3:0   | RW   | 0x0                | ddrio_powerup_cnt_hi<br>ddrio power up waiting time counter[19:16] |

# PMU\_DDR\_SREF\_ST

Address: Operational Base + offset (0x00a4)

| Bit  | Attr | <b>Reset Value</b> | Description                           |
|------|------|--------------------|---------------------------------------|
| 31:2 | RO   | 0x0                | reserved                              |
|      |      |                    | upctl_c_sysack                        |
|      |      |                    | upctl c_sysack status, same with      |
| 1    | RO   | 0x1                | GRF.GRF_UPCTL_STATUS0.upctrl_c_sysack |
|      |      |                    | 1'b0: acknowledge                     |
|      |      |                    | 1'b1: no acknowledge                  |
|      |      |                    | upctl_c_active                        |
|      |      |                    | upctl c_active status, same with      |
| 0    | RO   | 0x1                | GRF.GRF_UPCTL_STATUS0.upctrl_c_active |
|      |      |                    | 1'b0: enter the self-refresh          |
|      |      |                    | 1'b1: not enter the self-refresh      |

# PMU\_SYS\_REG0\_LO

Address: Operational Base + offset (0x00a8)

| Bit   | Attr | <b>Reset Value</b> | Description                |
|-------|------|--------------------|----------------------------|
| 21.10 | RW   | 0x0000             | write_mask                 |
| 51.10 |      |                    | 16 bits write mask for lsb |
| 15.0  | RW   |                    | pmu_sys_reg0_lo            |
| 15:0  |      |                    | pmu system register0[15:0] |

# PMU\_SYS\_REG0\_HI

Address: Operational Base + offset (0x00ac)

| Bit   | Attr | <b>Reset Value</b> | Description                 |
|-------|------|--------------------|-----------------------------|
| 21.10 | RW   | 0x0000             | write_mask                  |
| 51:10 |      |                    | 16 bits write mask for lsb  |
| 15.0  | RW   |                    | pmu_sys_reg0_hi             |
| 15:0  |      |                    | pmu system register0[31:16] |

# PMU SYS REG1 LO

Address: Operational Base + offset (0x00b0)

| Bit   | Attr | <b>Reset Value</b> | Description                                   |
|-------|------|--------------------|-----------------------------------------------|
| 31:16 | RW   | 0x0000             | write_mask<br>16 bits write mask for Isb      |
| 15:0  | RW   | 0x0000             | pmu_sys_reg1_lo<br>pmu system register1[15:0] |

# PMU\_SYS\_REG1\_HI

Address: Operational Base + offset (0x00b4)

| Bit   | Attr | <b>Reset Value</b> | Description                 |
|-------|------|--------------------|-----------------------------|
| 31:16 | RW   | 10x0000            | write_mask                  |
|       |      |                    | 16 bits write mask for lsb  |
| 15.0  | RW   | W 10X0000          | pmu_sys_reg1_hi             |
| 15:0  |      |                    | pmu system register1[31:16] |

# PMU\_SYS\_REG2\_LO

Address: Operational Base + offset (0x00b8)

| Bit   | Attr | <b>Reset Value</b> | Description                |
|-------|------|--------------------|----------------------------|
| 21.10 | RW   | 0x0000             | write_mask                 |
| 51.10 |      |                    | 16 bits write mask for lsb |
| 15.0  | RW   | W 10x0000          | pmu_sys_reg2_lo            |
| 15:0  |      |                    | pmu system register2[15:0] |

# PMU SYS REG2 HI

Address: Operational Base + offset (0x00bc)

| Bit   | Attr | <b>Reset Value</b> | Description                 |
|-------|------|--------------------|-----------------------------|
| 21.10 | RW   | 0x0000             | write_mask                  |
| 51.10 |      |                    | 16 bits write mask for lsb  |
| 15.0  | RW   | W 0.0000           | pmu_sys_reg2_hi             |
| 15:0  |      | 0x0000             | pmu system register2[31:16] |

#### PMU\_SYS\_REG3\_LO

Address: Operational Base + offset (0x00c0)

| Bit   | Attr | <b>Reset Value</b> | Description                |
|-------|------|--------------------|----------------------------|
| 21.10 | RW   | 0x0000             | write_mask                 |
| 51.10 |      |                    | 16 bits write mask for lsb |
| 15.0  | RW   | W 10x0000          | pmu_sys_reg3_lo            |
| 15:0  |      |                    | pmu system register3[15:0] |

#### PMU\_SYS\_REG3\_HI

Address: Operational Base + offset (0x00c4)

| Bit   | Attr | <b>Reset Value</b> | Description                 |
|-------|------|--------------------|-----------------------------|
| 21.10 | RW   | 10x0000            | write_mask                  |
| 51.10 |      |                    | 16 bits write mask for lsb  |
| 15.0  | RW   | W 10x0000          | pmu_sys_reg3_hi             |
| 15:0  |      |                    | pmu system register3[31:16] |

#### PMU CORE PWRDN CNT LO

Address: Operational Base + offset (0x00c8)

| Bit   | Attr | <b>Reset Value</b> | Description                      |
|-------|------|--------------------|----------------------------------|
| 21.16 | RW   | 10x0000            | write_mask                       |
| 51.10 |      |                    | 16 bits write mask for lsb 15-0  |
| 15:0  | RW   | 2W 10x5dc0         | pmu_core_pwrdn_cnt_lo            |
| 15:0  |      |                    | vd_core power down counter[15:0] |

# PMU CORE PWRDN CNT HI

Address: Operational Base + offset (0x00cc)

| Bit   | Attr | <b>Reset Value</b> | Description                       |
|-------|------|--------------------|-----------------------------------|
| 21.10 | RW   | 0x0000             | write_mask                        |
| 31:10 |      |                    | 16 bits write mask for lsb 15-0   |
| 15:4  | RO   | 0x0                | reserved                          |
| 2.0   | RW   | 2W IOXO I          | pmu_core_pwrdn_cnt_hi             |
| 3:0   |      |                    | vd_core power down counter[19:16] |

# PMU CORE PWRUP CNT LO

Address: Operational Base + offset (0x00d0)

| Bit   | Attr | <b>Reset Value</b> | Description                     |
|-------|------|--------------------|---------------------------------|
| 21.10 | RW   | 10x0000            | write_mask                      |
| 51:10 |      |                    | 16 bits write mask for lsb 15-0 |
| 15.0  | RW   | W 0x5dc0           | pmu_core_pwrdn_cnt_lo           |
| 15:0  |      | RW                 |                                 |

# PMU CORE PWRUP CNT HI

Address: Operational Base + offset (0x00d4)

| Bit   | Attr       | <b>Reset Value</b> | Description                     |  |
|-------|------------|--------------------|---------------------------------|--|
| 21.16 | write_mask |                    | write_mask                      |  |
| 31:16 | RVV        | 0x0000             | 16 bits write mask for lsb 15-0 |  |
| 15:4  | RO         | 0x0                | reserved                        |  |
| 2.0   | עע         |                    | pmu_core_pwrdn_cnt_hi           |  |
| 3:0   | RW         |                    | vd_core power up counter[19:16] |  |

# PMU TIMEOUT CNT LO

Address: Operational Base + offset (0x00d8)

| Bit   | Attr | <b>Reset Value</b>                               | Description                     |  |
|-------|------|--------------------------------------------------|---------------------------------|--|
| 31:16 |      | 0x0000                                           | write_mask                      |  |
| 51.10 | ĸvv  | 0x0000                                           | 16 bits write mask for lsb 15-0 |  |
| 15.0  |      | W 0x5dc0 pmu_timeout_cnt_lo<br>timeout_cnt[15:0] | pmu_timeout_cnt_lo              |  |
| 15:0  | RW   |                                                  | timeout_cnt[15:0]               |  |

# PMU TIMEOUT CNT HI

Address: Operational Base + offset (0x00dc)

| Bit   | Attr | <b>Reset Value</b> | Description                     |  |
|-------|------|--------------------|---------------------------------|--|
| 21.10 |      | 0x0000             | write_mask                      |  |
| 31:16 | RW   | 00000              | 16 bits write mask for lsb 15-0 |  |
| 15:4  | RO   | 0x0                | reserved                        |  |
| 2.0   |      | RW IOXO            | pmu_timeout_cnt_hi              |  |
| 3:0   | KW   |                    | timeout_cnt[19:16]              |  |

#### PMU CPU0APM CON

Address: Operational Base + offset (0x00e0)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.10 |      | 0.0000             | write_mask                             |
| 31:16 | RW   | 0x0000             | 16 bits write mask for lsb 15-0        |
| 15:4  | RO   | 0x0                | reserved                               |
|       |      |                    | cpu0_sft_wakeup                        |
| 2     |      | 0.40               | software wakeup for cpu0:              |
| 3     | RW   | RW 0x0             | 1'b0: not issue the software wakeup    |
|       |      |                    | 1'b1: issue the software wakeup        |
|       |      | 0×0                | global_int_disable0_cfg                |
| 2     | RW   |                    | global interrupt disable for cpu0:     |
| 2     | K VV |                    | 1'b0: not disable the interrupt        |
|       |      |                    | 1'b1: disable the interrupt            |
|       |      |                    | pd_cpu0_int_wakeup_en                  |
| 1     | RW   | 0x0                | 1'b0: pd_cpu0 interrupt wakeup disable |
|       |      |                    | 1'b1: pd_cpu0 interrupt wakeup enable  |
|       |      |                    | pd_cpu0_wfi_pwrdn_en                   |
| 0     | RW   | N 0x0              | 1'b0: pd_cpu0 wfi power down disable   |
|       |      |                    | 1'b1: pd_cpu0 wfi power down enable    |

#### PMU CPU1APM CON

Address: Operational Base + offset (0x00e4)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 31:16 | DW   | 0,40000            | write_mask                             |
| 51.10 | RVV  | 0x0000             | 16 bits write mask for lsb 15-0        |
| 15:4  | RO   | 0x0                | reserved                               |
|       |      |                    | cpu1_sft_wakeup                        |
| 3     | RW   | 0x0                | software wakeup for cpu1:              |
| 2     | ĸw   | 0.00               | 1'b0: not issue the software wakeup    |
|       |      |                    | 1'b1: issue the software wakeup        |
|       |      | / 0×0              | global_int_disable1_cfg                |
| 2     | RW   |                    | global interrupt disable for cpu1:     |
| Z     |      |                    | 1'b0: not disable the interrupt        |
|       |      |                    | 1'b1: disable the interrupt            |
|       |      |                    | pd_cpu1_int_wakeup_en                  |
| 1     | RW   | 0x0                | 1'b0: pd_cpu1 interrupt wakeup disable |
|       |      |                    | 1'b1: pd_cpu1 interrupt wakeup enable  |
|       |      | V 0×0              | pd_cpu1_wfi_pwrdn_en                   |
| 0     | RW   |                    | 1'b0: pd_cpu1 wfi power down disable   |
|       |      |                    | 1'b1: pd_cpu1 wfi power down enable    |

#### PMU\_CPU2APM\_CON

Address: Operational Base + offset (0x00e8)

| Bit   | Attr | <b>Reset Value</b>                                                                                                      | Description                                                                                                                     |  |
|-------|------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--|
| 31:16 | RW   | 0x0000                                                                                                                  | write_mask<br>16 bits write mask for lsb 15-0                                                                                   |  |
| 15:4  | RO   | 0x0                                                                                                                     | reserved                                                                                                                        |  |
| 3     | RW   | 0x0                                                                                                                     | cpu2_sft_wakeup<br>software wakeup for cpu2:<br>1'b0: not issue the software wakeup<br>1'b1: issue the software wakeup          |  |
| 2     | RW   | 0×0                                                                                                                     | global_int_disable2_cfg<br>global interrupt disable for cpu2:<br>1'b0: not disable the interrupt<br>1'b1: disable the interrupt |  |
| 1     | RW   | pd_cpu2_int_wakeup_en0x01'b0: pd_cpu2 interrupt wakeup disable1'b1: pd_cpu2 interrupt wakeup enable                     |                                                                                                                                 |  |
| 0     | RW   | 0x0       pd_cpu2_wfi_pwrdn_en         1'b0: pd_cpu2 wfi power down disable         1'b1: pd_cpu2 wfi power down enable |                                                                                                                                 |  |

# PMU CPU3APM CON

Address: Operational Base + offset (0x00ec)

| Bit   | Attr | Reset Value | Description                            |
|-------|------|-------------|----------------------------------------|
| 31:16 | RW   | 0x0000      | write_mask                             |
| 51.10 | 1    | 0,0000      | 16 bits write mask for lsb 15-0        |
| 15:4  | RO   | 0x0         | reserved                               |
|       |      |             | cpu3_sft_wakeup                        |
| 3     | RW   | 0x0         | software wakeup for cpu3:              |
| 5     | L AN | 0.00        | 1'b0: not issue the software wakeup    |
|       |      |             | 1'b1: issue the software wakeup        |
|       | RW   | V 0×0       | global_int_disable3_cfg                |
| 2     |      |             | global interrupt disable for cpu3:     |
| 2     | L AN |             | 1'b0: not disable the interrupt        |
|       |      |             | 1'b1: disable the interrupt            |
|       |      |             | pd_cpu3_int_wakeup_en                  |
| 1     | RW   | 0x0         | 1'b0: pd_cpu3 interrupt wakeup disable |
|       |      |             | 1'b1: pd_cpu3 interrupt wakeup enable  |
|       |      |             | pd_cpu3_wfi_pwrdn_en                   |
| 0     | RW   | W 0x0       | 1'b0: pd_cpu3 wfi power down disable   |
|       |      |             | 1'b1: pd_cpu3 wfi power down enable    |

# PMU\_INFO\_TX\_CON

Address: Operational Base + offset (0x00f0)

| Bit      | Attr | <b>Reset Value</b>  | Description                       |  |
|----------|------|---------------------|-----------------------------------|--|
| 31:16 RW |      |                     | write_mask                        |  |
| 51.10    | RW   | 00000               | 16 bits write mask for lsb 15-0   |  |
| 1 5.0    |      | $RW = 0 \times 0 0$ | pmu_info_tx_intv_time             |  |
| 15:8     | RW   |                     | pmu informations transmit counter |  |

| Bit   | Attr | <b>Reset Value</b> | Description                             |  |
|-------|------|--------------------|-----------------------------------------|--|
| 7     | RO   | 0x0                | reserved                                |  |
|       |      |                    | pmu_info_tx_byte_con                    |  |
| C . A |      | 0.40               | pmu informations selection              |  |
| 6:4   | RW   | 0×0                | 3'b000: info_tx_byte = power_state      |  |
|       |      |                    | other: reserved                         |  |
| 3:1   | RO   | 0x0                | reserved                                |  |
|       |      |                    | pmu_info_tx_en                          |  |
| 0     |      |                    | pmu informations transmit output enable |  |
| 0     | RW   |                    | 1'b0: disable                           |  |
|       |      |                    | 1'b1: enable                            |  |

# 11.5 Timing Diagram

# 11.5.1 Each domain power switch timing

The following figure is the each domain power down and power up timing.



Fig. 11-3 Each Domain Power Switch Timing

# 11.5.2 External wakeup PAD timing

The PMU supports a lot of external wakeup sources, such as SD/MMDC, USBDEV and so on. All these external wakeup sources must meet the timing requirement (at least 200us) when the wakeup event is asserted. The following figure gives the timing information.



Fig. 11-4 External Wakeup Source PAD Timing

# **11.6 Application Note**

# **11.6.1** Low power mode

PMU can work in the Low power mode by setting bit[0] of PMU\_PWRMODE\_CON register. After setting this bit and all CPU cores enters WFI states, PMU low power FSM will start to run. In the low power mode, PMU will manage power resources by hardware, such as power on/off the specified power domain, send idle request to specified power domain, shut down/up PLL and so on. All of above are configurable by setting corresponding registers. ALL FSM power states could be monitored through IO. The following table describes all power states of PMU FSM.

| 1   |                       | le 11-2 Low Power State                                                   |
|-----|-----------------------|---------------------------------------------------------------------------|
| Num | STATES                | Description                                                               |
| 0   | ST_NORMAL             | Still in normal state                                                     |
| 1   | ST_CPU0_PWRDN         | Power down cpu core 0                                                     |
| 2   | ST_L2_FLUSH           | Flush L2                                                                  |
| 3   | ST_L2_IDLE            | L2 Idle                                                                   |
| 4   | ST_TRANS_NO_FIN_CORE  | wait for buses in vd_core idle                                            |
| 5   | ST_SCU_PWRDN          | <pre>power down vd_core(not really remove power, assert reset only)</pre> |
| 6   | ST_CORE_CLK_DIS       | clock gating core clock                                                   |
| 7   | ST_TRANS_NO_FIN_BUS   | wait for buses in vd_logic idle                                           |
| 8   | ST_SREF_ENTER         | DDR enter self-refresh                                                    |
| 9   | ST_DDR_IO_RET         | DDR IO retention                                                          |
| 10  | ST_DDR_IO_PWROFF      | NOT USED                                                                  |
| 11  | ST_CLK_LF             | Vd_logic clock switch to low frequency                                    |
| 12  | ST_PLL_PWRDN          | power down PLL                                                            |
| 13  | ST_24M_OSC_DIS        | disable 24M OSC                                                           |
| 14  | ST_WAIT_WAKEUP        | wait for wakeup                                                           |
| 15  | ST_24M_OSC_EN         | enable 24M OSC                                                            |
| 16  | ST_PMU_HF             | pmu clock switch to high frequency                                        |
| 17  | ST_PLL_PWRUP          | power up PLL                                                              |
| 18  | ST_CLK_HF             | Vd_logic clock switch to high frequency                                   |
| 19  | ST_DDR_IO_PWRUP       | NOT USED                                                                  |
| 20  | ST_SREF_EXIT          | DDR exit self-refresh                                                     |
| 21  | ST_TRANS_RESTORE_BUS  | release idle request to vd_logic bus                                      |
| 22  | ST_CORE_CLK_EN        | Enable core clock                                                         |
| 23  | ST_SCU_PWRUP          | power up vd_core(de-assert reset)                                         |
| 24  | ST_TRANS_RESTORE_CORE | release idle request to vd_core                                           |
| 25  | ST_CPU0_PWRUP         | Power up CPU core 0                                                       |

# Table 11-2 Low Power State

# 11.6.2 Debug IO

RK3308 provide PMU Debug IO for FSM observation. Each IO maps to the correspond bit of the PMU\_POWER\_ST register.

| Module Pin         | Direction | Pin Name                          | IOMUX Setting                                               |
|--------------------|-----------|-----------------------------------|-------------------------------------------------------------|
| power_state<br>[0] | 0         | GPIO4_D0/SDMMC_D0                 | GRF_SOC_CON2[15]=1'b1 &<br>GRF_GPIO4D_IOMUX[1:0] =<br>2'b00 |
| power_state<br>[1] | 0         | GPIO4_D1/SDMMC_D1                 | GRF_SOC_CON2[15]=1'b1 &<br>GRF_GPIO4D_IOMUX[3:2] =<br>2'b00 |
| power_state<br>[2] | 0         | GPIO4_D2/SDMMC_D2/UART<br>2_RX_M1 | GRF_SOC_CON2[15]=1'b1 &<br>GRF_GPIO4D_IOMUX[5:4] =<br>2'b00 |

| Module Pin         | Direction | Pin Name                          | IOMUX Setting                                                 |
|--------------------|-----------|-----------------------------------|---------------------------------------------------------------|
| power_state<br>[3] | 0         | GPIO4_D3/SDMMC_D3/UART<br>2_TX_M1 | GRF_SOC_CON2[15]=1'b1 &<br>GRF_GPIO4D_IOMUX[7:6] =<br>2'b00   |
| power_state<br>[4] | 0         | GPIO4_D4/SDMMC_CMD                | GRF_SOC_CON2[15]=1'b1 &<br>GRF_GPIO4D_IOMUX[9:8] =<br>2'b00   |
| debug_Sout         | 0         | GPIO4_D5/SDMMC_CLK                | GRF_SOC_CON1[15]=1'b1 &<br>GRF_GPIO4D_IOMUX[11:10] =<br>2'b00 |

Another way, RK3308 provided the serial output by the debug\_sout for FSM observation by setting the bit[0] of PMU\_INFO\_TX\_CON register. Once the bit was set to "1", pmu will sent the serial signal as the following timing diagram.



Fig. 11-5 PMU Info TX Timing

Start\_bit: always is "10";

Power\_state: shown the current power state of pmu FSM End\_bit: pmu\_info\_tx\_intv\_time + 2

# 11.6.3 Clock Switch

When the system work in the low power mode, some modules (including GPIO, DETECT\_GRF, GIC, TIMER, PMU) should still work to generate the wakeup sources. The bus clocks and working clocks of these modules can be switch to low speed frequency (24MHz or 32KHz) by the PMU FSM.

There is two bits for switching to 24MHz or 32KHz in the

PMU\_PWRMODE\_COMMON\_CON\_LO register.

If\_24m: bit[3], switch to 24MHz;

If\_32K: bit[4], switch to 32KHz;

There is only one bit can been set in the low power mode.

For example, if the lf\_24m was set to "1", the following clocks will be switched to 24MHz: pclk\_gpio, pclk\_detect\_grf, aclk\_gic, pclk\_timer, pclk\_pmu.

Note: the high speed frequency of clk\_pmu is 24MHz, so it only can be switched to 32KHz.

# **11.6.4** Power Mode Control Registers and Sft Control Registers

There are two types registers: PMU\_PWRMODE\_COMMON\_CON\_x and PMU\_SFT\_CON\_x to control the same function, for example pll on/off, ddr self-refresh. The PMU\_PWRMODE\_COMMON\_CON\_X register in valid only in the pmu low power mode, and the PMU\_SFT\_CON\_x register will take effect as soon as the register it set. The following figure shows the structure of the two types registers:



Fig. 11-6 PMU Control Register Relationship

# Chapter 12 NAND Flash Controller (NANDC)

# 12.1 Overview

NAND Flash Controller (NANDC) is used to control data transmission from host to NAND Flash device or from NAND Flash device to host. NANDC is connected to AHB BUS through an AHB Master and an AHB Slave. The data transmission between host and external memory can be done through AHB Master interface or AHB Slave interface.

NANDC supports the following features:

- Software Interface Type
  - Support directly mode
- Flash Interface Type
  - Support Asynchronous Flash Interface with 8bits data width ("Asyn8x" for short)
  - Support 1 NAND Flash devices(1 chip select)
- Flash Type
  - Support SLC Flash
    - Flash Interface Timing
  - Asyn8x: configurable timing
- BCH/ECC Ability
  - 16bit/1KB BCH/ECC: support 16bit BCH/ECC, which can detect and correct up to 16 error bits in every 1K bytes data and 4 bytes meta-data
- Transmission Ability
  - Support 32K bytes data transmission at a time at most
  - Support two transfer working modes: Bypass or DMA
- Internal Memory
  - 2 built-in SRAMs, and the size is 1k bytes respectively
  - Can be accessed by other masters
  - Can be operated in Ping-Pong mode by other masters
- FIFO Mode
  - One built-in FIFO with 32 bits wide and 8 depth
  - Store command, address and data temporarily that are intend to write to the external NAND Flash

# 12.2 Block Diagram

NANDC comprises with:

- MIF: AHB Master Interface
- SIF: AHB Slave Interface
- SRIF: SRAM Interface
- TRANSC: Transfer Controller
- BCHENC: BCH Encoder
- BCHDEC: BCH Decoder
- FIF\_GEN: Flash Interface Generation



Fig. 12-1 NANDC Block Diagram

# **12.3 Function Description**

# 12.3.1 AHB Interface

There is an AHB master interface in NANDC, which is selectable and configurable. It is responsible for transferring data from external memory to internal memory when NAND Flash program, or inverse when NAND Flash read.

There is an AHB slave interface in NANDC. It is responsible for accessing registers and internal memories. The addresses of these registers and memories are listed in Register Description section.

# 12.3.2 Flash Type/Flash Interface

The NAND Flash controller supports asynchronous 8bits NAND Flash interface. You can use it by software (configure FMCTL) to suit for devices. Also you can configure their timing parameters by software (configure FMWAIT\_ASYN) to have your desired rate.

# 12.3.3 BCH Encoder/BCH Decoder

The BCH Encoder is responsible for encoding data to be written into NAND Flash device. The encoded length is 1056 bytes, in which the data length is 1024 bytes, system information (Meta-data) is 4 bytes, BCH code is 28 bytes.

The BCH Decoder is responsible for decoding data read from NAND Flash device. The decoded length is 1056 bytes, in which the data length is 1024 bytes, spare length is 32 bytes.

# **12.4 Register Description**

# 12.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

| Base Address[12:8] | Device | Address<br>Length | Offset Address Range |
|--------------------|--------|-------------------|----------------------|
| 5'b00_00x(x=0, 1)  | FLR    | 512 BYTE          | 0x0000 ~ 0x01ff      |
| 5'b00_01x(x=0, 1)  | SPR    | 512 BYTE          | 0x0200 ~ 0x03ff      |
| 5'b00_10x(x=0, 1)  | FLR1   | 512 BYTE          | 0x0400 ~ 0x05ff      |
| 5'b01_000          | Flash0 | 256 BYTE          | 0x0800 ~ 0x08ff      |
| 5'b10_0xx(x=0, 1)  | Sram0  | 1K BYTE           | 0x1000 ~ 0x13ff      |
| 5'b10_1xx(x=0, 1)  | Sram1  | 1K BYTE           | 0x1400 ~ 0x17ff      |
| 5'b11_000          | FIFO   | 1K BYTE           | 0x1800 ~ 0x1bff      |

Table 12-1 NANDC Address Mapping

# 12.4.2 Registers Summary

| Name                    | Offset | Size | Reset<br>Value | Description                                              |
|-------------------------|--------|------|----------------|----------------------------------------------------------|
| NANDC_FMCTL             | 0x0000 | W    | 0x00000600     | Flash Interface Control Register                         |
| NANDC FMWAIT ASYN       | 0x0004 | w    | 0x003ff7ff     | Flash Timing Control Register For<br>Asynchronous Timing |
| NANDC FLCTL             | 0x0008 | W    | 0x00100000     | Internal Transfer Control Register                       |
| NANDC BCHCTL            | 0x000c | W    | 0x0000008      | BCH Control Register                                     |
| NANDC_MTRANS_CFG        | 0x0010 | w    | 0x000001d0     | Bus Transfer Configuration<br>Register                   |
| NANDC MTRANS SADDR<br>0 | 0x0014 | w    | 0x0000000      | Start Address Register For Page<br>Data Transmission     |
| NANDC MTRANS SADDR<br>1 | 0x0018 | w    | 0x00000000     | Start Address Register For Spare<br>Data Transmission    |
| NANDC_MTRANS_STAT       | 0x001c | W    | 0x0000000      | Bus Transfer Status Register                             |
| NANDC BCHSTO            | 0x0020 | w    | 0x04000000     | BCH Status Register For<br>Codeword 0~1                  |
| NANDC BCHST1            | 0x0024 | w    | 0x00000000     | BCH Status Register For<br>Codeword 2~3                  |
| NANDC BCHST2            | 0x0028 | w    | 0×00000000     | BCH Status Register For<br>Codeword 4~5                  |
| NANDC_BCHST3            | 0x002c | w    | 0×00000000     | BCH Status Register For<br>Codeword 6~7                  |
| NANDC BCHST4            | 0x0030 | w    | 0×00000000     | BCH Status Register For<br>Codeword 8~9                  |
| NANDC BCHST5            | 0x0034 | w    | 0x00000000     | BCH Status Register For<br>Codeword 10~11                |
| NANDC BCHST6            | 0x0038 | w    | 0x00000000     | BCH Status Register For<br>Codeword 12~13                |
| NANDC BCHST7            | 0x003c | w    | 0x00000000     | BCH Status Register For<br>Codeword 14~15                |
| NANDC MTRANS STAT2      | 0x015c | W    | 0x0000000      | Bus Transfer Status Register2                            |
| NANDC_NANDC_VER         | 0x0160 | W    | 0x0000801      | NANDc Version Register                                   |
| NANDC INTEN             | 0x016c | W    | 0x00000000     | NANDC Interrupt Enable Register                          |
| NANDC_INTCLR            | 0x0170 | W    | 0x00000000     | NANDC Interrupt Clear Register                           |
| NANDC_INTST             | 0x0174 | W    | 0x00000000     | NANDC Interrupt Status Register                          |
| NANDC SPAREO 0          | 0x0200 | w    | 0xffffffff     | System Information For Codeword<br>0                     |
| NANDC SPARE1 0          | 0x0230 | w    | 0xffffffff     | System Information For Codeword<br>1                     |
| NANDC BCHST8            | 0x0520 | w    | 0x00000000     | BCH Status Register For<br>Codeword 16~17                |
| NANDC_BCHST9            | 0x0524 | w    | 0x00000000     | BCH Status Register For<br>Codeword 18~19                |

\_\_\_\_\_

| NANDC BCHST10     | 0x0528 | w   | 0x00000000    | BCH Status Register For<br>Codeword 20~21 |
|-------------------|--------|-----|---------------|-------------------------------------------|
| NANDC BCHST11     | 0x052c | w   | 0x00000000    | BCH Status Register For                   |
|                   | 0,0520 |     |               | Codeword 22~23                            |
| NANDC BCHST12     | 0x0530 | w   | 0x00000000    | BCH Status Register For                   |
| NANDC_DCH3112     | 0x0330 | vv  | 0x00000000    | Codeword 24~25                            |
|                   | 0x0534 | w   | 0x00000000    | BCH Status Register For                   |
| NANDC BCHST13     |        |     |               | Codeword 26~27                            |
| NANDE RELETIA     | 0,0520 | w   | 0x00000000    | BCH Status Register For                   |
| NANDC BCHST14     | 0x0538 |     |               | Codeword 28~29                            |
|                   | 0x053c | \\/ | 0,000,000,000 | BCH Status Register For                   |
| NANDC BCHST15     | 0x055C | W   | 0x00000000    | Codeword 30~31                            |
| NANDC_FLASH0_DATA | 0x0800 | W   | 0x00000000    | Flash0 Data                               |
| NANDC_FLASH0_ADDR | 0x0804 | W   | 0x00000000    | Flash0 Address                            |
| NANDC FLASH0 CMD  | 0x0808 | W   | 0x00000000    | Command Send To Flash0                    |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# 12.4.3 Detail Register Description NANDC\_FMCTL

Address: Operational Base + offset (0x0000)

| Bit   | Attr  | <b>Reset Value</b> | Description                                                    |    |      |    |      |          |
|-------|-------|--------------------|----------------------------------------------------------------|----|------|----|------|----------|
| 31:27 | RO    | 0x0                | reserved                                                       |    |      |    |      |          |
|       |       |                    | read_delay                                                     |    |      |    |      |          |
| 26:24 | RW    | 0x0                | The number of delay cycle to capture the NAND Flash data after |    |      |    |      |          |
|       |       |                    | posedge of rdn.                                                |    |      |    |      |          |
| 23:18 | RO    | 0x0                | reserved                                                       |    |      |    |      |          |
| 17    | RO    | 0x0                | flash_abort_stat                                               |    |      |    |      |          |
| 17    | ĸŬ    | 0.00               | reserved                                                       |    |      |    |      |          |
| 16    | RW    | 0x0                | flash_abort_en                                                 |    |      |    |      |          |
| 10    | RVV   | RVV                | RVV                                                            | RW | K VV | RW | 0.00 | reserved |
| 15    | RW    | N 0x0              | syn_mode                                                       |    |      |    |      |          |
| 13    |       |                    | reserved                                                       |    |      |    |      |          |
| 14    | RW    | 0×0                | syn_clken                                                      |    |      |    |      |          |
| 14    |       |                    | reserved                                                       |    |      |    |      |          |
|       |       |                    | tm                                                             |    |      |    |      |          |
| 13    | RW    | 0x0                | Timing mode indication.                                        |    |      |    |      |          |
| 13    |       | 0.00               | 1'b0: Asynchronous Mode.                                       |    |      |    |      |          |
|       |       |                    | 1'b1: reserved                                                 |    |      |    |      |          |
|       |       |                    | dwidth                                                         |    |      |    |      |          |
|       | 12 RW |                    | Flash data bus width indication.                               |    |      |    |      |          |
| 12    |       | W 0x0              | 1'b0: 8bits, active in both Asynchronous Mode flash and        |    |      |    |      |          |
|       |       |                    | Synchronous Mode flash.                                        |    |      |    |      |          |
|       |       |                    | 1'b1: 16bits, active only in Asynchronous Mode flash.          |    |      |    |      |          |
| 11    | RO    | 0x0                | reserved                                                       |    |      |    |      |          |

| Bit | Attr | <b>Reset Value</b> | Description                                   |
|-----|------|--------------------|-----------------------------------------------|
|     |      |                    | fifo_empty                                    |
| 10  | RW   | 0x1                | fifo empty signal.                            |
| 10  | RVV  | UXI                | 1'b0: fifo is not empty;                      |
|     |      |                    | 1'b1: fifo is emtpy;                          |
|     |      |                    | frdy                                          |
|     |      |                    | Flash ready/busy indicate signal.             |
| 9   | RO   | 0×1                | 1'b0: flash is busy.                          |
|     |      |                    | 1'b1: flash is ready.                         |
|     |      |                    | This bit is the sample of the pin of R/Bn.    |
|     |      | RW 0×0             | wp                                            |
|     |      |                    | Flash write protect.                          |
| 8   | RW   |                    | 1'b0: flash program/erase disabled.           |
|     |      |                    | 1'b1: flash program/erase enabled.            |
|     |      |                    | This bit is output to the pin of WPn.         |
| 7:1 | RO   | 0x0                | reserved                                      |
|     |      |                    | fcs0                                          |
| 0   | RW   |                    | Flash memory chip 0 select control.           |
| 0   | K VV |                    | 1'b1: hold flash memory chip select activity. |
|     |      |                    | 1'b0: flash memory chip select activity free. |

# NANDC FMWAIT ASYN

Address: Operational Base + offset (0x0004)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                        |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23 | RO   | 0x0                | reserved                                                                                                                                                                                           |
| 22:18 | RW   | 0x0f               | wait_frdy_dly<br>The number of delay cycle to accept the flash ready signal.                                                                                                                       |
| 17:12 | RW   | 0x3f               | csrw<br>When in Asynchronous mode, this field specifies the number of<br>processor clock cycles from the falling edge of CSn to the falling<br>edge of RDn or WRn. The min value of csrw is 0.     |
| 11    | RW   | 0×0                | hard_rdy<br>Hardware handshaking controller bit.<br>When asserted, an external device asserts signal "RDY" to extend<br>a wait-state access and the rest bits in this register will be<br>ignored. |
| 10:5  | RW   | 0x3f               | rwpw<br>When in Asynchronous mode, this field specifies the width of RDn<br>or WRn in processor clock cycles, 0x0<=rwpw<=0x3f.                                                                     |
| 4:0   | RW   | 0x1f               | rwcs<br>When in Asynchronous mode, this field specifies the number of<br>processor clock cycles from the rising edge of RDn or WRn to the<br>rising edge of CSn, 0x0<=rwcs<=0x1f.                  |

# NANDC FLCTL

# Address: Operational Base + offset (0x0008)

| Bit   | Attr  | <b>Reset Value</b> | Description                                                      |
|-------|-------|--------------------|------------------------------------------------------------------|
| 31    | RO    | 0x0                | reserved                                                         |
|       |       |                    | bypass_fifo_mode                                                 |
| 20    |       | 0.40               | The enable sigal for bypass with fifo mode.                      |
| 30    | RW    | 0x0                | 1'b0: disable fifo mode                                          |
|       |       |                    | 1'b1: enable fifo mode                                           |
| 29    | RO    | 0x0                | reserved                                                         |
|       |       |                    | low_power                                                        |
| 28    | RW    | 0x0                | NANDc low power control                                          |
| 20    | ĸw    | 0.00               | 1'b0: normal mode                                                |
|       |       |                    | 1'b1: low power mode                                             |
|       |       |                    | page_num                                                         |
|       |       |                    | Transmission codeword number in internal DMA mode when bus-      |
|       |       |                    | mode is master-mode                                              |
| 27:22 | D\//  | 0x00               | 1~32: 1~32 codeword.                                             |
| 27.22 | L A A | 0,00               | default: not support.                                            |
|       |       |                    | Notes:                                                           |
|       |       |                    | a. Only active in internal DMA mode                              |
|       |       |                    | b. Only active when bus-mode is master-mode                      |
|       |       | / 0×0              | page_size                                                        |
| 21    | RW    |                    | Transmission codeword size in internal DMA mode                  |
| ~ 1   |       | 0,0                | 1'b0: 1024bytes/codeword                                         |
|       |       |                    | 1'b1: reserved                                                   |
|       |       |                    | tr_rdy                                                           |
|       |       |                    | Internal DMA transmission ready indication.                      |
|       |       |                    | 1'b0: internal DMA transmission is busy                          |
|       |       |                    | 1'b1: internal DMA transmission is ready                         |
| 20    | RO    | 0x1                | When reading flash, tr_rdy should not be set to 1 until all data |
| _     |       | -                  | transmission and correct finished.                               |
|       |       |                    | When programming flash, tr_rdy should not be set to 1 until all  |
|       |       |                    | data transmission finished.                                      |
|       |       |                    | Notes:                                                           |
|       |       |                    | Only active in internal DMA mode.                                |
| 19:12 | кO    | 0x0                | reserved                                                         |
|       |       |                    | Iba_en                                                           |
|       |       |                    | LBA mode indication, 1 active.                                   |
| 1 1   |       |                    | 1'b0: NO-LBA mode, NANDC should transfer both page data and      |
| 11    | RW    | 0x0                | spare data in every codeword, and the page size is 1024 bytes or |
|       |       |                    | 512 bytes determined by BCHCTL[16](bchpage), spare size is 32    |
|       |       |                    | if bchmode=2'b00.                                                |
|       |       |                    | 1'b1: reserved                                                   |

| Bit | Attr | Reset Value | Description                                                       |
|-----|------|-------------|-------------------------------------------------------------------|
|     |      |             | cor_able                                                          |
|     |      |             | Auto correct enable indication, 1 active.                         |
|     |      |             | 1'b0: auto correct disable                                        |
| 10  | RW   | 0x0         | 1'b1: auto correct enable                                         |
| 10  |      | UNU         | Notes:                                                            |
|     |      |             | a. Only active in internal DMA mode.                              |
|     |      |             | b. lba_en is prior to cor_able. When lba_en=1, cor_able is        |
|     |      |             | ignored.                                                          |
| 9:8 | RO   | 0x0         | reserved                                                          |
|     |      |             | flash_st_mod                                                      |
|     |      |             | Mode for NANDC to start internal data transmission in internal    |
|     |      |             | DMA mode.                                                         |
|     |      |             | 1'b0: busy mode: hardware should not start internal data          |
| 7   | RW   | 0x0         | transmission until flash is ready even flash_st is asserted.      |
|     |      |             | 1'b1: ready mode: hardware should start internal data             |
|     |      |             | transmission directly when flash_st is asserted.                  |
|     |      |             | Notes:                                                            |
|     |      |             | Only active in internal DMA mode.                                 |
|     |      |             | tr_count                                                          |
|     |      |             | Transmission codeword number in internal DMA mode when bus-       |
|     |      |             | mode is slave-mode                                                |
|     |      |             | 2'b00: 0 codeword need transferred                                |
|     |      |             | 2'b01: 1 codeword need transferred                                |
| 6:5 | RW   | 0×0         | 2'b10: 2 codeword need transferred                                |
|     |      |             | 2'b11: not supported                                              |
|     |      |             | Notes:                                                            |
|     |      |             | a. Only active in internal DMA mode.                              |
|     |      |             | b. Only active when bus-mode is slave-mode.                       |
|     |      |             | st_addr                                                           |
|     |      |             | Start buffer address.                                             |
|     |      |             | 1'b0: start transfer from sram0                                   |
| 4   | RW   | 0x0         | 1'b1: start transfer from sram1                                   |
|     |      |             | Notes:                                                            |
|     |      |             | Only active in internal DMA mode.                                 |
|     |      |             | bypass                                                            |
|     | RW   |             | NANDC internal DMA bypass indication.                             |
|     |      |             | 1'b0: bypass the internal DMA, data are transferred to/from flash |
| 3   |      | 0x0         | by direct path.                                                   |
|     |      |             | 1'b1: internal DMA active, data are transferred to/from flash by  |
|     |      |             | internal DMA.                                                     |
|     |      |             | וותכווומו טויוא.                                                  |

| Bit | Attr      | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                      |
|-----|-----------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | R/W<br>SC | 0×0                | flash_st<br>Start signal for NANDC to transfer data between flash and<br>internal buffer in internal DMA mode. When asserted, it will auto<br>cleared.<br>1'b0: not start transmission<br>1'b1: start transmission<br>Notes:<br>Only active in internal DMA mode |
| 1   | RW        | 0x0                | flash_rdn<br>Indicate data flow direction.<br>1'b0: NANDC read data from flash.<br>1'b1: NANDC write data to flash                                                                                                                                               |
| 0   | R/W<br>SC | 0×0                | flash_rst<br>NANDC software reset indication. When asserted, it will auto<br>cleared.<br>1'b0: not software reset<br>1'b1: software reset<br>Notes:<br>flash_rst is prior to flash_st                                                                            |

# NANDC\_BCHCTL

Address: Operational Base + offset (0x000c)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
| 31:29 | RO   | 0x0                | reserved                                              |
|       |      |                    | bch_toddr                                             |
| 28    | RW   | 0x0                | enable signal for storing bch decode status into ddr. |
| 20    | r vv | 0.00               | 1'b0: disable;                                        |
|       |      |                    | 1'b1: enable;                                         |
| 27    | RO   | 0x0                | reserved                                              |
| 26:19 | D\// | 0x00               | bchthres                                              |
| 20.19 |      | UXUU               | BCH error number threshold                            |
|       |      |                    | bchmode1                                              |
|       |      |                    | High bit of BCH mode selection.                       |
|       |      |                    | BchMode=bchmode1, bchmode0:                           |
| 18    | RW   |                    | 2'b00: 16bitBCH                                       |
|       |      |                    | 2'b01: reserved                                       |
|       |      |                    | 2'b10: reserved                                       |
|       |      |                    | 2'b11: reserved                                       |
| 17    | RO   | 0x0                | reserved                                              |

| Bit  | Attr      | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                             |
|------|-----------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | RW        | 0x0                | bchpage<br>The data size indication when BCH is active.<br>1'b0: 1024 bytes, all the 1024 bytes data in codeword are valid<br>data to be transferred.<br>1'b1: 512 bytes, higher 512bytes are valid, and lower 512bytes<br>are invalid and stuffed with 0xff.<br>Notes:<br>a. Only active when data transferred in internal DMA mode.<br>b. Only active for asynchronous flash.<br>addr |
| 15:8 | RW        | 0x00               | BCH active range selection.<br>BCH should be active when access in range address.                                                                                                                                                                                                                                                                                                       |
| 7:5  | RW        | 0×0                | region<br>BCH active region selection indication.<br>3'b000: Flash memory 0 region (flash 0)<br>3'b001: Flash memory 1 region (flash 1)<br>3'b010~3'b011: reserved                                                                                                                                                                                                                      |
| 4    | RW        | 0x0                | bchmode0<br>BCH mode selection indication.<br>BCH mode is determined by both bchmode0 and bchmode1,<br>detailed information is showed in BCHCTL[18].                                                                                                                                                                                                                                    |
| 3    | RW        | 0x1                | bchepd<br>BCH encoder/decoder power down indication.<br>1'b0: BCH encoder/decoder working.<br>1'b1: BCH encoder/decoder not working.                                                                                                                                                                                                                                                    |
| 2    | RW        | 0×0                | mode_addrcare<br>BCH address care mode selection indication.<br>1'b0: address care.<br>1'b1: address not care.<br>Notes:<br>This bit is just active for data transmission in bypass mode, but<br>not for command and address transmission.                                                                                                                                              |
| 1    | RO        | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 0    | R/W<br>SC | 0×0                | bchrst<br>BCH software reset indication, When asserted, it will auto<br>cleared.<br>1'b0: not software reset<br>1'b1: software reset<br>Notes:<br>a. BCH Decoder should be software reset before decode begin.<br>b. bch software reset should be used with NANDC software reset<br>at the same time.                                                                                   |

# NANDC MTRANS CFG

Address: Operational Base + offset (0x0010)

| Bit   | Attr         | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|--------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO           | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                               |
| 15    | 15 R/W<br>SC | ′ 0x0       | ahb_rst                                                                                                                                                                                                                                                                                                                                                                                                                |
| 12    |              | UXU         | ahb master interface software reset, auto cleared                                                                                                                                                                                                                                                                                                                                                                      |
| 14    | RW           | 0×0         | <ul> <li>fl_pwd</li> <li>Flash power down indication, 1 active.</li> <li>1'b0: Flash power on, data transferred through master interface is data that to be written into or read from flash.</li> <li>1'b1: Flash power down, data transferred through master interface is not data that to be written into or read from flash.</li> <li>NANDC is just used as DMA for external memory and internal memory.</li> </ul> |
| 13:9  | RW           | 0×00        | incr_num<br>AHB Master incr num indication.<br>incr_num=1~16.<br>When burst=001, software should configure incr_num.<br>Notes:<br>Only active for master-mode.                                                                                                                                                                                                                                                         |
| 8:6   | RW           | 0x7         | burst<br>AHB Master burst type indication:<br>3'b000: Single transfer<br>3'b011: 4-beat burst<br>3'b101: 8-beat Burst<br>3'b111: 16-beat burst<br>default: not supported<br>Notes:<br>Only active for master-mode.                                                                                                                                                                                                     |
| 5:3   | RW           | 0x2         | hsize<br>AHB Master data size indication:<br>3'b000: 8 bits<br>3'b001: 16 bits<br>3'b010: 32 bits<br>default: not supported<br>Notes:<br>Only active for master-mode.                                                                                                                                                                                                                                                  |
| 2     | RW           | 0×0         | bus_mode<br>Bus interface selection.<br>1'b0: Slave interface, flash data is transferred through slave<br>interface<br>1'b1: Master interface, flash data is transferred through master<br>interface                                                                                                                                                                                                                   |

| 1 | RW        | 0×0 | <pre>ahb_wr<br/>Data transfer direction through master interface.<br/>1'b0: read direction(external memory -&gt;internal memory)<br/>1'b1: write direction (internal memory-&gt;external memory)<br/>Notes:<br/>a. Only active for master-mode.<br/>b. When read flash(flash_rdn=0), ahb_wr=1; when program<br/>flash(flash_rdn=1), ahb_wr=0.</pre>                                                                                                                                                                                                                                          |
|---|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | R/W<br>SC | 0×0 | <ul> <li>ahb_wr_st</li> <li>Start indication for loading data from external memory to internal memory or storing data from internal memory to external memory through master. When asserted, it will be automatically cleared only active when fl_pwd is 1</li> <li>Notes: <ul> <li>a. Only active for master-mode and fl_pwd=1.</li> <li>b. When fl_pwd=0, flash is active, NANDC start to transfer data through master interface if flash_st=1</li> <li>c. When fl_pwd=1, flash is not active, NANDC start to transfer data through master interface if ahb_wr_st=1</li> </ul> </li> </ul> |

### NANDC MTRANS SADDRO

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description                                         |
|------|------|--------------------|-----------------------------------------------------|
|      |      |                    | saddr0                                              |
|      |      |                    | Start address for page data transmission.           |
| 31:0 | RW   | 0x00000000         | Notes:                                              |
|      |      |                    | a. Only active for master-mode.                     |
|      |      |                    | b. Should be aligned with hsize in MTRANS_CFG[5:3]. |

### NANDC\_MTRANS\_SADDR1

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description                                         |
|------|------|--------------------|-----------------------------------------------------|
|      |      |                    | saddr1                                              |
|      |      |                    | Start address for spare data.                       |
| 31:0 | RW   | 0x00000000         | Notes:                                              |
|      |      |                    | a. Only active for master-mode.                     |
|      |      |                    | b. Should be aligned with hsize in MTRANS_CFG[5:3]. |

# NANDC MTRANS STAT

Address: Operational Base + offset (0x001c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                         |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                                                                                                                            |
| 21:16 | RO   | 0×00               | mtrans_cnt<br>finished counter for codeword transmission through Master<br>interface<br>Notes:<br>Only active for master-mode.                                      |
| 15:0  | RO   | 0x0000             | bus_err<br>Bus error indication for codeword0~15.<br>[0]: bus error for codeword 0<br><br>[15]: bus error for codeword 15<br>Notes:<br>Only active for master-mode. |

# NANDC BCHSTO

Address: Operational Base + offset (0x0020)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                              |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RO   | 0x0                | reserved                                                                                                                                 |
| 30    | RO   | 0x0                | err_hnum1_h1<br>Highest bit of err_hnum1                                                                                                 |
| 29    | RO   | 0x0                | err_tnum1_h1<br>Highest bit of err_tnum1                                                                                                 |
| 28    | RO   | 0x0                | err_hnum0_h1<br>Highest bit of err_hnum0                                                                                                 |
| 27    | RO   | 0x0                | err_tnum0_h1<br>Highest bit of err_tnum0                                                                                                 |
| 26    | RO   | 0x1                | bchrdy<br>Ready indication for bch encoder/decoder, 1 active.<br>1'b0: bch encoder/decoder is busy<br>1'b1: bch encoder/decoder is ready |
| 25:21 | RO   | 0×00               | err_hnum1_l5<br>Lower 5 bits of number of error bits found in first 512bytes of 1st<br>backup codeword                                   |
| 20:16 | RO   | 0×00               | err_tnum1_I5<br>Lower 5 bits of number of error bits found in 1st backup<br>codeword                                                     |
| 15    | RO   | 0x0                | fail1<br>Indication for the 1st backup codeword decoded failed or not.<br>1'b0: decode successfully<br>1'b1: decode fail                 |
| 14    | RO   | 0x0                | done1<br>Indication for finishing decoding the 1st backup codeword<br>1'b0: not finished<br>1'b1: finished                               |

| Bit  | Attr | Reset Value | Description                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------|
| 13   | RO   | 0×0         | errf1<br>Indication for error found in 1st backup codeword.<br>1'b0: no error<br>1'b1: error found                     |
| 12:8 | RO   | 0×00        | err_hnum0_l5<br>Lower 5 bits of number of error bits found in first 512bytes of<br>current backup codeword             |
| 7:3  | RO   | 0×00        | err_tnum0_l5<br>Lower 5 bits of number of error bits found in current backup<br>codeword                               |
| 2    | RO   | 0×0         | fail0<br>Indication for current backup codeword decode failed or not<br>1'b0: decode successfully<br>1'b1: decode fail |
| 1    | RO   | 0×0         | done0<br>Indication for finishing decoding the current backup codeword.<br>1'b0: not finished<br>1'b1: finished        |
| 0    | RO   | 0×0         | errf0<br>Indication for error found in current backup codeword.<br>1'b0: no error<br>1'b1: error found                 |

NANDC\_BCHST1 Address: Operational Base + offset (0x0024)

| Bit   | Attr | Reset Value | Description                                                         |
|-------|------|-------------|---------------------------------------------------------------------|
| 31    | RO   | 0x0         | reserved                                                            |
| 30    | RO   | 0x0         | err_hnum3_h1                                                        |
| 30    | RU   | 0x0         | Highest bit of err_hnum3                                            |
| 29    | RO   | 0.20        | err_tnum3_h1                                                        |
| 29    | ĸŪ   | 0x0         | Highest bit of err_tnum3                                            |
| 28    | RO   | 0x0         | err_hnum2_h1                                                        |
| 20    | ĸŪ   | 0.00        | Highest bit of err_hnum2                                            |
| 27    | RO   |             | err_tnum2_h1                                                        |
| 27    | кU   | 0x0         | Highest bit of err_tnum2                                            |
| 26    | RO   | 0x0         | reserved                                                            |
|       |      |             | err_hnum3_l5                                                        |
| 25:21 | RO   | 0x00        | Lower 5 bits of number of error bits found in first 512bytes of 3th |
|       |      |             | backup codeword                                                     |
|       |      |             | err_tnum3_l5                                                        |
| 20:16 | RO   | 0x00        | Lower 5 bits of number of error bits found in 3th backup            |
|       |      |             | codeword                                                            |

| Bit      | Attr  | Reset Value | Description                                                         |
|----------|-------|-------------|---------------------------------------------------------------------|
|          |       |             | fail3                                                               |
| 15       | RO    | 0x0         | Indication for the 3th backup codeword decoded failed or not.       |
| 13       | IS RU | 0.00        | 1'b0: decode successfully                                           |
|          |       |             | 1'b1: decode fail                                                   |
|          |       |             | done3                                                               |
| 14       | RO    | 0x0         | Indication for finishing decoding the 3th backup codeword           |
| 14       | KU    | 0.00        | 1'b0: not finished                                                  |
|          |       |             | 1'b1: finished                                                      |
|          |       |             | errf3                                                               |
| 13       | RO    | 0x0         | Indication for error found in 3th backup codeword.                  |
| 13       | RU    | UXU         | 1'b0: no error                                                      |
|          |       |             | 1'b1: error found                                                   |
|          |       |             | err_hnum2_I5                                                        |
| 12:8     | RO    | 0x00        | Lower 5 bits of number of error bits found in first 512bytes of 2th |
|          |       |             | backup codeword                                                     |
|          |       |             | err_tnum2_l5                                                        |
| 7:3      | RO    | 0x00        | Lower 5 bits of number of error bits found in 2th backup            |
|          |       |             | codeword                                                            |
|          |       |             | fail2                                                               |
| 2        | RO    | 0×0         | Indication for 2th backup codeword decode failed or not             |
| 2        | ĸŪ    | 0.00        | 1'b0: decode successfully                                           |
|          |       |             | 1'b1: decode fail                                                   |
|          |       |             | done2                                                               |
| 1        | RO    | 0x0         | Indication for finishing decoding the 2th backup codeword.          |
| <b>–</b> | RU    | UXU         | 1'b0: not finished                                                  |
|          |       |             | 1'b1: finished                                                      |
|          |       |             | errf2                                                               |
| 0        | RO    | 0x0         | Indication for error found in 2th backup codeword.                  |
| 0        | RU    | UXU         | 1'b0: no error                                                      |
|          |       |             | 1'b1: error found                                                   |

# NANDC BCHST2

Address: Operational Base + offset (0x0028)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                      |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | bchst_cwd4_cwd5<br>BCHST information for 4th and 5th backup codeword. Bit<br>assignment is similar to BCHST1 register. For more description,<br>please refer to BCHST1 register. |

### NANDC\_BCHST3

Address: Operational Base + offset (0x002c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                      |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | bchst_cwd6_cwd7<br>BCHST information for 6th and 7th backup codeword. Bit<br>assignment is similar to BCHST1 register. For more description,<br>please refer to BCHST1 register. |

### NANDC BCHST4

Address: Operational Base + offset (0x0030)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                      |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | bchst_cwd8_cwd9<br>BCHST information for 8th and 9th backup codeword. Bit<br>assignment is similar to BCHST1 register. For more description,<br>please refer to BCHST1 register. |

### NANDC BCHST5

Address: Operational Base + offset (0x0034)

| 31:0 RO 0x00000000 bchst_cwd10_cwd11<br>BCHST information for 10th and 11th backup codew<br>assignment is similar to BCHST1 register. For more<br>please refer to BCHST1 register. |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|

### NANDC\_BCHST6

Address: Operational Base + offset (0x0038)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                          |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000         | bchst_cwd12_cwd13<br>BCHST information for 12th and 13th backup codeword. Bit<br>assignment is similar to BCHST1 register. For more description,<br>please refer to BCHST1 register. |

### NANDC BCHST7

Address: Operational Base + offset (0x003c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                          |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000         | bchst_cwd14_cwd15<br>BCHST information for 14th and 15th backup codeword. Bit<br>assignment is similar to BCHST1 register. For more description,<br>please refer to BCHST1 register. |

### NANDC MTRANS STAT2

Address: Operational Base + offset (0x015c)

| Bit   | Attr | <b>Reset Value</b> | Description                             |
|-------|------|--------------------|-----------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                |
|       |      |                    | bus_err2                                |
|       |      |                    | Bus error indication for codeword16~31. |
|       |      |                    | [0]: bus error for codeword 16          |
| 15:0  | RO   | 0x0000             |                                         |
|       |      |                    | [15]: bus error for codeword 31         |
|       |      |                    | Notes:                                  |
|       |      |                    | Only active for master-mode.            |

# NANDC NANDC VER

Address: Operational Base + offset (0x0160)

| Bit  | Attr | <b>Reset Value</b> | Description                             |
|------|------|--------------------|-----------------------------------------|
| 31:0 | RO   | 0x00000801         | version<br>Version indication for NANDC |

### NANDC INTEN

Address: Operational Base + offset (0x016c)

| Bit  |    | Reset Value | + offset (0x016c)                                               |
|------|----|-------------|-----------------------------------------------------------------|
|      |    |             | Description                                                     |
| 31:7 | RO | 0x0         | reserved                                                        |
|      |    |             | master_idle_int_en                                              |
|      |    |             | Enable for master idle interrupt                                |
| 6    | RW | 0x0         | 1'b0: interrupt disable                                         |
| 0    |    | 0,0         | 1'b1: interrupt enable                                          |
|      |    |             | When master_idle_int_en is active, an interrupt is generated if |
|      |    |             | posedge of master idle happen                                   |
| 5:4  | RO | 0x0         | reserved                                                        |
|      |    |             | bchfail_int_en                                                  |
|      |    |             | Enable for bch fail interrupt.                                  |
| 2    | RW | 0.40        | 1'b0: interrupt disable                                         |
| 3    | RW | 0x0         | 1'b1: interrupt enable                                          |
|      |    |             | When bchfail_int_en is active, an interrupt is generated if bch |
|      |    |             | decode failed                                                   |
|      |    |             | bcherr_int_en                                                   |
|      |    |             | Enable for bch error interrupt.                                 |
| -    |    | W 0×0       | 1'b0: interrupt disable                                         |
| 2    | RW |             | 1'b1: interrupt enable                                          |
|      |    |             | When bcherr_int_en is active, an interrupt is generated if bch  |
|      |    |             | decode error bit is larger than bchthres(BCHCTL[26:19])         |
|      |    |             | frdy_int_en                                                     |
|      |    |             | Enable for flash_rdy interrupt                                  |
|      |    |             | 1'b0: interrupt disable                                         |
| 1    | RW | W 0×0       | 1'b1: interrupt enable                                          |
|      |    |             | When frdy_int_en is active, an interrupt is generated if flash  |
|      |    |             | R/B# changes from 0 to 1                                        |
|      | 1  | 1           |                                                                 |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                   |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0×0                | dma_int_en<br>Enable for internal DMA transfer finished interrupt<br>1'b0: interrupt disable<br>1'b1: interrupt enable<br>When dma_int_en is active, an interrupt is generated if<br>page_num(FLCTL[27:22]) of flash data transfer in DMA mode is<br>finished |

### NANDC\_INTCLR

Address: Operational Base + offset (0x0170)

| Bit  | Attr      | <b>Reset Value</b> | Description                                                                                                                                                                   |
|------|-----------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO        | 0x0                | reserved                                                                                                                                                                      |
| 6    | R/W<br>SC | 0x0                | master_idle_int_clr<br>Clear for master idle interrupt. When asserted, this bit will be<br>auto cleared.<br>1'b0: interrupt not cleared<br>1'b1: interrupt cleared            |
| 5:4  | RO        | 0x0                | reserved                                                                                                                                                                      |
| 3    | R/W<br>SC | 0x0                | bchfail_int_clr<br>Clear for bch decode fail interrupt. When asserted, this bit will be<br>auto cleared.<br>1'b0: interrupt cleared<br>1'b1: interrupt not cleared            |
| 2    | R/W<br>SC | 0x0                | bcherr_int_clr<br>Clear for bch error interrupt. When asserted, this bit will be auto<br>cleared.<br>1'b0: interrupt cleared<br>1'b1: interrupt not cleared                   |
| 1    | R/W<br>SC | 0x0                | frdy_int_clr<br>Clear for flash_rdy interrupt. When asserted, this bit will be auto<br>cleared.<br>1'b0: interrupt cleared<br>1'b1: interrupt not cleared                     |
| 0    | R/W<br>SC | 0×0                | dma_int_clr<br>Clear for internal DMA transfer finished interrupt. When asserted,<br>this bit will be auto cleared.<br>1'b0: interrupt cleared<br>1'b1: interrupt not cleared |

### NANDC\_INTST

Address: Operational Base + offset (0x0174)

| Bit  | Attr | Reset Value | Description                                                      |
|------|------|-------------|------------------------------------------------------------------|
| 31:7 | RO   | 0x0         | reserved                                                         |
| 6    | RO   | 0x0         | master_idle_int_stat                                             |
| 0    | кU   | 0.00        | Status for master idle interrupt, high active                    |
| 5:4  | RO   | 0x0         | reserved                                                         |
| 3    | RO   | 0x0         | bchfail_int_stat                                                 |
| 3    | RU   |             | Status for bch decode fail interrupt, high active                |
| 2    | RO   | .O 0x0      | bcherr_int_stat                                                  |
| 2    | кU   |             | Status for bch error interrupt, high active                      |
| 1    | PO   | RO 0x0      | frdy_int_stat                                                    |
| T    | RU   |             | Status for flash_rdy interrupt, high active                      |
| 0    | PO   | 0.20        | dma_int_stat                                                     |
| 0    | 0 RO | RO 0x0      | Status for internal DMA transfer finished interrupt, high active |

### NANDC SPAREO 0

Address: Operational Base + offset (0x0200)

| Bit   | Attr | <b>Reset Value</b> | Description                       |
|-------|------|--------------------|-----------------------------------|
| 31:24 |      | W l0xff            | system_3                          |
| 51.24 | RW   |                    | the 4th system byte of codeword 0 |
| 22.16 |      | W 0xff             | system_2                          |
| 23:16 | RW   |                    | the 3rd system byte of codeword 0 |
| 1     | RW   |                    | system_1                          |
| 15:8  |      | 0xff               | the 2nd system byte of codeword 0 |
| 7.0   |      | 0                  | system_0                          |
| 7:0   | RW   | 0xff               | the 1st system byte of codeword 0 |

### NANDC SPARE1 0

Address: Operational Base + offset (0x0230)

| Bit   | Attr | <b>Reset Value</b> | Description                       |      |
|-------|------|--------------------|-----------------------------------|------|
| 31:24 |      | W 0xff             | system_3                          |      |
| 51:24 | RW   |                    | the 4th system byte of codeword 1 |      |
| 23:16 |      | W 0xff             | system_2                          |      |
| 23:10 | RW   |                    | the 3rd system byte of codeword 1 |      |
| 1     | RW   | NV 0 ff            | system_1                          |      |
| 15:8  |      | RW                 | S RW                              | 0xff |
| 7.0   | RW   | Over               | system_0                          |      |
| 7:0   |      | 0xff               | the 1st system byte of codeword 1 |      |

### NANDC\_BCHST8

Address: Operational Base + offset (0x0520)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                          |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0×00000000         | bchst_cwd16_cwd17<br>BCHST information for 16th and 17th backup codeword. Bit<br>assignment is similar to BCHST1 register. For more description,<br>please refer to BCHST1 register. |

#### NANDC\_BCHST9

Address: Operational Base + offset (0x0524)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |
|------|------|--------------------|-----------------------------------------------------------------|
|      | RO   | 0x00000000         | bchst_cwd18_cwd19                                               |
| 31:0 |      |                    | BCHST information for 18th and 19th backup codeword. Bit        |
| 51.0 |      |                    | assignment is similar to BCHST1 register. For more description, |
|      |      |                    | please refer to BCHST1 register.                                |

### NANDC BCHST10

Address: Operational Base + offset (0x0528)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |  |  |  |  |
|------|------|--------------------|-----------------------------------------------------------------|--|--|--|--|
|      |      | 0x00000000         | bchst_cwd20_cwd21                                               |  |  |  |  |
| 31:0 | RO   |                    | BCHST information for 20th and 21th backup codeword. Bit        |  |  |  |  |
| 51.0 | κυ   |                    | assignment is similar to BCHST1 register. For more description, |  |  |  |  |
|      |      |                    | please refer to BCHST1 register.                                |  |  |  |  |

### NANDC BCHST11

Address: Operational Base + offset (0x052c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |  |  |  |  |  |
|------|------|--------------------|-----------------------------------------------------------------|--|--|--|--|--|
| 31:0 |      | 0×00000000         | bchst_cwd22_cwd23                                               |  |  |  |  |  |
|      | RO   |                    | BCHST information for 22th and 23th backup codeword. Bit        |  |  |  |  |  |
| 51.0 | κυ   |                    | assignment is similar to BCHST1 register. For more description, |  |  |  |  |  |
|      |      |                    | please refer to BCHST1 register.                                |  |  |  |  |  |

#### NANDC BCHST12

Address: Operational Base + offset (0x0530)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                          |  |  |  |  |  |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31:0 | RO   | 0×00000000         | bchst_cwd24_cwd25<br>BCHST information for 24th and 25th backup codeword. Bit<br>assignment is similar to BCHST1 register. For more description,<br>please refer to BCHST1 register. |  |  |  |  |  |

### NANDC BCHST13

Address: Operational Base + offset (0x0534)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |  |  |  |  |  |
|------|------|--------------------|-----------------------------------------------------------------|--|--|--|--|--|
|      | RO   | 0x00000000         | bchst_cwd26_cwd27                                               |  |  |  |  |  |
| 31:0 |      |                    | BCHST information for 26th and 27th backup codeword. Bit        |  |  |  |  |  |
| 51.0 |      |                    | assignment is similar to BCHST1 register. For more description, |  |  |  |  |  |
|      |      |                    | please refer to BCHST1 register.                                |  |  |  |  |  |

#### NANDC BCHST14

Address: Operational Base + offset (0x0538)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |  |  |  |  |  |
|------|------|--------------------|-----------------------------------------------------------------|--|--|--|--|--|
|      |      | 0×00000000         | bchst_cwd28_cwd29                                               |  |  |  |  |  |
| 31:0 | RO   |                    | BCHST information for 28th and 29th backup codeword. Bit        |  |  |  |  |  |
| 51.0 | ΝŪ   |                    | assignment is similar to BCHST1 register. For more description, |  |  |  |  |  |
|      |      |                    | please refer to BCHST1 register.                                |  |  |  |  |  |

### NANDC\_BCHST15

Address: Operational Base + offset (0x053c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                          |  |  |  |  |  |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31:0 | RO   | 0×00000000         | bchst_cwd30_cwd31<br>BCHST information for 30th and 31th backup codeword. Bit<br>assignment is similar to BCHST1 register. For more description,<br>please refer to BCHST1 register. |  |  |  |  |  |

### NANDC FLASHO DATA

Address: Operational Base + offset (0x0800)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                            |  |  |  |  |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                               |  |  |  |  |
| 15:0  | RW   | 0×0000             | flash0_data<br>valid for flash bypass internal dma mode(FLCTL[3]=0)<br>FLASH0_DATA[15:0] is used for Asynchronous 16 bits mode or<br>Toggle mode and FLASH0_DATA[7:0] is used for 8 bits<br>Asynchronous mode.<br>If Synchronous mode is selected, please refer to<br>FLASH0_DATA_SYN. |  |  |  |  |

### NANDC\_FLASH0\_ADDR

Address: Operational Base + offset (0x0804)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                        |  |  |  |  |
|------|------|--------------------|----------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:8 | RO   | 0x0                | reserved                                                                                           |  |  |  |  |
| 7:0  | wo   | 0x00               | flash0_addr<br>page or block address send to flash0 before flash erase, read or<br>write operation |  |  |  |  |

### NANDC\_FLASH0\_CMD

Address: Operational Base + offset (0x0808)

| Bit  | Attr | <b>Reset Value</b> | Description                                       |  |  |  |  |
|------|------|--------------------|---------------------------------------------------|--|--|--|--|
| 31:8 | RO   | 0x0                | reserved                                          |  |  |  |  |
| 7:0  | RW   | 0x00               | flash0_cmd<br>contain the command write to flash0 |  |  |  |  |

# **12.5 Interface Description**

Table 12-2 NANDC Interface Description

| Module Pin Directi |   | PIN Name                                  | IOMUX Setting                |  |  |  |  |  |  |
|--------------------|---|-------------------------------------------|------------------------------|--|--|--|--|--|--|
| flash_ale          | 0 | GPIO3_B3/FLASH_ALE/EMMC_PWREN/SPI1<br>CLK | GRF_GPIO3B_IOMUX [7:6]=2'b01 |  |  |  |  |  |  |

| Module Pin    | Direction | PIN Name                                               | IOMUX Setting                      |
|---------------|-----------|--------------------------------------------------------|------------------------------------|
| flash_cle     | 0         | GPIO3_B1/FLASH_CLE/EMMC_CLK                            | GRF_GPIO3B_IOMUX [3:2]=2'b01       |
| flash_wrn     | 0         | GPIO3_B0/FLASH_WRN/EMMC_CMD                            | GRF_GPIO3B_IOMUX [1:0]=2'b01       |
| flash_rdn     | 0         | GPIO3_B2/FLASH_RDN/SPI1_MISO                           | GRF_GPIO3B_IOMUX [5:4]=2'b01       |
| flash_data[0] | I/O       | GPIO3_A0/FLASH_D0/EMMC_D0/SFC_SIO0                     | GRF_GPIO3A_IOMUX [1:0]=2'b01       |
| flash_data[1] | I/O       | GPIO3_A1/FLASH_D1/EMMC_D1/SFC_SIO1                     | GRF_GPIO3A_IOMUX [3:2]=2'b01       |
| flash_data[2] | I/O       | GPIO3_A2/FLASH_D2/EMMC_D2/SFC_WP_<br>SIO2              | GRF_GPIO3A_IOMUX [5:4]=2'b01       |
| flash_data[3] | I/O       | GPIO3_A3/FLASH_D3/EMMC_D3/SFC_HOL<br>D_SIO3            | GRF_GPIO3A_IOMUX [7:6]=2'b01       |
| flash_data[4] | I/O       | GPIO3_A4/FLASH_D4/EMMC_D4/SFC_CLK                      | GRF_GPIO3A_IOMUX [9:8]=2'b01       |
| flash_data[5] | I/O       | GPIO3_A5/FLASH_D5/EMMC_D5/SFC_CSN<br>0                 | GRF_GPIO3A_IOMUX<br>[11:10]=2'b01  |
| flash_data[6] | I/O       | GPIO3_A6/FLASH_D6/EMMC_D6                              | GRF_GPIO3A_IOMUX<br>[13:12]=2'b01  |
| flash_data[7] | I/O       | GPIO3_A7/FLASH_D7/EMMC_D7                              | GRF_GPIO3A_IOMUX<br>[15:14]=2'b01  |
| flash_rdy     | I         | GPIO3_B4/FLASH_RDY/I2C3_SDA_M1/SPI1<br>_MOSI/UART3_RX  | GRF_GPIO3B_IOMUX<br>[10:8]=3'b001  |
| flash_csn0    | 0         | GPIO3_B5/FLASH_CSN0/I2C3_SCL_M1/SPI<br>1_CSN0/UART3_TX | GRF_GPIO3B_IOMUX<br>[14:12]=3'b001 |

Notes: I=input, O=output, I/O=input/output, bidirectional

Furthermore, different IOs are selected and connected to different NAND Flash interface, which is shown as follows.

| Module Pin      | Direction | Flash Interface |         |      |        |
|-----------------|-----------|-----------------|---------|------|--------|
|                 |           | Asyn8x          | Asyn16x | ONFI | Toggle |
| flash_csni(i=0) | 0         | $\checkmark$    | -       | -    | -      |
| flash_ale       | 0         | $\checkmark$    | -       | -    | -      |
| flash_cle       | 0         | $\checkmark$    | -       | -    | -      |
| flash_wrn       | 0         | $\checkmark$    | -       | -    | -      |
| flash_rdn       | 0         | $\checkmark$    | -       | -    | -      |
| flash_data[7:0] | I/O       | $\checkmark$    | -       | -    | -      |
| flash_rdy       | I         | $\checkmark$    | -       | -    | _      |

# **12.6 Application Notes**

### 12.6.1 BCHST/BCHLOC/BCHDE/SPARE Application 1. BCHST

There are 16 BCHST-registers in NANDC to store 32 codeword's BCH decode status(bchst) information. Every register stores 2 codeword's bchst information except BCHST0, which not only includes bchst information, but also includes one bit for *bchrdy*.

Let bchst\_cwd0~bchst\_cwd31 be the bchst information for 32 codewords. In BCHSTregisters, the latest codeword's bchst is stored into bchst\_cwd0, and the former is shifted into bchst\_cwd1. That is, bchst\_cwd0 $\rightarrow$  bchst\_cwd1 $\rightarrow$ ..... $\rightarrow$ bchst\_cwd31. Therefore, for example, if 32 codewords are decoded, then bchst\_cwd0 is the bch decode status for codeword31, and bchst\_cwd31 is the bch decode status for codeword0. bchst\_cwd0 = {BCHST0[28], BCHST0[12:8], BCHST0[27], BCHST0[7:3], BCHST0[2:0]} bchst\_cwd1 = {BCHST0[30], BCHST0[25:21], BCHST0[29], BCHST0[20:16],

```
BCHST0[15:13]}
bchst_cwd2 = {BCHST1[28], BCHST1[12:8], BCHST1[27], BCHST1[7:3], BCHST1[2:0]}
bchst_cwd3 = {BCHST1[30], BCHST1[25:21], BCHST1[29], BCHST1[20:16],
BCHST1[15:13]}
```

bchst\_cwd4 = {BCHST2[28], BCHST2[12:8], BCHST2[27], BCHST2[7:3], BCHST2[2:0]} bchst\_cwd5 = {BCHST2[30], BCHST2[25:21], BCHST2[29], BCHST2[20:16], BCHST2[15:13]}

```
bchst_cwd6 = {BCHST3[28], BCHST3[12:8], BCHST3[27], BCHST3[7:3], BCHST3[2:0]}
bchst_cwd7 = {BCHST3[30], BCHST3[25:21], BCHST3[29], BCHST3[20:16],
```

BCHST3[15:13]}

```
bchst_cwd8 = {BCHST4[28], BCHST4[12:8], BCHST4[27], BCHST4[7:3], BCHST4[2:0]}
bchst_cwd9 = {BCHST4[30], BCHST4[25:21], BCHST4[29], BCHST4[20:16],
```

```
BCHST4[15:13]}
```

```
bchst_cwd10 = {BCHST5[28], BCHST5[12:8], BCHST5[27], BCHST5[7:3], BCHST5[2:0]}
```

bchst cwd11 = {BCHST5[30], BCHST5[25:21], BCHST5[29], BCHST5[20:16], BCHST5[15:13]} bchst\_cwd12 = {BCHST6[28], BCHST6[12:8], BCHST6[27], BCHST6[7:3], BCHST6[2:0]} bchst\_cwd13 = {BCHST6[30], BCHST6[25:21], BCHST6[29], BCHST6[20:16], BCHST6[15:13]} bchst\_cwd14 = {BCHST7[28], BCHST7[12:8], BCHST7[27], BCHST7[7:3], BCHST7[2:0]} bchst cwd15 = {BCHST7[30], BCHST7[25:21], BCHST7[29], BCHST7[20:16], BCHST7[15:13]} bchst\_cwd16 = {BCHST8[28], BCHST8[12:8], BCHST8[27], BCHST8[7:3], BCHST8[2:0]} bchst\_cwd17 = {BCHST8[30], BCHST8[25:21], BCHST8[29], BCHST8[20:16], BCHST8[15:13]} bchst\_cwd18 = {BCHST9[28], BCHST9[12:8], BCHST9[27], BCHST9[7:3], BCHST9[2:0]} bchst\_cwd19 = {BCHST9[30], BCHST9[25:21], BCHST9[29], BCHST9[20:16], BCHST9[15:13]} bchst\_cwd20 = {BCHST10[28], BCHST10[12:8], BCHST10[27], BCHST10[7:3], BCHST10[2:0]} bchst\_cwd21 = {BCHST10[30], BCHST10[25:21], BCHST10[29], BCHST10[20:16], BCHST10[15:13]} bchst\_cwd22 = {BCHST11[28], BCHST11[12:8], BCHST11[27], BCHST11[7:3], BCHST11[2:0]}  $bchst_cwd23 = \{BCHST11[30], BCHST11[25:21], BCHST11[29], BCHST11[20:16], \}$ BCHST11[15:13]} bchst\_cwd24 = {BCHST12[28], BCHST12[12:8], BCHST12[27], BCHST12[7:3], BCHST12[2:0]} bchst  $cwd25 = \{BCHST12[30], BCHST12[25:21], BCHST12[29], BCHST12[20:16], \}$ BCHST12[15:13]} bchst\_cwd26 = {BCHST13[28], BCHST13[12:8], BCHST13[27], BCHST13[7:3], BCHST13[2:0]} bchst\_cwd27 = {BCHST13[30], BCHST13[25:21], BCHST13[29], BCHST13[20:16], BCHST13[15:13]} bchst\_cwd28 = {BCHST14[28], BCHST14[12:8], BCHST14[27], BCHST14[7:3], BCHST14[2:0]}  $bchst_cwd29 = \{BCHST14[30], BCHST14[25:21], BCHST14[29], BCHST14[20:16], \}$ BCHST14[15:13]} bchst\_cwd30 = {BCHST15[28], BCHST15[12:8], BCHST15[27], BCHST15[7:3], BCHST15[2:0]} bchst cwd31 = {BCHST15[30], BCHST15[25:21], BCHST15[29], BCHST15[20:16], BCHST15[15:13]}

### 2. SPARE

SPARE includes two register-groups, SPARE0 and SPARE1. Each group has 8 registers: SPARE0\_0~SPARE0\_7 and SPARE1\_0~SPARE1\_7. Only SPARE0\_0 and SPARE1\_0 can be accessed via software, others are used internally.

When in bch encoding, SPARE0\_0 stores system information for codeword in sram0, SPARE0\_n(n=1~7) stores encode information for codeword in sram0; SPARE1\_0 stores system information for codeword in sram1, SPARE1\_n(n=1~7) stores encode information for codeword in sram1.

When in bch decoding, SPARE0\_n(n=0~7) stores the spare data read from NAND Flash for codeword in sram0 if BCHCTL[28]=0, the bch decode status(BCHST) information which reflects the current codeword will be written into ddr instead of SPARE0\_1 if BCHCTL[28]=1; SPARE1\_n(n=0~7) stores the spare data read from NAND Flash for codeword in sram1 if BCHCTL[28]=0, the bch decode status(BCHST) information which reflects the current codeword will be written into ddr Instead of SPARE1\_1 if BCHCTL[28]=1.

# 12.6.2 Bus Mode Application

MTRANS\_CFG[2] determines whether the data load/store between internal memory and external memory is through slave interface or master interface.

### 1. Slave Mode

When MTRANS\_CFG[2]=0, slave is selected. i. e. , NAND Flash data load/store between

internal memory and external memory is through slave interface by cpu or external DMA. In this mode, software should store page data into internal memory and spare data into SPARE registers before starting NAND Flash program operation; and should load page data from internal memory and spare data from SPARE registers after finishing NAND Flash read operation.

In this mode, MTRANS\_CFG, MTRANS\_SADDR0 and MTRANS\_SADDR1 are unused. The transfer codeword number is determined by FLCTL[6:5], and the maximum number is 2. The judgment condition for finishing data transfer is FLCTL[20]. When FLCTL[20] is high, it means that data transfer is finished.

#### 2. Master Mode

When MTRANS\_CFG[2]=1, master is selected. i. e., NAND Flash data load/store between internal memory and external memory is through master interface.

In this mode, software should initialize page data and spare data into external memory, and set their addresses in MTRANS\_SADDR0 and MTRANS\_SADDR1 respectively before starting NAND Flash program operation. Similarly, software should configure MTRANS\_SADDR0 and MTRANS\_SADDR1 respectively before starting NAND Flash read operation and could read data from addresses in MTRANS\_SADDR0 and MTRANS\_SADDR1 after NANDC transfer finish.

In this mode, MTRANS\_CFG, MTRANS\_SADDR0 and MTRANS\_SADDR1 are used. The transfer codeword number is determined by FLCTL[26:22], and the maximum number is 32. The judgment condition for finishing data transfer is FLCTL[20]. When FLCTL[20] is high, it means that data transmission is finished.

When MTRANS\_CFG[2]=1, page data and spare data are stored in the continuous space of external memory respectively.

For page data, source address is named Saddr0, specified in MTRANS\_SADDR0. The space can be divided into many continuous units, and the unit size(named PUnit) is 1024 bytes. For spare data, source address is named Saddr1, specified in MTRANS\_SADDR1. The space can be divided into many continuous units, and the unit size(named SUnit) is 64 bytes for 16 bits BCH mode.



Fig. 12-2 NANDC Address Assignment

The detailed format for page data and spare data in every unit is shown in following figures.



Fig. 12-3 NANDC Data Format

# 12.6.3 BchPage Application

BCHCTL[16] determines whether codeword size for page data is 1024 bytes or 512 bytes when FLCTL[11] is 0.

### 1. 1024bytes

When BCHCTL[16]=0, BchPage=0, hardware needs to write 1024 bytes page data and spare data into NAND Flash or read 1024 bytes page data and spare data from NAND Flash. All the 1024 bytes page data and spare data are encoded when writing or decoded when reading. **2.512bytes** 

When BCHCTL[16]=1, BchPage=1, hardware needs to write 512 bytes page data and spare data into NAND Flash or read 512 bytes page data and spare data from NAND Flash.

In this mode, the page data unit size for BCH encoder and BCH decoder still is 1024byte. So to support BCH encoder and decoder, software should configure page data as

follows:1th~512th bytes are invalid data which must be stuffed with 0xff, 513th~1024th bytes are valid page data.

# 12.6.4 PageSize/SpareSize Application

### 1. Big Page

When FLCTL[11]=0(LbaEn=0), the NAND Flash to be operated is Raw NAND Flash. Every codeword size is 1024 bytes and FLCTL[21] should always be set to 0, and the PageStep in external memory is 1024 bytes if bus mode is master mode.

At this mode, the spare size and SpareStep in external memory are determined by BCH Mode as follows:

BCH Mode=16bitBCH: spare size=(28+4)bytes , SpareStep=64bytes

# 2. Small Page

The NAND Flash controller will not operate in LBA mode, so small page with 512 bytes for a codeword is not supported.

# 12.6.5 NANDC Interrupt Application

NANDC has 1 interrupt output signal and 5 interrupt sources: dma finish interrupt source, NAND Flash ready interrupt source, bch error interrupt source, bch fail interrupt source and master idle interrupt source. When one or more of these interrupt source are enabled, NANDC interrupt is asserted if one or more interrupt source is high. Software can determine the interrupt source by reading INTST and clear interrupt by writing corresponding bit in INTCLR.

# 12.6.6 FIFO Application

FIFO in NANDC is used to store command, address and data temporarily that are intend to write to the external NAND Flash. The FIFO is 32-bit wide and 8-location deep, user can access it by configuring the NANDC to work on bypass(FLCTL[3]=1) and fifo

enable(FLCTL[30]=1) mode.

The format of data written into fifo is as follows.



DATA\_TYPE: 2'b00/2'b11 : flash data 2'b10 : flash command 2'b01 : flash address

#### Fig. 12-4 FIFO Data Format

Command, address or data write to external NAND Flash are pushed into fifo first and pop up automatically if the fifo is not empty. Then FIFO\_DATA1, FIFO\_DATA2 and FIFO\_DATA3 are written to NAND Flash by NANDC in order. The method to determine the end of write operation is to read register FMCTL. If FMCTL[10] is set , it means that the fifo is empty and NAND Flash write operation is over.

# **Chapter 13 Embedded SRAM**

# 13.1 Overview

There is only one embedded SRAM, SYSTEM\_SRAM. The AXI slave device, which supports read and write access to provide system fast access data storage.

### **13.1.1 Features supported**

- SYSTEM\_SRAM
  - Provide 256KB access space
  - Support security and non-security access
  - Security or non-security space is software programmable
  - Security space is nx4KB(up to whole memory space)
  - Shares space from 32KB~256KB with vad

# 13.2 Block Diagram



Fig. 13-1 Embedded SRAM block diagram

# **13.3 Function Description**

# 13.3.1 AXI slave interface of SYSTEM\_SRAM

The AXI slave interface is bridge which translate AXI bus access to SRAM interface of SYSTEM\_SRAM.

# 13.3.2 Embedded SRAM access path

The SYSTEM\_SRAM can only be accessed by CPU, DMAC0, DMAC1, CRYPTO and VOP.VAD can access SYSTEM\_SRAM from 32KB to 256KB, and vad only write to SYSTEM\_SRAM, and will not read from SYSTEM\_SRAM.VAD can write to SYSTEM\_SRAM when cpu read from/write to SYSTEM\_SRAM.

# **Chapter 14 System Debug**

# 14.1 Overview

The chip uses the DAPLITE Technology to support real-time debug.

# 14.1.1 Features

- Invasive debug with core halted
- SW-DP

# 14.1.2 Debug components address map

Base Address: 0xFF800000.

The following table shows the debug components address in memory map: Table 14-1 Debug Address Mapping Table

| Module                              | Address Offset    |
|-------------------------------------|-------------------|
| APB ROM table for the processor     | 0x00000 - 0x00FFF |
| Reserved for other debug components | 0x01000 - 0x07FFF |
| Reserved for future expansion       | 0x08000 - 0x0FFFF |
| Core 0 Debug                        | 0x10000 - 0x10FFF |
| Core 0 PMU                          | 0x11000 - 0x11FFF |
| Core 1 Debug                        | 0x12000 - 0x12FFF |
| Core 1 PMU                          | 0x13000 - 0x13FFF |
| Core 2 Debug                        | 0x14000 - 0x14FFF |
| Core 2 PMU                          | 0x15000 - 0x15FFF |
| Core 3 Debug                        | 0x16000 - 0x16FFF |
| Core 3 PMU                          | 0x17000 - 0x17FFF |
| Core 0 CTI                          | 0x18000 - 0x18FFF |
| Core 1 CTI                          | 0x19000 - 0x19FFF |
| Core 2 CTI                          | 0x1A000 - 0x1AFFF |
| Core 3 CTI                          | 0x1B000 - 0x1BFFF |
| Core 0 Trace                        | 0x1C000 - 0x1CFFF |
| Core 1 Trace                        | 0x1D000 - 0x1DFFF |
| Core 2 Trace                        | 0x1E000 - 0x1EFFF |
| Core 3 Trace                        | 0x1F000 - 0x1FFFF |

# 14.2 Block Diagram



Fig. 14-1 Debug system structure

# **14.3 Function Description**

# 14.3.1 DAP

The DAP has following components:

- Serial Wire JTAG Debug Port(SWJ-DP)
- APB Access Port(APB-AP)

#### • ROM table

The debug port is the host tools interface to access the DAP-Lite. This interface controls any access ports provided within the DAP-Lite. The DAP-Lite supports a combined debug port which includes both JTAG and Serial Wire Debug(SWD), with a mechanism that supports switching between them.

The APB-AP acts as a bridge between SWJ-DP and APB bus which translate the Debug request to APB bus.

The DAP provides an internal ROM table connected to the master Debug APB port of the APB-Mux. The Debug ROM table is loaded at address 0x00000000 and 0x80000000 of this bus and is accessible from both APB-AP and the system APB input. Bit[31] of the address bus is not connected to the ROM Table, ensuring that both views read the same value. The ROM table stores the locations of the components on the Debug APB.

More information please refer to the document CoreSight\_DAPLite\_TRM.pdf for the debug detail description.

# **14.4 Register Description**

Please refer to the document CoreSight DAP-Lite Technical Reference Manual for the debug detail description.

# **14.5 Interface Description**

# 14.5.1 DAP SWJ-DP Interface

The following figure is the DAP SWJ-DP interface, the SWJ-DP is a combined JTAG-DP and SW-DP that enable you to connect either a Serial Wire Debug(SW-DP) or JTAG probe to a target.



#### Fig. 14-2 DAP SWJ interface

# 14.5.2 DAP SW-DP Interface

This implementation is taken from ADIv5.1 and operates with a synchronous serial interface. This uses a single bidirectional data signal, and a clock signal.

The figure below describes the interaction between the timing of transactions on the serial wire interface, and the DAP internal bus transfers. It shows when the target responds with a

#### WAIT acknowledgement.



#### Fig. 14-3 SW-DP acknowledgement timing

Table 14-2 SW-DP Interface Description

| Module pin | Direction | PIN name                                               | IOMUX                             |
|------------|-----------|--------------------------------------------------------|-----------------------------------|
| jtag_tck   | Ι         | GPIO1_C6/UART1_CTSN/UART2_RX_<br>M0/SPI2_MISO/JTAG_TCK | GRF_GPIO1C_IOMUX_<br>H[7:4]=4'h4  |
| jtag_tms   | I/O       | GPIO1_C7/UART1_RTSN/UART2_TX_<br>M0/SPI2_MOSI/JTAG_TMS | GRF_GPIO1C_IOMUX_<br>H[11:8]=4'h4 |

*Notes: I=input, O=output, I/O=input/output, bidirectional.* 

# Chapter 15 UART

# **15.1 Overview**

The Universal Asynchronous Receiver/Transmitter (UART) is used for serial communication with a peripheral, modem (data carrier equipment, DCE) or data set. Data is written from a master (CPU) over the APB bus to the UART and it is converted to serial form and transmitted to the destination device. Serial data is also received by the UART and stored for the master (CPU) to read back.

UART Controller supports the following features:

- Support 5 independent UART controller: UART0~UART4
- contain two 64Bytes FIFOs for data receive and transmit
- support auto flow-control
- Support bit rates 115.2Kbps,460.8Kbps,921.6Kbps,1.5Mbps,3Mbps, 4Mbps
- Support programmable baud rates, even with non-integer clock divider
- Standard asynchronous communication bits (start, stop and parity)
- Support interrupt-based or DMA-based mode
- Support 5-8 bits width transfer

# 15.2 Block Diagram

This section provides a description about the functions and behavior under various conditions. The UART Controller comprises with:

- AMBA APB interface
- FIFO controllers
- Register block
- Modem synchronization block and baud clock generation block
- Serial receiver and serial transmitter



#### Fig. 15-1UART Block Diagram

#### **APB INTERFACE**

The host processor accesses data, control, and status information on the UART through the APB interface. The UART supports APB data bus widths of 8, 16, and 32 bits.

#### **Register block**

Be responsible for the main UART functionality including control, status and interrupt generation.

#### Modem Synchronization block

Synchronizes the modem input signal.

#### **FIFO block**

Be responsible for FIFO control and storage (when using internal RAM) or signaling to

control external RAM (when used).

#### **Baud Clock Generator**

Generates the transmitter and receiver baud clockalong with the output reference clock signal (baudout\_n).

#### **Serial Transmitter**

Converts the parallel data, written to the UART, into serial form and adds all additional bits, as specified by the control register, for transmission. This makeup of serial data, referred to as a character can exit the block in two forms, either serial UART format or IrDA 1.0 SIR format.

#### **Serial Receiver**

Converts the serial data character (as specified by the control register) received in either the UART or IrDA 1.0 SIR format to parallel form. Parity error detection, framing error detection and line break detection is carried out in this block.

# **15.3 Function Description**

### UART (RS232) Serial Protocol

Because the serial communication is asynchronous, additional bits (start and stop) are added to the serial data to indicate the beginning and end. An additional parity bit may be added to the serial character. This bit appears after the last data bit and before the stop bit(s) in the character structure to perform simple error checking on the received data, as shown in Figure.



Fig. 15-2UART Serial protocol

#### IrDA 1.0 SIR Protocol

The Infrared Data Association (IrDA) 1.0 Serial Infrared (SIR) mode supports bi-directional datacommunications with remote devices using infrared radiation as the transmission medium. IrDA 1.0 SIR mode specifies a maximum baud rate of 115.2 Kbaud.

Transmitting a single infrared pulse signals a logic zero, while a logic one is represented by not sending a pulse. The width of each pulse is 3/16ths of a normal serial bit time. Data transfers can only occur in half-duplex fashion when IrDA SIR mode is enabled.



#### **Baud Clock**

The baud rate is controlled by the serial clock (sclk or pclk in a single clock implementation) and the Divisor Latch Register (DLH and DLL). As the exact number of baud clocks that each bit was transmitted for is known, calculating the mid-point for sampling is not difficult, that is every 16 baud clocks after the mid-point sample of the start bit.



# FIFO Support

# 1. NONE FIFO MODE

If FIFO support is not selected, then no FIFOs are implemented and only a single receive data byte and transmit data byte can be stored at a time in the RBR and THR.

#### 2. FIFO MODE

The FIFO depth of UART0/UART1/UART2/UART3/UART4/UART5 is 64bytes. The FIFO mode of all the UART is enabled by register FCR[0].

#### Interrupts

The following interrupt types can be enabled with the IER register.

- Receiver Error
- Receiver Data Available
- Character Timeout (in FIFO mode only)
- Transmitter Holding Register Empty at/below threshold (in Programmable THRE Interrupt mode)
- Modem Status

### **DMA Support**

The UART supports DMA signaling with the use of two output signals (dma\_tx\_req\_n and dma\_rx\_req\_n) to indicate when data is ready to be read or when the transmit FIFO is empty.

The dma\_tx\_req\_n signal is asserted under the following conditions:

- When the Transmitter Holding Register is empty in non-FIFO mode.
- When the transmitter FIFO is empty in FIFO mode with Programmable THRE interrupt mode disabled.
- When the transmitter FIFO is at, or below the programmed threshold with Programmable THRE interrupt mode enabled.

The dma\_rx\_req\_n signal is asserted under the following conditions:

- When there is a single character available in the Receive Buffer Register in non-FIFO mode.
- When the Receiver FIFO is at or above the programmed trigger level in FIFO mode.

### **Auto Flow Control**

The UART can be configured to have a 16750-compatible Auto RTS and Auto CTS serial data flow control mode available. If FIFOs are not implemented, then this mode cannot be selected. When Auto Flow Control mode has been selected, it can be enabled with the Modem Control Register (MCR[5]). Following figure shows a block diagram of the Auto Flow Control functionality.



Fig. 15-5 UART Auto flow control block diagram

- Auto RTS Becomes active when the following occurs:
- Auto Flow Control is selected during configuration
- FIFOs are implemented
- RTS (MCR[1] bit and MCR[5]bit are both set)
- FIFOs are enabled (FCR[0]) bit is set)
- SIR mode is disabled (MCR[6] bit is not set)



Fig. 15-6 UART AUTO RTS TIMING

- Auto CTS becomes active when the following occurs:
- Auto Flow Control is selected during configuration
- FIFOs are implemented
- AFCE (MCR[5] bit is set)
- FIFOs are enabled through FIFO Control Register FCR[0] bit
- SIR mode is disabled (MCR[6] bit is not set)





# **15.4 Register Description**

# 15.4.1 Registers Summary

| Name            | Offset | Size | Reset      | Description                       |
|-----------------|--------|------|------------|-----------------------------------|
|                 | 0000   | 14/  | Value      |                                   |
| UART_RBR        | 0x0000 | W    |            | Receive Buffer Register           |
| UART THR        | 0x0000 | W    | 0x0000000  | Transmit Holding Register         |
| UART_DLL        | 0x0000 | W    | 0x0000000  | Divisor Latch (Low)               |
| UART_DLH        | 0x0004 | W    | 0x0000000  | Divisor Latch (High)              |
| <u>UART IER</u> | 0x0004 | W    |            | Interrupt Enable Register         |
| UART_IIR        | 0x0008 | W    | 0x0000001  | Interrupt Identification Register |
| <u>UART_FCR</u> | 0x0008 | W    | 0x0000000  | FIFO Control Register             |
| <u>UART_LCR</u> | 0x000c | W    |            | Line Control Register             |
| <u>UART_MCR</u> | 0x0010 | W    | 0x0000000  | Modem Control Register            |
| <u>UART_LSR</u> | 0x0014 | W    | 0x0000060  | Line Status Register              |
| <u>UART_MSR</u> | 0x0018 | W    | 0x0000000  | Modem Status Register             |
| <u>UART_SCR</u> | 0x001c | W    | 0x00000000 | Scratchpad Register               |
| UART SRBR       | 0x0030 | W    | 0x00000000 | Shadow Receive Buffer Register    |
| UART_STHR       | 0x006c | W    | 0x00000000 | Shadow Transmit Holding Register  |
| <u>UART_FAR</u> | 0x0070 | W    | 0x00000000 | FIFO Access Register              |
| UART TFR        | 0x0074 | W    | 0x00000000 | Transmit FIFO Read                |
| UART_RFW        | 0x0078 | W    | 0x00000000 | Receive FIFO Write                |
| UART USR        | 0x007c | W    | 0x0000006  | UART Status Register              |
| UART_TFL        | 0x0080 | W    | 0x0000000  | Transmit FIFO Level               |
| UART_RFL        | 0x0084 | W    | 0x0000000  | Receive FIFO Level                |
| UART SRR        | 0x0088 | W    | 0x0000000  | Software Reset Register           |
| UART_SRTS       | 0x008c | W    | 0x00000000 | Shadow Request to Send            |
| UART SBCR       | 0x0090 | W    | 0x00000000 | Shadow Break Control Register     |
| UART SDMAM      | 0x0094 | W    | 0x00000000 | Shadow DMA Mode                   |
| UART_SFE        | 0x0098 | W    | 0x0000000  | Shadow FIFO Enable                |
| UART SRT        | 0x009c | W    | 0x00000000 | Shadow RCVR Trigger               |
| UART_STET       | 0x00a0 | W    | 0x00000000 | Shadow TX Empty Trigger           |
| UART HTX        | 0x00a4 | W    | 0x00000000 | Halt TX                           |
| UART DMASA      | 0x00a8 | W    | 0x0000000  | DMA Software Acknowledge          |
| UART_CPR        | 0x00f4 | W    | 0x00000000 | Component Parameter Register      |
| UART UCV        | 0x00f8 | W    | 0x3330382a | UART Component Version            |
| UART_CTR        | 0x00fc | W    | 0x44570110 | Component Type Register           |

# 15.4.2 Detail Register Description

# UART RBR

Address: Operational Base + offset (0x0000)

| Bit  | Attr | <b>Reset Value</b> | Description |
|------|------|--------------------|-------------|
| 31:8 | RO   | 0x0                | reserved    |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RW   | 0×00               | data_input<br>Data byte received on the serial input port (sin) in UART mode, or<br>the serial infrared input (sir_in) in infrared mode. The data in this<br>register is valid only if the Data Ready (DR) bit in the Line Status<br>Register (LCR) is set.<br>If in non-FIFO mode (FIFO_MODE == NONE) or FIFOs are<br>disabled (FCR[0] set to zero), the data in the RBR must be read<br>before the next data arrives, otherwise it is overwritten, resulting<br>in an over-run error.<br>If in FIFO mode (FIFO_MODE != NONE) and FIFOs are enabled<br>(FCR[0] set to one), this register accesses the head of the receive<br>FIFO. If the receive FIFO is full and this register is not read<br>before the next data character arrives, then the data already in<br>the FIFO is preserved, but any incoming data are lost and an<br>over-run error occurs. |

### UART\_THR

Address: Operational Base + offset (0x0000)

|        |   | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|---|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 R | 0 | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7:0 R  | W | 0×00        | data_output<br>Data to be transmitted on the serial output port (sout) in UART<br>mode or the serial infrared output (sir_out_n) in infrared mode.<br>Data should only be written to the THR when the THR Empty<br>(THRE) bit (LSR[5]) is set.<br>If in non-FIFO mode or FIFOs are disabled (FCR[0] = 0) and<br>THRE is set, writing a single character to the THR clears the<br>THRE. Any additional writes to the THR before the THRE is set<br>again causes the THR data to be overwritten.<br>If in FIFO mode and FIFOs are enabled (FCR[0] = 1) and THRE is<br>set, x number of characters of data may be written to the THR<br>before the FIFO is full. The number x (default=16) is determined<br>by the value of FIFO Depth that you set during configuration. Any<br>attempt to write data when the FIFO is full results in the write<br>data being lost. |

# UART DLL

Address: Operational Base + offset (0x0000)

| Bit  | Attr | <b>Reset Value</b> | Description |
|------|------|--------------------|-------------|
| 31:8 | RO   | 0x0                | reserved    |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RW   | 0×00               | baud_rate_divisor_L<br>Lower 8-bits of a 16-bit, read/write, Divisor Latch register that<br>contains the baud rate divisor for the UART. This register may<br>only be accessed when the DLAB bit (LCR[7]) is set and the UART<br>is not busy (USR[0] is zero).<br>The output baud rate is equal to the serial clock (sclk) frequency<br>divided by sixteen times the value of the baud rate divisor, as<br>follows: baud rate = (serial clock freq) / (16 * divisor).<br>Note that with the Divisor Latch Registers (DLL and DLH) set to<br>zero, the baud clock is disabled and no serial communications<br>occur. Also, once the DLH is set, at least 8 clock cycles of the<br>slowest Uart clock should be allowed to pass before transmitting<br>or receiving data. |

### UART\_DLH

Address: Operational Base + offset (0x0004)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                    |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                                                                       |
|      |      |                    | baud_rate_divisor_H                                                                                            |
| 7:0  | RW   |                    | Upper 8 bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. |

### <u>UART\_IER</u>

Address: Operational Base + offset (0x0004)

| Bit  | Attr | <b>Reset Value</b> | Description                                                      |
|------|------|--------------------|------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                         |
|      |      |                    | prog_thre_int_en                                                 |
|      |      |                    | Programmable THRE Interrupt Mode Enable.                         |
| 7    | RW   | 0x0                | This is used to enable/disable the generation of THRE Interrupt. |
|      |      |                    | 1'b0: disabled                                                   |
|      |      |                    | 1'b1: enabled                                                    |
| 6:4  | RO   | 0x0                | reserved                                                         |
|      |      |                    | modem_status_int_en                                              |
|      |      | W 0×0              | Enable Modem Status Interrupt.                                   |
| 3    | RW   |                    | This is used to enable/disable the generation of Modem Status    |
| 5    | ĸvv  |                    | Interrupt. This is the fourth highest priority interrupt.        |
|      |      |                    | 1'b0: disabled                                                   |
|      |      |                    | 1'b1: enabled                                                    |
|      |      |                    | receive_line_status_int_en                                       |
|      |      | W 0x0              | Enable Receiver Line Status Interrupt.                           |
| 2    | DW   |                    | This is used to enable/disable the generation of Receiver Line   |
| Z    | r vv |                    | Status Interrupt. This is the highest priority interrupt.        |
|      |      |                    | 1'b0: disabled                                                   |
|      |      |                    | 1'b1: enabled                                                    |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | RW   | 0x0                | trans_hold_empty_int_en                                                                                                                                                                                                                                                                                                                                                                     |
| 0   |      | 0×0                | Enable Transmit Holding Register Empty Interrupt<br>receive_data_available_int_en<br>Enable Received Data Available Interrupt.<br>This is used to enable/disable the generation of Received Data<br>Available Interrupt and the Character Timeout Interrupt (if in<br>FIFO mode and FIFOs enabled). These are the second highest<br>priority interrupts.<br>1'b0: disabled<br>1'b1: enabled |

# <u>UART\_IIR</u>

Address: Operational Base + offset (0x0008)

| Bit  | Attr | <b>Reset Value</b> | Description                                                        |
|------|------|--------------------|--------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                           |
|      |      |                    | fifos_en                                                           |
|      |      |                    | FIFOs Enabled.                                                     |
| 7:6  | RO   | 0x0                | This is used to indicate whether the FIFOs are enabled or          |
| 7.0  | KU   | 0.00               | disabled.                                                          |
|      |      |                    | 2'b00: disabled                                                    |
|      |      |                    | 2'b11: enabled                                                     |
| 5:4  | RO   | 0x0                | reserved                                                           |
|      |      | 0 0×1              | int_id                                                             |
|      | RO   |                    | Interrupt ID.                                                      |
|      |      |                    | This indicates the highest priority pending interrupt which can be |
|      |      |                    | one of the following types:                                        |
|      |      |                    | 4'b0000: modem status                                              |
| 3:0  |      |                    | 4'b0001: no interrupt pending                                      |
|      |      |                    | 4'b0010: THR empty                                                 |
|      |      |                    | 4'b0100: received data available                                   |
|      |      |                    | 4'b0110: receiver line status                                      |
|      |      |                    | 4'b0111: busy detect                                               |
|      |      |                    | 4'b1100: character timeout                                         |

# UART\_FCR

Address: Operational Base + offset (0x0008)

| Bit  | Attr | <b>Reset Value</b> |          | Description |  |
|------|------|--------------------|----------|-------------|--|
| 31:8 | RO   | 0x0                | reserved |             |  |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6 | wo   | 0×0                | rcvr_trigger<br>RCVR Trigger.<br>This is used to select the trigger level in the receiver FIFO at<br>which the Received Data Available Interrupt is generated. In auto<br>flow control mode it is used to determine when the rts_n signal is<br>de-asserted. It also determines when the dma_rx_req_n signal is<br>asserted in certain modes of operation. The following trigger<br>levels are supported:<br>2'b00: 1 character in the FIFO<br>2'b01: FIFO 1/4 full<br>2'b10: FIFO 1/2 full<br>2'b11: FIFO 2 less than ful |
| 5:4 | wo   | 0×0                | <pre>tx_empty_trigger<br/>TX Empty Trigger.<br/>This is used to select the empty threshold level at which the THRE<br/>Interrupts are generated when the mode is active. It also<br/>determines when the dma_tx_req_n signal is asserted when in<br/>certain modes of operation. The following trigger levels are<br/>supported:<br/>2'b00: FIFO empty<br/>2'b01: 2 characters in the FIFO<br/>2'b10: FIFO 1/4 full<br/>2'b11: FIFO 1/2 full</pre>                                                                         |
| 3   | wo   | 0×0                | dma_mode<br>DMA Mode.<br>This determines the DMA signalling mode used for the<br>dma_tx_req_n and dma_rx_req_n output signals when additional<br>DMA handshaking signals are not selected .<br>1'b0: mode 0<br>1'b1: mode 1                                                                                                                                                                                                                                                                                                |
| 2   | wo   | 0×0                | xmit_fifo_reset<br>XMIT FIFO Reset.<br>This resets the control portion of the transmit FIFO and treats the<br>FIFO as empty. This also de-asserts the DMA TX request and<br>single signals when additional DMA handshaking signals are<br>selected . Note that this bit is 'self-clearing'. It is not necessary to<br>clear this bit.                                                                                                                                                                                      |
| 1   | wo   | 0x0                | rcvr_fifo_reset<br>RCVR FIFO Reset.<br>This resets the control portion of the receive FIFO and treats the<br>FIFO as empty. This also de-asserts the DMA RX request and<br>single signals when additional DMA handshaking signals are<br>selected. Note that this bit is 'self-clearing'. It is not necessary to<br>clear this bit.                                                                                                                                                                                        |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                              |
|-----|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | wo   | 0×0                | fifo_en<br>FIFO Enable. This enables/disables the transmit (XMIT) and<br>receive (RCVR) FIFOs. Whenever the value of this bit is changed<br>both the XMIT and RCVR controller portion of FIFOs is reset. |

# UART\_LCR

Address: Operational Base + offset (0x000c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7    | RW   | 0×0                | div_lat_access<br>Divisor Latch Access Bit.<br>Writeable only when UART is not busy (USR[0] is zero), always<br>readable. This bit is used to enable reading and writing of the<br>Divisor Latch register (DLL and DLH) to set the baud rate of the<br>UART. This bit must be cleared after initial baud rate setup in<br>order to access other registers.                                                                                                                                                                        |
| 6    | RW   | 0×0                | break_ctrl<br>Break Control Bit.<br>This is used to cause a break condition to be transmitted to the<br>receiving device. If set to one the serial output is forced to the<br>spacing (logic 0) state. When not in Loopback Mode, as<br>determined by MCR[4], the sout line is forced low until the Break<br>bit is cleared. If MCR[6] set to one, the sir_out_n line is<br>continuously pulsed. When in Loopback Mode, the break condition<br>is internally looped back to the receiver and the sir_out_n line is<br>forced low. |
| 5    | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4    | RW   | 0×0                | even_parity_sel<br>Even Parity Select.<br>Writeable only when UART is not busy (USR[0] is zero), always<br>readable. This is used to select between even and odd parity,<br>when parity is enabled (PEN set to one). If set to one, an even<br>number of logic 1s is transmitted or checked. If set to zero, an<br>odd number of logic 1s is transmitted or checked                                                                                                                                                               |
| 3    | RW   | 0x0                | parity_en<br>Parity Enable.<br>Writeable only when UART is not busy (USR[0] is zero), always<br>readable. This bit is used to enable and disable parity generation<br>and detection in transmitted and received serial character<br>respectively.<br>1'b0: parity disabled<br>1'b1: parity enabled                                                                                                                                                                                                                                |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | RW   | 0x0                | stop_bits_num<br>Number of stop bits.<br>Writeable only when UART is not busy (USR[0] is zero), always<br>readable. This is used to select the number of stop bits per<br>character that the peripheral transmits and receives. If set to<br>zero, one stop bit is transmitted in the serial data.If set to one<br>and the data bits are set to 5 (LCR[1:0] set to zero) one and a<br>half stop bits is transmitted. Otherwise, twostop bits are<br>transmitted. Note that regardless of the number of stop bits<br>selected, the receiver checks only the first stop bit.<br>1'b0: 1 stop bit<br>1'b1: 1.5 stop bits when DLS (LCR[1:0]) is zero, else 2 stop bit. |
| 1:0 | RW   | 0×0                | data_length_sel<br>Data Length Select.<br>Writeable only when UART is not busy (USR[0] is zero), always<br>readable. This is used to select the number of data bits per<br>character that the peripheral transmits and receives. The number<br>of bit that may be selected areas follows:<br>2'b00: 5 bits<br>2'b01: 6 bits<br>2'b11: 6 bits<br>2'b11: 8 bits                                                                                                                                                                                                                                                                                                       |

 UART\_MCR

 Address: Operational Base + offset (0x0010)

| Bit  | Attr | <b>Reset Value</b> | Description                                                  |
|------|------|--------------------|--------------------------------------------------------------|
| 31:7 | RO   | 0x0                | reserved                                                     |
|      |      |                    | sir_mode_en                                                  |
|      |      |                    | SIR Mode Enable.                                             |
| 6    | RW   | 0x0                | This is used to enable/disable the IrDA SIR Mode .           |
|      |      |                    | 1'b0: IrDA SIR Mode disabled                                 |
|      |      |                    | 1'b1: IrDA SIR Mode enabled                                  |
|      |      | 0x0                | auto_flow_ctrl_en                                            |
| 5    | RW   |                    | Auto Flow Control Enable.                                    |
| 5    | ĸvv  |                    | 1'b0: Auto Flow Control Mode disabled                        |
|      |      |                    | 1'b1: Auto Flow Control Mode enabled                         |
|      |      |                    | loopback                                                     |
| 1    |      |                    | LoopBack Bit.                                                |
| 4    | RW   | 0x0                | This is used to put the UART into a diagnostic mode for test |
|      |      |                    | purposes                                                     |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                         |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | out2<br>OUT2.                                                                                                                                                                                                                                                                                                                                       |
| 3   | RW   | 0×0         | This is used to directly control the user-designated Output2<br>(out2_n) output. The value written to this location is inverted and                                                                                                                                                                                                                 |
| 5   |      | 0.00        | driven out on out2_n, that is:                                                                                                                                                                                                                                                                                                                      |
|     |      |             | 1'b0: out2_n de-asserted (logic 1)<br>1'b1: out2_n asserted (logic 0)                                                                                                                                                                                                                                                                               |
| 2   | RW   | 0x0         | out1<br>OUT1                                                                                                                                                                                                                                                                                                                                        |
| 1   | RW   | 0×0         | req_to_send<br>Request to Send.<br>This is used to directly control the Request to Send (rts_n)<br>output. The Request To Send (rts_n) output is used to inform the                                                                                                                                                                                 |
| 0   | RW   | 0×0         | modem or data set that the UART is ready to exchange data.<br>data_terminal_ready<br>Data Terminal Ready.<br>This is used to directly control the Data Terminal Ready (dtr_n)<br>output. The value written to this location is inverted and driven<br>out on dtr_n, that is:<br>1'b0: dtr_n de-asserted (logic 1)<br>1'b1: dtr_n asserted (logic 0) |

# UART\_LSR

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                      |
|------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                         |
| 7    | RO   | 0×0                | receiver_fifo_error<br>Receiver FIFO Error bit. This bit is relevant FIFOs are enabled<br>(FCR[0] set to one). This is used to indicate if there is at least<br>one parity error, framing error, or break indication in the FIFO.<br>1'b0: no error in RX FIFO<br>1'b1: error in RX FIFO                         |
| 6    | RO   | 0×1                | trans_empty<br>Transmitter Empty bit. If FIFOs enabled (FCR[0] set to one), this<br>bit is set whenever the Transmitter Shift Register and the FIFO<br>are both empty. If FIFOs are disabled, this bit is set whenever the<br>Transmitter Holding Register and the Transmitter Shift Register<br>are both empty. |

| Bit | Attr | Reset Value | Description                                                       |
|-----|------|-------------|-------------------------------------------------------------------|
|     |      |             | trans_hold_reg_empty                                              |
|     |      |             | Transmit Holding Register Empty bit.                              |
|     |      |             | If THRE mode is disabled (IER[7] set to zero) and regardless of   |
|     |      |             | FIFO's being implemented/enabled or not, this bit indicates that  |
|     |      |             | the THR or TX FIFO is empty.                                      |
|     |      |             | This bit is set whenever data is transferred from the THR or TX   |
| 5   | RO   | 0x1         | FIFO to the transmitter shift register and no new data has been   |
|     |      |             | written to the THR or TX FIFO. This also causes a THRE Interrupt  |
|     |      |             | to occur, if the THRE Interrupt is enabled. If IER[7] set to one  |
|     |      |             | and FCR[0] set to one respectively, the functionality is switched |
|     |      |             | to indicate the transmitter FIFO is full, and no longer controls  |
|     |      |             | THRE interrupts, which are then controlled by the FCR[5:4]        |
|     |      |             | threshold setting                                                 |
|     |      |             | break_int                                                         |
| 4   | RO   | 0x0         | Break Interrupt bit.                                              |
|     |      |             | This is used to indicate the detection of a break sequence on the |
|     |      |             | serial input data.                                                |
|     |      | 0×0         | framing_error<br>Framing Error bit.                               |
| 3   | RO   |             | This is used to indicate the occurrence of a framing error in the |
| 5   |      |             | receiver. A framing error occurs when the receiver does not       |
|     |      |             | detect a valid STOP bit in the received data.                     |
|     |      |             | parity_eror                                                       |
| _   |      | 0x0         | Parity Error bit.                                                 |
| 2   | RO   |             | This is used to indicate the occurrence of a parity error in the  |
|     |      |             | receiver if the Parity Enable (PEN) bit (LCR[3]) is set.          |
|     |      |             | overrun_error                                                     |
|     |      |             | Overrun error bit.                                                |
| 1   | RO   | 0x0         | This is used to indicate the occurrence of an overrun error. This |
|     |      |             | occurs if a new data character was received before the previous   |
|     |      |             | data was read.                                                    |
|     |      |             | data_ready                                                        |
|     |      |             | Data Ready bit.                                                   |
| 0   | RO   | O 0x0       | This is used to indicate that the receiver contains at least one  |
|     | _    |             | character in the RBR or the receiver FIFO.                        |
|     |      |             | 1'b0: no data ready                                               |
|     |      |             | 1'b1: data ready                                                  |

### <u>UART\_MSR</u>

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description |
|------|------|--------------------|-------------|
| 31:8 | RO   | 0x0                | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                       |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RO   | 0×0         | data_carrior_detect<br>Data Carrier Detect.<br>This is used to indicate the current state of the modem control<br>line dcd_n.                                                                                                     |
| 6   | RO   | 0x0         | ring_indicator<br>Ring Indicator.<br>This is used to indicate the current state of the modem control<br>line ri_n.                                                                                                                |
| 5   | RO   | 0x0         | data_set_ready<br>Data Set Ready.<br>This is used to indicate the current state of the modem control<br>line dsr_n.                                                                                                               |
| 4   | RO   | 0×0         | clear_to_send<br>Clear to Send.<br>This is used to indicate the current state of the modem control<br>line cts_n.                                                                                                                 |
| 3   | RO   | 0x0         | delta_data_carrier_detect<br>Delta Data Carrier Detect.<br>This is used to indicate that the modem control line dcd_n has<br>changed since the last time the MSR was read.                                                        |
| 2   | RO   | 0x0         | trailing_edge_ring_indicator<br>Trailing Edge of Ring Indicator. This is used to indicate that a<br>change on the input ri_n (from an active-low to an inactive-high<br>state) has occurred since the last time the MSR was read. |
| 1   | RO   | 0x0         | delta_data_set_ready<br>Delta Data Set Ready.<br>This is used to indicate that the modem control line dsr_n has<br>changed since the last time the MSR was read.                                                                  |
| 0   | RO   | 0×0         | delta_clear_to_send<br>Delta Clear to Send.<br>This is used to indicate that the modem control line cts_n has<br>changed since the last time the MSR was read.                                                                    |

# <u>UART\_SCR</u>

Address: Operational Base + offset (0x001c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                 |
|------|------|--------------------|---------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                                                    |
| 7:0  | RW   |                    | temp_store_space<br>This register is for programmers to use as a temporary storage<br>space |

# UART SRBR

Address: Operational Base + offset (0x0030)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7:0  | RO   | 0×00               | shadow_rbr<br>This is a shadow register for the RBR and has been allocated<br>sixteen 32-bit locations so as to accommodate burst accesses<br>from the master. This register contains the data byte received on<br>the serial input port (sin) in UART mode or the serial infrared<br>input (sir_in) in infrared mode. The data in this register is valid<br>only if the Data Ready (DR) bit in the Line status Register (LSR)<br>is set.<br>If FIFOs are disabled (FCR[0] set to zero), the data in the RBR<br>must be read before the next data arrives, otherwise it is<br>overwritten, resulting in an overrun error.<br>If FIFOs are enabled (FCR[0] set to one), this register accesses<br>the head of the receive FIFO. If the receive FIFO is full and this<br>register is not read before the next data character arrives, then<br>the data already in the FIFO are preserved, but any incoming<br>data is lost. An overrun error also occurs. |

# UART STHR

Address: Operational Base + offset (0x006c)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                             |
| 7:0  | RO   | 0x00               | shadow_thr<br>This is a shadow register for the THR. |

### UART FAR

Address: Operational Base + offset (0x0070)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0    | RW   | 0×0                | fifo_access_test_en<br>This register is use to enable a FIFO access mode for testing, so<br>that the receive FIFO can be written by the master and the<br>transmit FIFO can be read by the master when FIFOs are<br>implemented and enabled. When FIFOs are not enabled it allows<br>the RBR to be written by the master and the THR to be read by<br>the master.<br>1'b0: FIFO access mode disabled<br>1'b1: FIFO access mode enabled |

# UART\_TFR

Address: Operational Base + offset (0x0074)

| Bit  | Attr | <b>Reset Value</b> |          | Description |  |
|------|------|--------------------|----------|-------------|--|
| 31:8 | RO   | 0x0                | reserved |             |  |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RO   | 0×00               | trans_fifo_read<br>Transmit FIFO Read.<br>These bits are only valid when FIFO access mode is enabled<br>(FAR[0] is set to one).When FIFOs are implemented and enabled,<br>reading this register gives the data at the top of the transmit<br>FIFO. Each consecutive read pops the transmit FIFO and gives<br>the next data value that is currently at the top of the FIFO |

### UART\_RFW

Address: Operational Base + offset (0x0078)

| Bit   | Attr | <b>Reset Value</b>              | Description                                                                                                        |
|-------|------|---------------------------------|--------------------------------------------------------------------------------------------------------------------|
| 31:10 | RO   | 0x0                             | reserved                                                                                                           |
|       |      |                                 | receive_fifo_framing_error                                                                                         |
| 9     | wo   | 0x0                             | Receive FIFO Framing Error.                                                                                        |
| 5     | vvO  | 0.00                            | These bits are only valid when FIFO access mode is enabled                                                         |
|       |      |                                 | (FAR[0] is set to one).                                                                                            |
|       |      |                                 | receive_fifo_parity_error                                                                                          |
| 8     | wo   | O 0x0 Receive FIFO Parity Error | Receive FIFO Parity Error.                                                                                         |
| 0     | **0  | 0.00                            | These bits are only valid when FIFO access mode is enabled<br>(FAR[0] is set to one).<br>receive_fifo_parity_error |
|       |      |                                 | (FAR[0] is set to one).                                                                                            |
|       |      |                                 | receive_fifo_write                                                                                                 |
|       |      |                                 | Receive FIFO Write Data.                                                                                           |
|       |      |                                 | These bits are only valid when FIFO access mode is enabled                                                         |
|       |      |                                 | (FAR[0] is set to one). When FIFOs are enabled, the data that is                                                   |
| 7:0   | WO   | 0x00                            | written to the RFWD is pushed into the receive FIFO. Each                                                          |
|       |      |                                 | consecutive write pushes the new data to the next write location                                                   |
|       |      |                                 | in the receive FIFO.                                                                                               |
|       |      |                                 | When FIFOs not enabled, the data that is written to the RFWD is                                                    |
|       |      |                                 | pushed into the RBR                                                                                                |

# UART USR

Address: Operational Base + offset (0x007c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                        |
|------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x0                | reserved                                                                                                                                                                                                                           |
| 4    | RO   | 0x0                | receive_fifo_full<br>Receive FIFO Full.<br>This is used to indicate that the receive FIFO is completely full.<br>1'b0: Receive FIFO not full<br>1'b1: Receive FIFO Full<br>This bit is cleared when the RX FIFO is no longer full. |

| Bit | Attr                     | Reset Value                                                              | Description                                                    |
|-----|--------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------|
|     |                          |                                                                          | receive_fifo_not_empty                                         |
|     |                          |                                                                          | Receive FIFO Not Empty.                                        |
|     |                          |                                                                          | This is used to indicate that the receive FIFO contains one or |
| 3   | RO                       | 0x0                                                                      | more entries.                                                  |
|     |                          |                                                                          | 1'b0: Receive FIFO is empty                                    |
|     |                          |                                                                          | 1'b1: Receive FIFO is not empty                                |
|     |                          |                                                                          | This bit is cleared when the RX FIFO is empty.                 |
|     |                          |                                                                          | trasn_fifo_empty                                               |
|     |                          |                                                                          | Transmit FIFO Empty.                                           |
|     |                          |                                                                          | This is used to indicate that the transmit FIFO is completely  |
| 2   | RO                       | 0x1                                                                      | empty.                                                         |
|     |                          |                                                                          | 1'b0: Transmit FIFO is not empty                               |
|     |                          |                                                                          | 1'b1: Transmit FIFO is empty                                   |
|     |                          |                                                                          | This bit is cleared when the TX FIFO is no longer empty.       |
|     |                          |                                                                          | trans_fifo_not_full                                            |
|     |                          |                                                                          | Transmit FIFO Not Full.                                        |
| 1   | RO                       | RO 0x1<br>1'b0: Transmit FIFO is full<br>1'b1: Transmit FIFO is not full | This is used to indicate that the transmit FIFO in not full.   |
| 1   |                          |                                                                          | 1'b0: Transmit FIFO is full                                    |
|     |                          |                                                                          | 1'b1: Transmit FIFO is not full                                |
|     |                          |                                                                          | This bit is cleared when the TX FIFO is full.                  |
|     |                          |                                                                          | uart_busy                                                      |
|     | UART Busy. This is indic | UART Busy. This is indicates that a serial transfer is in progress,      |                                                                |
| 0   | RO                       | 0x0                                                                      | when cleared indicates that the uart is idle or inactive.      |
|     |                          |                                                                          | 1'b0: Uart is idle or inactive                                 |
|     |                          |                                                                          | 1'b1: Uart is busy (actively transferring data)                |

### UART\_TFL

Address: Operational Base + offset (0x0080)

| Bit  | Attr | <b>Reset Value</b> | Description                                                       |  |
|------|------|--------------------|-------------------------------------------------------------------|--|
| 31:5 | RO   | 0x0                | served                                                            |  |
|      |      |                    | trans_fifo_level                                                  |  |
| 4:0  | RW   | 0x00               | Transmit FIFO Level. This is indicates the number of data entries |  |
|      |      |                    | in the transmit FIFO.                                             |  |

# UART\_RFL

Address: Operational Base + offset (0x0084)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                    |  |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------|--|
| 31:5 | RO   | 0x0                | served                                                                                                         |  |
| 4:0  | RO   | 0x00               | receive_fifo_level<br>Receive FIFO Level. This is indicates the number of data entries<br>in the receive FIFO. |  |

#### UART SRR

Address: Operational Base + offset (0x0088)

| Bit  | Attr | <b>Reset Value</b> | Description                                                       |  |  |  |  |
|------|------|--------------------|-------------------------------------------------------------------|--|--|--|--|
| 31:3 | RO   | 0x0                | reserved                                                          |  |  |  |  |
|      |      |                    | xmit_fifo_reset                                                   |  |  |  |  |
| 2    | WO   | 0x0                | XMIT FIFO Reset.                                                  |  |  |  |  |
|      |      |                    | This is a shadow register for the XMIT FIFO Reset bit (FCR[2]).   |  |  |  |  |
|      |      |                    | rcvr_fifo_reset                                                   |  |  |  |  |
| 1    | WO   | 0x0                | RCVR FIFO Reset.                                                  |  |  |  |  |
|      |      |                    | This is a shadow register for the RCVR FIFO Reset bit (FCR[1]).   |  |  |  |  |
|      |      |                    | uart_reset                                                        |  |  |  |  |
|      |      |                    | UART Reset.                                                       |  |  |  |  |
| 0    | WO   | 0x0                | This asynchronously resets the Uart and synchronously removes     |  |  |  |  |
|      |      |                    | the reset assertion. For a two clock implementation both pclk and |  |  |  |  |
|      |      |                    | sclk domains are reset.                                           |  |  |  |  |

#### UART SRTS

Address: Operational Base + offset (0x008c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |  |  |  |
|------|------|--------------------|-----------------------------------------------------------------|--|--|--|
| 31:1 | RO   | 0x0                | reserved                                                        |  |  |  |
|      | RW   | 0x0                | shadow_req_to_send                                              |  |  |  |
|      |      |                    | Shadow Request to Send.                                         |  |  |  |
| 0    |      |                    | This is a shadow register for the RTS bit (MCR[1]), this can be |  |  |  |
|      |      |                    | used to remove the burden of having to performing a read-       |  |  |  |
|      |      |                    | modify-write on the MCR.                                        |  |  |  |

### UART\_SBCR

Address: Operational Base + offset (0x0090)

| Bit  | Attr | <b>Reset Value</b> | Description                                                       |  |  |  |
|------|------|--------------------|-------------------------------------------------------------------|--|--|--|
| 31:1 | RO   | 0x0                | reserved                                                          |  |  |  |
|      | RW   | 0×0                | shadow_break_ctrl                                                 |  |  |  |
|      |      |                    | Shadow Break Control Bit.                                         |  |  |  |
| 0    |      |                    | This is a shadow register for the Break bit (LCR[6]), this can be |  |  |  |
|      |      |                    | used to remove the burden of having to performing a read modify   |  |  |  |
|      |      |                    | write on the LCR.                                                 |  |  |  |

# UART SDMAM

Address: Operational Base + offset (0x0094)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                     |  |  |  |  |
|------|------|--------------------|-------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:1 | RO   | 0x0                | reserved                                                                                        |  |  |  |  |
| 0    | RW   | 0x0                | shadow_dma_mode<br>Shadow DMA Mode. This is a shadow register for the DMA mode<br>bit (FCR[3]). |  |  |  |  |

## UART\_SFE

Address: Operational Base + offset (0x0098)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                              |  |  |  |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:1 | RO   | 0x0                | reserved                                                                                                                 |  |  |  |
| 0    | RW   | 0x0                | shadow_fifo_en<br>Shadow FIFO Enable. Shadow FIFO Enable. This is a shadow<br>register for the FIFO enable bit (FCR[0]). |  |  |  |

#### UART\_SRT

Address: Operational Base + offset (0x009c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                    |  |  |  |  |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:2 | RO   | 0x0                | reserved                                                                                                       |  |  |  |  |
| 1:0  | RW   | 0x0                | shadow_rcvr_trigger<br>Shadow RCVR Trigger. This is a shadow register for the RCVR<br>trigger bits (FCR[7:6]). |  |  |  |  |

#### UART\_STET

Address: Operational Base + offset (0x00a0)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                |  |  |  |  |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:2 | RO   | 0x0                | reserved                                                                                                                   |  |  |  |  |
| 1:0  | RW   | 0x0                | shadow_tx_empty_trigger<br>Shadow TX Empty Trigger. This is a shadow register for the TX<br>empty trigger bits (FCR[5:4]). |  |  |  |  |

#### UART HTX

Address: Operational Base + offset (0x00a4)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                  |  |  |  |  |
|------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:1 | RO   | 0x0                | reserved                                                                                                                                                                                                                     |  |  |  |  |
| 0    | RW   | 0x0                | halt_tx_en<br>This register is use to halt transmissions for testing, so that the<br>transmit FIFO can be filled by the master when FIFOs are<br>implemented and enabled.<br>1'b0: Halt TX disabled<br>1'b1: Halt TX enabled |  |  |  |  |

### UART\_DMASA

Address: Operational Base + offset (0x00a8)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |  |  |  |
|------|------|--------------------|-----------------------------------------------------------------|--|--|--|
| 31:1 | RO   | 0x0                | reserved                                                        |  |  |  |
|      |      |                    | dma_software_ack                                                |  |  |  |
| 0    | WO   | 0x0                | This register is use to perform a DMA software acknowledge if a |  |  |  |
|      |      |                    | transfer needs to be terminated due to an error condition.      |  |  |  |

#### UART\_CPR

Address: Operational Base + offset (0x00f4)

| Bit   | Attr | <b>Reset Value</b> | Description             |
|-------|------|--------------------|-------------------------|
| 31:24 |      | 0x0                | reserved                |
| 01121 |      |                    | FIFO_MODE               |
|       |      |                    | 8'h00: 0                |
|       |      |                    | 8'h01: 16               |
| 23:16 | RO   | 0x00               | 8'h02: 32               |
| 23110 |      | 0,00               | to                      |
|       |      |                    | 8'h80: 2048             |
|       |      |                    | 8'h81- 8'hff: reserved  |
| 15:14 | RO   | 0x0                | reserved                |
| 13111 | i co | 0,00               | DMA_EXTRA               |
| 13    | RO   | 0x0                | 1'b0: FALSE             |
| 13    | NO   | 0,0                | 1'b1: TRUE              |
|       |      |                    | UART ADD ENCODED PARAMS |
| 12    | RO   | 0x0                | 1'b0: FALSE             |
| 12    | NO   | 0,0                | 1'b1: TRUE              |
|       |      |                    | SHADOW                  |
| 11    | RO   | 0x0                | 1'b0: FALSE             |
| ± ±   | NO   | 0,0                | 1'b1: TRUE              |
|       |      |                    | FIFO_STAT               |
| 10    | RO   | 0×0                | 1'b0: FALSE             |
| 10    |      |                    | 1'b1: TRUE              |
|       |      |                    | FIFO_ACCESS             |
| 9     | RO   | 0×0                | 1'b0: FALSE             |
| 2     |      |                    | 1'b1: TRUE              |
|       |      |                    | NEW_FEAT                |
| 8     | RO   | 0×0                | 1'b0: FALSE             |
| •     |      |                    | 1'b1: TRUE              |
|       |      |                    | SIR_LP_MODE             |
| 7     | RO   | 0×0                | 1'b0: FALSE             |
| -     |      |                    | 1'b1: TRUE              |
|       |      |                    | SIR_MODE                |
| 6     | RO   | 0x0                | 1'b0: FALSE             |
|       |      |                    | 1'b1: TRUE              |
|       |      |                    | THRE_MODE               |
| 5     | RO   | 0x0                | 1'b0: FALSE             |
|       |      |                    | 1'b1: TRUE              |
|       |      |                    | AFCE_MODE               |
| 4     | RO   | 0x0                | 1'b0: FALSE             |
|       |      |                    | 1'b1: TRUE              |
| 3:2   | RO   | 0x0                | reserved                |
|       |      |                    | APB_DATA_WIDTH          |
|       |      |                    | 2'b00: 8 bits           |
| 1:0   | RO   | 0x0                | 2'b01: 16 bits          |
|       |      |                    | 2'b10: 32 bits          |
|       |      |                    | 2'b11: reserved         |

#### UART\_UCV

Address: Operational Base + offset (0x00f8)

| Bit  | Attr | <b>Reset Value</b> | Description                                        |
|------|------|--------------------|----------------------------------------------------|
| 31:0 | RO   | 0x3330382a         | ver<br>ASCII value for each number in the version. |

#### UART\_CTR

Address: Operational Base + offset (0x00fc)

| Bit  | Attr | <b>Reset Value</b> | Description |           |                                   |            |  |
|------|------|--------------------|-------------|-----------|-----------------------------------|------------|--|
| 31:0 | PO   | 0x44570110         | periphera   | l_id      |                                   |            |  |
| 31:0 | ĸŬ   |                    | This regis  | ter conta | tains the peripherals identificat | tion code. |  |

# **15.5 Interface Description**

| Table 15-1 UART Interface Description |     |                                |                                  |  |  |
|---------------------------------------|-----|--------------------------------|----------------------------------|--|--|
| Modulepin                             | Dir | Pin name                       | ΙΟΜUΧ                            |  |  |
|                                       |     | UART0 Interface                |                                  |  |  |
| uart0_sin                             | Ι   | GPIO2_A0/UART0_RX/SPI0_MISO    | GRF_GPIO2A_IOMUX[1:0]=2′b01      |  |  |
| uart0_sout                            | 0   | GPIO2_A1/UART0_TX/SPI0_MOSI    | GRF_GPIO2A_IOMUX[3:2]=2'b01      |  |  |
| uart0_cts_n                           | Ι   | GPIO2_A2/UART0_CTSN/SPI0_CLK/I | GRF_GPIO2A_IOMUX[5:4]=2'b01      |  |  |
|                                       |     | 2C2_SDA                        |                                  |  |  |
| uart0_rts_n                           | 0   | GPIO2_A3/UART0_RTSN/SPI0_CSN0  | GRF_GPIO2A_IOMUX[7:6]=2'b01      |  |  |
|                                       |     | /I2C2_SCL                      |                                  |  |  |
|                                       |     | UART1 Interface                |                                  |  |  |
| uart1_sin                             | Ι   | GPIO1_D0/UART1_RX/I2C0_SDA/SPI | GRF_GPIO1D_IOMUX[1:0]= 2'b01     |  |  |
|                                       |     | 2_CLK                          |                                  |  |  |
| uart1_sout                            | 0   | GPIO1_D1/UART1_TX/I2C0_SCL/SPI | GRF_GPIO1D_IOMUX[3:2]= 2'b01     |  |  |
|                                       |     | 2_CSN0                         |                                  |  |  |
| uart1_cts_n                           | Ι   | GPIO1_C6/UART1_CTSN/UART2_RX_  | GRF_GPIO1C_IOMUX_H[7:4]= 4'b0001 |  |  |
|                                       |     | M0/SPI2_MISO/JTAG_TCK          |                                  |  |  |
| uart1_rts_n                           | 0   | GPIO1_C7/UART1_RTSN/UART2_TX_  | GRF_GPIO1C_IOMUX_H[11:8]=4'b000  |  |  |
|                                       |     | M0/SPI2_MOSI/JTAG_TMS          | 1                                |  |  |
|                                       |     | UART2m0 Interfac               | e                                |  |  |
| uart2m0_sin                           | Ι   | GPIO1_C6/UART1_CTSN/UART2_RX_  | GRF_GPIO1C_IOMUX_H[7:4]=4'b0010  |  |  |
|                                       |     | M0/SPI2_MISO/JTAG_TCK          |                                  |  |  |
| uart2m0_sout                          | 0   | GPIO1_C7/UART1_RTSN/UART2_TX_  | GRF_GPIO1C_IOMUX_H[11:8]=4'b001  |  |  |
|                                       |     | M0/SPI2_MOSI/JTAG_TMS          | 0                                |  |  |
|                                       |     | UART2m1 Interfac               | e                                |  |  |
| uart2m1_sin                           | Ι   | GPIO4_D2/SDMMC_D2/UART2_RX_M   | GRF_GPIO4D_IOMUX[5:4]=2'b10      |  |  |
|                                       |     | 1                              |                                  |  |  |
| uart2m1_sout                          | 0   | GPIO4_D3/SDMMC_D3/UART2_TX_M   | GRF_GPIO4D_IOMUX[7:6]=2'b10      |  |  |
|                                       |     | 1                              |                                  |  |  |
|                                       |     | UART3 Interface                |                                  |  |  |

|            |      | • · · ·   | <b>D</b>    |
|------------|------|-----------|-------------|
| Table 15-1 | UART | Interface | Description |

| Modulepin   | Dir             | Pin name                      | ΙΟΜUΧ                           |  |  |  |
|-------------|-----------------|-------------------------------|---------------------------------|--|--|--|
| uart3_sin   | Ι               | GPIO3_B4/FLASH_RDY/I2C3_SDA_M | GRF_GPIO3B_IOMUX[11:8]=4'b0100  |  |  |  |
|             |                 | 1/SPI1_MOSI/UART3_RX          |                                 |  |  |  |
| uart3_sout  | 0               | GPIO3_B5/FLASH_CSN0/I2C3_SCL_ | GRF_GPIO3B_IOMUX[15:12]=4'b0100 |  |  |  |
|             |                 | M1/SPI1_CSN0/UART3_TX         |                                 |  |  |  |
|             | UART4 Interface |                               |                                 |  |  |  |
| uart4_sin   | Ι               | GPIO4_B0/UART4_RX             | GRF_GPIO4B_IOMUX[1:0]=2'b01     |  |  |  |
| uart4_sout  | 0               | GPIO4_B1/UART4_TX             | GRF_GPIO4B_IOMUX[3:2]= 2'b01    |  |  |  |
| uart4_cts_n | Ι               | GPIO4_A6/UART4_CTSN           | GRF_GPIO4A_IOMUX[13:12]=2'b01   |  |  |  |
| uart4_rts_n | 0               | GPIO4_A7/UART4_RTSN           | GRF_GPIO4A_IOMUX[15:14]=2'b01   |  |  |  |

The I/O interface of UART2 can be chosen by setting GRF\_SOC\_CON5[3:2]bit, if those bit is set to 2'b01, UART2 uses the UART2m1 I/O interface, if those bit is set to 2'b10, UART2 uses the internal usbphy uart debug port.

# **15.6 Application Notes**

# 15.6.1 None FIFO Mode Transfer Flow



Fig. 15-8 UART none fifo mode

## 15.6.2 FIFO Mode Transfer Flow



Fig. 15-9 UART Serial protocol

The UART is an APB slave performing:

Serial-to-parallel conversion on data received from a peripheral device.

Parallel-to-serial conversion on data transmitted to the peripheral device.

The CPU reads and writes data and control/status information through the APB interface. The transmitting and receiving paths are buffered with internal FIFO memories enabling up to 64-bytes to be stored independently in both transmit and receive modes. A baud rate generator can generate a common transmit and receive internal clock input. The baud rates will depend on the internal clock frequency. The UART will also provide transmit, receive and exception interrupts to system. A DMA interface is implemented for improving the system performance.

## 15.6.3 Baud Rate Calculation

#### **UART clock generation**

The following figures shows the UART clock generation.UART0~4 source clocks can be selected from five PLL outputs (XIN\_OSC0\_FUNC/DPLL\_CLK\_MUX/USBPHY\_480M/ VPLL1\_CLK\_MUX/VPLL0\_MUX).

UART clocks can be generated by 1 to 32 division of its source clock, or can be fractionally divided again.



Fig. 15-10 UART clock generation

#### UART baud rate configuration

The following table provides some reference configuration for different UART baud rates. Table 15-2 UART baud rate configuration

| <b>Baud Rate</b> | Reference Configuration                                    |
|------------------|------------------------------------------------------------|
| 115.2 Kbps       | Configure DPLL to get 1200MHz clock output;                |
|                  | Divide 1200MHz clock by 46875/72 to get 1.8432MHz clock;   |
|                  | Configure UART_DLL to 1.                                   |
| 460.8 Kbps       | Configure DPLL to get 1200MHz clock output;                |
|                  | Divide 1200MHz clock by 46875/288 to get 7.3728MHz clock;  |
|                  | Configure UART_DLL to 1.                                   |
| 921.6 Kbps       | Configure DPLL to get 1200MHz clock output;                |
|                  | Divide 1200MHz clock by 46875/576 to get 14.7456MHz clock; |
|                  | Configure UART_DLL to 1.                                   |
| 1.5 Mbps         | Choose DPLL to get 1200MHz clock output;                   |
|                  | Divide 1200MHz clock by 50 to get 24MHz clock;             |
|                  | Configure UART_DLL to 1.                                   |
| 3 Mbps           | Choose DPLL to get 1200MHz clock output;                   |
|                  | Divide 1200MHz clock by 1200/48 to get 48MHz clock;        |
|                  | Configure UART_DLL to 1.                                   |
| 4 Mbps           | Configure DPLL to get 1200MHz clock output;                |
|                  | Divide 1200MHz clock by 480/7.5 to get 64MHz clock;        |
|                  | Configure UART_DLL to 1.                                   |

## 15.6.4 CTS\_n and RTS\_n Polarity Configurable

The polarity of cts\_n and rts\_n ports can be configured by GRF registers.

- When grf\_uart\_cts\_sel[\*] is configured as 1'b1, cts\_n is high active. Otherwise, lowactive.
- When grf\_uart\_rts\_sel[\*] is configured as 1'b1, rts\_n is high active. Otherwise, lowactive.

|       | Table 13-3 UART Dauu Ta | te configuration        |
|-------|-------------------------|-------------------------|
| UART  | <b>GRF_UART_CTS_SEL</b> | <b>GRF_UART_RTS_SEL</b> |
| UART0 | GRF_SOC_CON3[0]         | GRF_SOC_CON3[5]         |
| UART1 | GRF_SOC_CON3[1]         | GRF_SOC_CON3[6]         |
| UART2 | GRF_SOC_CON3[2]         | GRF_SOC_CON3[7]         |
| UART3 | GRF_SOC_CON3[3]         | GRF_SOC_CON3[8]         |
| UART4 | GRF_SOC_CON3[4]         | GRF_SOC_CON3[9]         |

Table 15-3 UART baud rate configuration

# 15.6.5 UART tx dma\_req enable signal Configurable

Because uart tx dma\_req signal auto drive high after system power up,and DMAC will take it as a valid request, so RK3308 add a grf bit to mask uart tx dma\_req when system power up. •When grf\_uart\_dma\_req\_ctrl[\*] is configured as 1'b0, dma\_req is active. Otherwise, dma\_req is masked.This bit default value is 1, and it must be set to 0 after uart is configured, otherwise, uart will not work correctly.

| Table 15 | Table 15-4 UART dma_req enable configuration |  |  |  |  |  |
|----------|----------------------------------------------|--|--|--|--|--|
| UART     | GRF_UART_DMA_REQ_CTRL                        |  |  |  |  |  |
| UART0    | GRF_SOC_CON3[10]                             |  |  |  |  |  |
| UART1    | GRF_SOC_CON3[11]                             |  |  |  |  |  |
| UART2    | GRF_SOC_CON3[12]                             |  |  |  |  |  |
| UART3    | GRF_SOC_CON3[13]                             |  |  |  |  |  |
| UART4    | GRF_SOC_CON3[14]                             |  |  |  |  |  |

# Chapter 16 Pulse Width Modulation (PWM)

# 16.1 Overview

The pulse-width modulator (PWM) feature is very common in embedded systems. It provides a way to generate a pulse periodic waveform for motor control or can act as a digital-to-analog converter with some external components.

The PWM Module supports the following features:

- 4-built-in PWM channels
- Configurable to operate in capture mode
  - Measures the high/low polarity effective cycles of this input waveform
  - Generates a single interrupt at the transition of input waveform polarity
  - 32-bit high polarity capture register
  - 32-bit low polarity capture register
  - 32-bit current value register
  - The capture result can be stored in a FIFO, and the depth of FIFO is 8. The data of FIFO can be read by CPU or DMA
  - Channel 3 support 32-bits power key capture mode
  - Support a input filter to remove glitch
- Configurable to operate in continuous mode or one-shot mode
  - 32-bit period counter
  - 32-bit duty register
  - 32-bit current value register
  - Configurable PWM output polarity in inactive state and duty period pulse polarity
  - Period and duty cycle are shadow buffered. Change takes effect when the end of the effective period is reached or when the channel is disabled
  - Programmable center or left aligned outputs, and change takes effect when the end of the effective period is reached or when the channel is disabled
  - 8-bit repeat counter for one-shot operation. One-shot operation will produce N + 1 periods of the waveform, where N is the repeat counter value, and generates a single interrupt at the end of operation
  - Continuous mode generates the waveform continuously, and does not generates any interrupts
- pre-scaled operation to clk\_pwm and then further scaled
- Available low-power mode to reduce power consumption when the channel is inactive.

# 16.2 Block Diagram



#### Fig. 16-1 PWM Block Diagram

The host processor gets access to PWM Register Block through the APB slave interface with 32-bit bus width, and asserts the active-high level interrupt. PWM only supports one interrupt output, please refer to interrupt register to know the raw interrupt status when an

interrupt is asserted.

PWM Channel is the control logic of PWM module, and controls the operation of PWM module according to the configured working mode.

# **16.3 Function Description**

The PWM supports three operation modes: capture mode, one-shot mode and continuous mode. For the one-shot mode and the continuous mode, the PWM output can be configured as the left-aligned mode or the center-aligned mode.

# 16.3.1 Capture mode

The capture mode is used to measure the PWM channel input waveform high/low effective cycles with the PWM channel clock, and asserts an interrupt when the polarity of the input waveform changes. The number of the high effective cycles is recorded in the

PWMx\_PERIOD\_HPC register, while the number of the low effective cycles is recorded in the PWMx\_DUTY\_LPC register.

Notes: the PWM input waveform is doubled buffered when the PWM channel is working in order to filter unexpected shot-time polarity transition, and therefore the interrupt is asserted several cycles after the input waveform polarity changes, and so does the change of the values of PWMx\_PERIOD\_HPC and PWMx\_DUTY\_LPC.



Fig. 16-2 PWM Capture Mode

The capture result also can be stored in a FIFO. The FIFO has an almost full indicator. The indicator can chose to use as an interrupt or DMA request. When it is used as an interrupt, the data in FIFO can be read by CPU. When it is used as a DMA request, the data in FIFO can be read through DMA. It also supports timeout interrupt when the data in FIFO has not been read in a time threshold.

The PWM (only channel 3) support 32-bits power key capture mode. User can configure 10 power key to match, the interrupt will be asserted when the capture value match any one.

## **16.3.2 Continuous mode**

The PWM channel generates a series of the pulses continuously as expected once the channel is enabled with continuous mode.

In the continuous mode, the PWM output waveforms can be in one form of the two output mode: left-aligned mode or center-aligned mode.

For the left-aligned output mode, the PWM channel firstly starts the duty cycle with the configured duty polarity (PWMx\_CTRL.duty\_pol). Once duty cycle number

(PWMx\_DUTY\_LPC) is reached, the output is switched to the opposite polarity. After the period number (PWMx\_PERIOD\_HPC) is reached, the output is again switched to the opposite polarity to start another period of desired pulse.



Fig. 16-3 PWM Continuous Left-aligned Output Mode

For the center-aligned output mode, the PWM channel firstly starts the duty cycle with the configured duty polarity (PWMx\_CTRL.duty\_pol). Once one half of duty cycle number (PWMx\_DUTY\_LPC) is reached, the output is switched to the opposite polarity. Then if there is one half of duty cycle left for the whole period, the output is again switched to the opposite polarity. Finally after the period number (PWMx\_PERIOD\_HPC) is reached, the output starts another period of desired pulse.



Fig. 16-4 PWM Continuous Center-aligned Output Mode

Once disable the PWM channel, the channel stops generating the output waveforms and output polarity is fixed as the configured inactive polarity (PWMx\_CTRL.inactive\_pol).

## 16.3.3 One-shot mode

Unlike the continuous mode, the PWM channel generates the output waveforms within the configured periods (PWM\_CTRL.rpt + 1), and then stops. At the same times, an interrupt is asserted to inform that the operation has been finished.

There are also two output modes for the one-shot mode: the left-aligned mode and the center-aligned mode.



Fig. 16-5 PWM One-shot Center-aligned Output Mode

# **16.4 Register Description**

## **16.4.1 Registers Summary**

| Name                | Offset | Size | Reset<br>Value | Description                    |
|---------------------|--------|------|----------------|--------------------------------|
| PWM_PWM0_CNT        | 0x0000 | W    | 0x00000000     | PWM Channel 0 Counter Register |
|                     |        |      |                | PWM Channel 0 Period           |
| PWM PWM0 PERIOD HPR | 0x0004 | W    | 0x00000000     | Register/High Polarity Capture |
|                     |        |      |                | Register                       |
|                     |        |      |                | PWM Channel 0 Duty             |
| PWM PWM0 DUTY LPR   | 0x0008 | W    | 0x00000000     | Register/Low Polarity Capture  |
|                     |        |      |                | Register                       |
| PWM PWM0 CTRL       | 0x000c | W    | 0x00000000     | PWM Channel 0 Control Register |
| PWM_PWM1_CNT        | 0x0010 | W    | 0x00000000     | PWM Channel 1 Counter Register |
|                     |        |      |                | PWM Channel 1 Period           |
| PWM PWM1 PERIOD HPR | 0x0014 | W    | 0x00000000     | Register/High Polarity Capture |
|                     |        |      |                | Register                       |
|                     |        |      |                | PWM Channel 1 Duty             |
| PWM_PWM1_DUTY_LPR   | 0x0018 | W    | 0x0000000      | Register/Low Polarity Capture  |
|                     |        |      |                | Register                       |
| PWM PWM1 CTRL       | 0x001c | W    | 0x0000000      | PWM Channel 1 Control Register |
| PWM_PWM2_CNT        | 0x0020 | W    | 0x00000000     | PWM Channel 2 Counter Register |
|                     |        |      |                | PWM Channel 2 Period           |
| PWM PWM2 PERIOD HPR | 0x0024 | W    | 0x00000000     | Register/High Polarity Capture |
|                     |        |      |                | Register                       |
|                     |        |      |                | PWM Channel 2 Duty             |
| PWM_PWM2_DUTY_LPR   | 0x0028 | W    | 0x00000000     | Register/Low Polarity Capture  |
|                     |        |      |                | Register                       |
| PWM PWM2 CTRL       | 0x002c | W    | 0x00000000     | PWM Channel 2 Control Register |
| PWM_PWM3_CNT        | 0x0030 | W    | 0x0000000      | PWM Channel 3 Counter Register |

|                      |         | Reset |                                         |                                  |  |
|----------------------|---------|-------|-----------------------------------------|----------------------------------|--|
| Name                 | Offset  | Size  | Value                                   | Description                      |  |
|                      |         |       |                                         | PWM Channel 3 Period             |  |
| PWM PWM3 PERIOD HPR  | 0x0034  | W     | 0x00000000                              | Register/High Polarity Capture   |  |
|                      |         |       |                                         | Register                         |  |
|                      |         |       |                                         | PWM Channel 3 Duty               |  |
| PWM PWM3 DUTY LPR    | 0x0038  | W     | 0x00000000                              | Register/Low Polarity Capture    |  |
|                      |         |       |                                         | Register                         |  |
| PWM PWM3 CTRL        | 0x003c  | W     | 0x00000000                              | PWM Channel 3 Control Register   |  |
| PWM INTSTS           | 0x0040  | W     | 0x00000000                              | Interrupt Status Register        |  |
| <u>PWM INT EN</u>    | 0x0044  | W     | 0x0000000                               | Interrupt Enable Register        |  |
|                      | 0,00000 | \A/   | 0x00000000                              | PWM Channel 3 FIFO Mode          |  |
| <u>PWM_FIFO_CTRL</u> | 0x0050  | W     | 0x00000000                              | Control Register                 |  |
| PWM_FIFO_INTSTS      | 0x0054  | W     | 0x0000010                               | FIFO Interrupts Status Register  |  |
| PWM FIFO TOUTTHR     | 0x0058  | W     | 0x00000000                              | FIFO Timeout Threshold Register  |  |
| PWM_VERSION_ID       | 0x005c  | W     | 0x02120b34                              | PWM Version ID Register          |  |
| <u>PWM_FIFO</u>      | 0x0060  | W     | 0x00000000                              | FIFO Register                    |  |
| PWM PWRMATCH CTRL    | 0x0080  | W     | 0x00000000                              | Power Key Match Control Register |  |
| PWM PWRMATCH LPRE    | 0x0084  | w     | 0x238c22c4                              | Power Key Match Of Low Preload   |  |
| PWM PWRMATCH LPRE    | 0X0004  | vv    | 0X236C22C4                              | Register                         |  |
| PWM_PWRMATCH_HPRE    | 0x0088  | w     | 0x11f81130                              | Power Key Match Of High Preload  |  |
|                      | 0X0088  | vv    | 0X11101130                              | Register                         |  |
| PWM_PWRMATCH_LD      | 0x008c  | w     | 0x029401cc                              | Power Key Match Of Low Data      |  |
|                      | 0,0000  | vv    | 0,02940100                              | Register                         |  |
| PWM PWRMATCH HD ZER  | 0x0090  | w     | 0x029401cc                              | Power Key Match Of High Data For |  |
| <u>0</u>             | 0,0000  | vv    | 0,02040100                              | Zero Register                    |  |
| PWM PWRMATCH HD ONE  | 0x0094  | w     | 0x06fe0636                              | Power Key Match Of High Data For |  |
|                      | 0,000,1 | ••    | 0,00100050                              | One Register                     |  |
| PWM_PWRMATCH_VALUE0  | 0x0098  | W     | 0x0000000                               | Power Key Match Value 0 Register |  |
| PWM PWRMATCH VALUE1  | 0x009c  | W     | 0x0000000                               | Power Key Match Value 1 Register |  |
| PWM PWRMATCH VALUE2  | 0x00a0  | W     | 0x0000000                               | Power Key Match Value 2 Register |  |
| PWM_PWRMATCH_VALUE3  | 0x00a4  | W     | 0x0000000                               | Power Key Match Value 3 Register |  |
| PWM PWRMATCH VALUE4  | 0x00a8  | W     | 0x0000000                               | Power Key Match Value 4 Register |  |
| PWM_PWRMATCH_VALUE5  | 0x00ac  | W     | 0x0000000                               | Power Key Match Value 5 Register |  |
| PWM_PWRMATCH_VALUE6  | 0x00b0  | W     | 0x0000000                               | Power Key Match Value 6 Register |  |
| PWM PWRMATCH VALUE7  | 0x00b4  | W     | 0x0000000                               | Power Key Match Value 7 Register |  |
| PWM_PWRMATCH_VALUE8  | 0x00b8  | W     | 0x0000000                               | Power Key Match Value 8 Register |  |
| PWM PWRMATCH VALUE9  | 0x00bc  | W     | 0x0000000                               | Power Key Match Value 9 Register |  |
| PWM PWM3 PWRCAPTURE  | 0x00cc  | w     | 0x00000000                              | Channel 3 Power Key Capture      |  |
| VALUE                |         | vv    | 0.0000000000000000000000000000000000000 | Value Register                   |  |
| PWM FILTER CTRL      | 0x00d0  | W     | $0 \times 00000000$                     | Filter Control Register          |  |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# 16.4.2 Detail Register Description

#### PWM\_PWM0\_CNT

Address: Operational Base + offset (0x0000)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                               |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | CNT<br>The 32-bit indicates current value of PWM Channel 0 counter. The<br>counter runs at the rate of PWM clock.<br>The value ranges from 0 to (2^32-1). |

#### PWM PWM0 PERIOD HPR

Address: Operational Base + offset (0x0004)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000         | PERIOD_HPR<br>If PWM is operated at the continuous mode or one-shot mode,<br>this value defines the period of the output waveform. Note that, if<br>the PWM is operated at the center-aligned mode, the period<br>should be an even one, and therefore only the bit [31:1] is taken<br>into account and bit [0] always considered as 0.<br>If PWM is operated at the capture mode, this value indicates the<br>effective high polarity cycles of input waveform. This value is<br>based on the PWM clock.<br>The value ranges from 0 to (2^32-1). |

#### PWM PWM0 DUTY LPR

Address: Operational Base + offset (0x0008)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000         | DUTY_LPR<br>If PWM is operated at the continuous mode or one-shot mode,<br>this value defines the duty cycle of the output waveform. The<br>PWM starts the output waveform with duty cycle. Note that, if the<br>PWM is operated at the center-aligned mode, the period should<br>be an even one, and therefore only the [31:1] is taken into<br>account.<br>If PWM is operated at the capture mode, this value indicates the<br>effective low polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to<br>(2^32-1). |

#### PWM\_PWM0\_CTRL

Address: Operational Base + offset (0x000c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                           |  |  |
|-------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:24 | RW   | 0x00               | rpt<br>This field defines the repeated effective periods of output<br>waveform in one-shot mode. The value N means N+1 repeated<br>effective periods. |  |  |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | scale                                                                                                                                                                                                                                                 |
| 23:16 | RW   | 0×00        | This field defines the scale factor applied to prescaled clock. The value N means the clock is divided by 2*N. If N is 0, it means that the clock is divided by 512(2*256).                                                                           |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                              |
| 14:12 | RW   | 0×0         | prescale<br>This field defines the prescale factor applied to input clock. The<br>value N means that the input clock is divided by 2^N.                                                                                                               |
| 11:10 | RO   | 0x0         | reserved                                                                                                                                                                                                                                              |
| 9     | RW   | 0x0         | clk_sel<br>0: non-scaled clock is selected as PWM clock source. It means<br>that the prescale clock is directly used as the PWM clock source<br>1: scaled clock is selected as PWM clock source                                                       |
| 8     | RW   | 0×0         | force_clk_en<br>0: disabled, when PWM channel is inactive state, the clk_pwm to<br>PWM Clock prescale module is blocked to reduce power<br>consumption.<br>1: enabled, the clk_pwm to PWM Clock prescale module is always<br>enable.                  |
| 7     | RW   | 0×0         | ch_cnt_en<br>0: disabled<br>1: enabled                                                                                                                                                                                                                |
| 6     | RW   | 0×0         | conlock<br>pwm period and duty lock to previous configuration<br>0: disable lock<br>1: enable lock                                                                                                                                                    |
| 5     | RW   | 0×0         | output_mode<br>0: left aligned mode<br>1: center aligned mode                                                                                                                                                                                         |
| 4     | RW   | 0×0         | inactive_pol<br>This defines the output waveform polarity when PWM channel is<br>in inactive state. The inactive state means that PWM finishes the<br>complete waveform in one-shot mode or PWM channel is<br>disabled.<br>0: negative<br>1: positive |
| 3     | RW   | 0×0         | duty_pol<br>This defines the polarity for duty cycle. PWM starts the output<br>waveform with duty cycle.<br>0: negative<br>1: positive                                                                                                                |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:1 | RW   | 0x0         | <ul> <li>pwm_mode</li> <li>00: One shot mode. PWM produces the waveform within the repeated times defined by PWMx_CTRL_rpt .</li> <li>01: Continuous mode. PWM produces the waveform continuously</li> <li>10: Capture mode. PWM measures the cycles of high/low polarity of input waveform.</li> <li>11: reserved</li> </ul> |
| 0   | RW   | 0×0         | pwm_en<br>0: disabled<br>1: enabled. If the PWM is worked in the one-shot mode, this bit<br>will be cleared at the end of operation                                                                                                                                                                                           |

#### PWM PWM1 CNT

Address: Operational Base + offset (0x0010)

| Bit  | Attr | <b>Reset Value</b> | Description                                                      |
|------|------|--------------------|------------------------------------------------------------------|
|      | RO   | 0x00000000         | CNT                                                              |
| 31:0 |      |                    | The 32-bit indicates current value of PWM Channel 1 counter. The |
| 51.0 |      |                    | counter runs at the rate of PWM clock.                           |
|      |      |                    | The value ranges from 0 to (2^32-1).                             |

#### PWM PWM1 PERIOD HPR

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000         | PERIOD_HPR<br>If PWM is operated at the continuous mode or one-shot mode,<br>this value defines the period of the output waveform. Note that, if<br>the PWM is operated at the center-aligned mode, the period<br>should be an even one, and therefore only the bit [31:1] is taken<br>into account and bit [0] always considered as 0.<br>If PWM is operated at the capture mode, this value indicates the<br>effective high polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to<br>(2^32-1). |

#### PWM PWM1 DUTY LPR

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000         | DUTY_LPR<br>If PWM is operated at the continuous mode or one-shot mode,<br>this value defines the duty cycle of the output waveform. The<br>PWM starts the output waveform with duty cycle. Note that, if the<br>PWM is operated at the center-aligned mode, the period should<br>be an even one, and therefore only the [31:1] is taken into<br>account.<br>If PWM is operated at the capture mode, this value indicates the<br>effective low polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to<br>(2^32-1). |

### PWM PWM1 CTRL

Address: Operational Base + offset (0x001c)

| Bit   |    | <b>Reset Value</b> | Description                                                                                                                                                                                                                          |
|-------|----|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RW | 0×00               | rpt<br>This field defines the repeated effective periods of output<br>waveform in one-shot mode. The value N means N+1 repeated<br>effective periods.                                                                                |
| 23:16 | RW | 0×00               | scale<br>This field defines the scale factor applied to prescaled clock. The<br>value N means the clock is divided by 2*N. If N is 0, it means<br>that the clock is divided by 512(2*256).                                           |
| 15    | RO | 0x0                | reserved                                                                                                                                                                                                                             |
| 14:12 | RW | 0×0                | prescale<br>This field defines the prescale factor applied to input clock. The<br>value N means that the input clock is divided by 2^N.                                                                                              |
| 11:10 | RO | 0x0                | reserved                                                                                                                                                                                                                             |
| 9     | RW | 0×0                | clk_sel<br>0: non-scaled clock is selected as PWM clock source. It means<br>that the prescale clock is directly used as the PWM clock source<br>1: scaled clock is selected as PWM clock source                                      |
| 8     | RW | 0×0                | force_clk_en<br>0: disabled, when PWM channel is inactive state, the clk_pwm to<br>PWM Clock prescale module is blocked to reduce power<br>consumption.<br>1: enabled, the clk_pwm to PWM Clock prescale module is always<br>enable. |
| 7     | RW | 0x0                | ch_cnt_en<br>0: disabled<br>1: enabled                                                                                                                                                                                               |
| 6     | RW | 0x0                | conlock<br>pwm period and duty lock to previous configuration<br>0: disable lock<br>1: enable lock                                                                                                                                   |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                   |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |                    | output_mode                                                                                                                                                                                                                                                                                                   |
| 5   | RW   | 0x0                | 0: left aligned mode                                                                                                                                                                                                                                                                                          |
|     |      |                    | 1: center aligned mode                                                                                                                                                                                                                                                                                        |
| 4   | RW   | 0×0                | <ul> <li>inactive_pol</li> <li>This defines the output waveform polarity when PWM channel is</li> <li>in inactive state. The inactive state means that PWM finishes the</li> <li>complete waveform in one-shot mode or PWM channel is</li> <li>disabled.</li> <li>0: negative</li> <li>1: positive</li> </ul> |
| 3   | RW   | 0×0                | duty_pol<br>This defines the polarity for duty cycle. PWM starts the output<br>waveform with duty cycle.<br>0: negative<br>1: positive                                                                                                                                                                        |
| 2:1 | RW   | 0x0                | pwm_mode<br>00: One shot mode. PWM produces the waveform within the<br>repeated times defined by PWMx_CTRL_rpt<br>01: Continuous mode. PWM produces the waveform continuously<br>10: Capture mode. PWM measures the cycles of high/low polarity<br>of input waveform.<br>11: reserved                         |
| 0   | RW   | 0x0                | pwm_en<br>0: disabled<br>1: enabled. If the PWM is worked in the one-shot mode, this bit<br>will be cleared at the end of operation                                                                                                                                                                           |

#### PWM\_PWM2\_CNT

Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description                                                      |
|------|------|--------------------|------------------------------------------------------------------|
|      | RO   | 0x000000000        | CNT                                                              |
| 31:0 |      |                    | The 32-bit indicates current value of PWM Channel 2 counter. The |
| 51.0 |      |                    | counter runs at the rate of PWM clock.                           |
|      |      |                    | The value ranges from 0 to (2^32-1).                             |

# PWM PWM2 PERIOD HPR

Address: Operational Base + offset (0x0024)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000         | PERIOD_HPR<br>If PWM is operated at the continuous mode or one-shot mode,<br>this value defines the period of the output waveform. Note that, if<br>the PWM is operated at the center-aligned mode, the period<br>should be an even one, and therefore only the bit [31:1] is taken<br>into account and bit [0] always considered as 0.<br>If PWM is operated at the capture mode, this value indicates the<br>effective high polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to<br>(2^32-1). |

### PWM PWM2 DUTY LPR

Address: Operational Base + offset (0x0028)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000         | DUTY_LPR<br>If PWM is operated at the continuous mode or one-shot mode,<br>this value defines the duty cycle of the output waveform. The<br>PWM starts the output waveform with duty cycle. Note that, if the<br>PWM is operated at the center-aligned mode, the period should<br>be an even one, and therefore only the [31:1] is taken into<br>account.<br>If PWM is operated at the capture mode, this value indicates the<br>effective low polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to<br>(2^32-1). |

#### PWM\_PWM2\_CTRL

Address: Operational Base + offset (0x002c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                 |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RW   | 0×00               | rpt<br>This field defines the repeated effective periods of output<br>waveform in one-shot mode. The value N means N+1 repeated<br>effective periods.                                       |
| 23:16 | RW   | 0x00               | scale<br>This fields defines the scale factor applied to prescaled clock. The<br>value N means the clock is divided by 2*N. If N is 0, it means<br>that the clock is divided by 512(2*256). |
| 15    | RO   | 0x0                | reserved                                                                                                                                                                                    |
| 14:12 | RW   | 0x0                | prescale<br>This field defines the prescale factor applied to input clock. The<br>value N means that the input clock is divided by 2^N.                                                     |
| 11:10 | RO   | 0x0                | reserved                                                                                                                                                                                    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      |             | clk_sel                                                                                                                                                                                                                                                                                                       |
| 9   | RW   | 0×0         | 0: non-scaled clock is selected as PWM clock source. It means<br>that the prescale clock is directly used as the PWM clock source<br>1: scaled clock is selected as PWM clock source                                                                                                                          |
| 8   | RW   | 0×0         | force_clk_en<br>0: disabled, when PWM channel is inactive state, the clk_pwm to<br>PWM Clock prescale module is blocked to reduce power<br>consumption.<br>1: enabled, the clk_pwm to PWM Clock prescale module is always<br>enable.                                                                          |
| 7   | RW   | 0×0         | ch_cnt_en<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                                        |
| 6   | RW   | 0×0         | conlock<br>pwm period and duty lock to previous configuration<br>0: disable lock<br>1: enable lock                                                                                                                                                                                                            |
| 5   | RW   | 0×0         | output_mode<br>0: left aligned mode<br>1: center aligned mode                                                                                                                                                                                                                                                 |
| 4   | RW   | 0x0         | <ul> <li>inactive_pol</li> <li>This defines the output waveform polarity when PWM channel is</li> <li>in inactive state. The inactive state means that PWM finishes the</li> <li>complete waveform in one-shot mode or PWM channel is</li> <li>disabled.</li> <li>0: negative</li> <li>1: positive</li> </ul> |
| 3   | RW   | 0×0         | duty_pol<br>This defines the polarity for duty cycle. PWM starts the output<br>waveform with duty cycle.<br>0: negative<br>1: positive                                                                                                                                                                        |
| 2:1 | RW   | 0×0         | pwm_mode<br>00: One shot mode. PWM produces the waveform within the<br>repeated times defined by PWMx_CTRL_rpt.<br>01: Continuous mode. PWM produces the waveform continuously<br>10: Capture mode. PWM measures the cycles of high/low polarity<br>of input waveform.<br>11: reserved                        |
| 0   | RW   | 0x0         | pwm_en<br>0: disabled<br>1: enabled. If the PWM is worked in the one-shot mode, this bit<br>will be cleared at the end of operation                                                                                                                                                                           |

### PWM\_PWM3\_CNT

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

#### Address: Operational Base + offset (0x0030)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                               |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000         | CNT<br>The 32-bit indicates current value of PWM Channel 3 counter. The<br>counter runs at the rate of PWM clock.<br>The value ranges from 0 to (2^32-1). |

#### PWM\_PWM3\_PERIOD\_HPR

Address: Operational Base + offset (0x0034)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x0000000          | PERIOD_HPR<br>If PWM is operated at the continuous mode or one-shot mode,<br>this value defines the period of the output waveform. Note that, if<br>the PWM is operated at the center-aligned mode, the period<br>should be an even one, and therefore only the bit [31:1] is taken<br>into account and bit [0] always considered as 0.<br>If PWM is operated at the capture mode, this value indicates the<br>effective high polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to<br>(2^32-1). |

#### PWM PWM3 DUTY LPR

Address: Operational Base + offset (0x0038)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   |                    | DUTY_LPR<br>If PWM is operated at the continuous mode or one-shot mode,<br>this value defines the duty cycle of the output waveform. The<br>PWM starts the output waveform with duty cycle. Note that, if the<br>PWM is operated at the center-aligned mode, the period should<br>be an even one, and therefore only the [31:1] is taken into<br>account.<br>If PWM is operated at the capture mode, this value indicates the<br>effective low polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to<br>(2^32-1). |

#### PWM\_PWM3\_CTRL

Address: Operational Base + offset (0x003c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                           |
|-------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RW   | 0x00               | rpt<br>This field defines the repeated effective periods of output<br>waveform in one-shot mode. The value N means N+1 repeated<br>effective periods. |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |             | scale                                                                                                                                                                                                                                                 |
| 23:16 | RW   | 0×00        | This field defines the scale factor applied to prescaled clock. The value N means the clock is divided by 2*N. If N is 0, it means that the clock is divided by 512(2*256).                                                                           |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                              |
| 14:12 | RW   | 0×0         | prescale<br>This field defines the prescale factor applied to input clock. The<br>value N means that the input clock is divided by 2^N.                                                                                                               |
| 11:10 | RO   | 0x0         | reserved                                                                                                                                                                                                                                              |
| 9     | RW   | 0×0         | clk_sel<br>0: non-scaled clock is selected as PWM clock source. It means<br>that the prescale clock is directly used as the PWM clock source<br>1: scaled clock is selected as PWM clock source                                                       |
| 8     | RW   | 0×0         | force_clk_en<br>0: disabled, when PWM channel is inactive state, the clk_pwm to<br>PWM Clock prescale module is blocked to reduce power<br>consumption.<br>1: enabled, the clk_pwm to PWM Clock prescale module is always<br>enable.                  |
| 7     | RW   | 0×0         | ch_cnt_en<br>0: disabled<br>1: enabled                                                                                                                                                                                                                |
| 6     | RW   | 0×0         | conlock<br>pwm period and duty lock to previous configuration<br>0: disable lock<br>1: enable lock                                                                                                                                                    |
| 5     | RW   | 0x0         | output_mode<br>0: left aligned mode<br>1: center aligned mode                                                                                                                                                                                         |
| 4     | RW   | 0×0         | inactive_pol<br>This defines the output waveform polarity when PWM channel is<br>in inactive state. The inactive state means that PWM finishes the<br>complete waveform in one-shot mode or PWM channel is<br>disabled.<br>0: negative<br>1: positive |
| 3     | RW   | 0×0         | duty_pol<br>This defines the polarity for duty cycle. PWM starts the output<br>waveform with duty cycle.<br>0: negative<br>1: positive                                                                                                                |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:1 | RW   | 0x0         | <pre>pwm_mode<br/>00: One shot mode. PWM produces the waveform within the<br/>repeated times defined by PWMx_CTRL_rpt<br/>01: Continuous mode. PWM produces the waveform continuously<br/>10: Capture mode. PWM measures the cycles of high/low polarity<br/>of input waveform.<br/>11: reserved</pre> |
| 0   | RW   | 0×0         | pwm_en<br>0: disabled<br>1: enabled. If the PWM is worked in the one-shot mode, this bit<br>will be cleared at the end of operation                                                                                                                                                                    |

#### PWM INTSTS

Address: Operational Base + offset (0x0040)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                   |
|-------|------|--------------------|-------------------------------------------------------------------------------|
| 31:12 | RO   | 0x0                | reserved                                                                      |
|       |      |                    | CH3_Pol                                                                       |
|       |      |                    | This bit is used in capture mode in order to identify the transition          |
|       |      |                    | of the input waveform when interrupt is generated. When bit is                |
| 11    | RO   | 0x0                | 1, please refer to PWM3_PERIOD_HPR to know the effective high                 |
|       |      |                    | cycle of Channel 3 input waveform. Otherwise, please refer to                 |
|       |      |                    | PWM3_PERIOD_LPR to know the effective low cycle of Channel 3                  |
|       |      |                    | input waveform. Write 1 to CH3_IntSts will clear this bit.                    |
|       |      |                    | CH2_Pol                                                                       |
|       |      | 0×0                | This bit is used in capture mode in order to identify the                     |
|       |      |                    | transition of the input waveform when interrupt is generated.                 |
| 10    | RO   |                    | When bit is 1, please refer to PWM2_PERIOD_HPR to know the                    |
|       |      |                    | effective high cycle of Channel 2 input waveform. Otherwise,                  |
|       |      |                    | please refer to PWM2_PERIOD_LPR to know the effective low                     |
|       |      |                    | cycle of Channel 2 input waveform. Write 1 to CH2_IntSts will clear this bit. |
|       |      |                    | CH1 Pol                                                                       |
|       |      |                    | This bit is used in capture mode in order to identify the                     |
|       |      | RO 0x0             | transition of the input waveform when interrupt is generated.                 |
|       |      |                    | When bit is 1, please refer to PWM1_PERIOD_HPR to know the                    |
| 9     | RO   |                    | effective high cycle of Channel 1 input waveform. Otherwise,                  |
|       |      |                    | please refer to PWM1_PERIOD_LPR to know the effective low                     |
|       |      |                    | cycle of Channel 1 input waveform. Write 1 to CH1_IntSts will                 |
|       |      |                    | clear this bit.                                                               |

| Bit | Attr | <b>Reset Value</b> | Description                                                   |   |   |   |   |  |                                  |
|-----|------|--------------------|---------------------------------------------------------------|---|---|---|---|--|----------------------------------|
|     |      |                    | CH0_Pol                                                       |   |   |   |   |  |                                  |
|     |      |                    | This bit is used in capture mode in order to identify the     |   |   |   |   |  |                                  |
|     |      |                    | transition of the input waveform when interrupt is generated. |   |   |   |   |  |                                  |
| 0   |      | 0.40               | When bit is 1, please refer to PWM0_PERIOD_HPR to know the    |   |   |   |   |  |                                  |
| 8   | RO   | 0x0                | effective high cycle of Channel 0 input waveform. Otherwise,  |   |   |   |   |  |                                  |
|     |      |                    | please refer to PWM0_PERIOD_LPR to know the effective low     |   |   |   |   |  |                                  |
|     |      |                    | cycle of Channel 0 input waveform. Write 1 to CH0_IntSts will |   |   |   |   |  |                                  |
|     |      |                    | clear this bit.                                               |   |   |   |   |  |                                  |
|     | W1   |                    | CH3_pwr_IntSts                                                |   |   |   |   |  |                                  |
| 7   | C    | 0x0                | 0: Channel 3 power key Interrupt not generated                |   |   |   |   |  |                                  |
|     | C    |                    | 1: Channel 3 power key Interrupt generated                    |   |   |   |   |  |                                  |
|     | W1   |                    | CH2_pwr_IntSts                                                |   |   |   |   |  |                                  |
| 6   | C    | 0x0                | 0: Channel 2 power key Interrupt not generated                |   |   |   |   |  |                                  |
|     | C    |                    | 1: Channel 2 power key Interrupt generated                    |   |   |   |   |  |                                  |
|     | W1   | 0×0                | CH1_pwr_IntSts                                                |   |   |   |   |  |                                  |
| 5   | C    |                    | 0: Channel 1 power keyInterrupt not generated                 |   |   |   |   |  |                                  |
|     | C    |                    | 1: Channel 1 power key Interrupt generated                    |   |   |   |   |  |                                  |
|     | W1   | 0×0                | CH0_pwr_IntSts                                                |   |   |   |   |  |                                  |
| 4   | C    |                    | 0: Channel 0 power key Interrupt not generated                |   |   |   |   |  |                                  |
|     | C    |                    | 1: Channel 0 power key Interrupt generated                    |   |   |   |   |  |                                  |
|     | W1   | 0x0                | CH3_IntSts                                                    |   |   |   |   |  |                                  |
| 3   | C    |                    | 0: Channel 3 Interrupt not generated                          |   |   |   |   |  |                                  |
|     | C    | C                  | C                                                             | C | C | C | C |  | 1: Channel 3 Interrupt generated |
|     | W1   |                    | CH2_IntSts                                                    |   |   |   |   |  |                                  |
| 2   | C    | 0x0                | 0: Channel 2 Interrupt not generated                          |   |   |   |   |  |                                  |
|     | Ŭ    |                    | 1: Channel 2 Interrupt generated                              |   |   |   |   |  |                                  |
|     | W1   |                    | CH1_IntSts                                                    |   |   |   |   |  |                                  |
| 1   | C    | 0x0                | 0: Channel 1 Interrupt not generated                          |   |   |   |   |  |                                  |
|     | Ŭ    |                    | 1: Channel 1 Interrupt generated                              |   |   |   |   |  |                                  |
|     | W1   |                    | CH0_IntSts                                                    |   |   |   |   |  |                                  |
| 0   | C    | 0x0                | 0: Channel 0 Interrupt not generated                          |   |   |   |   |  |                                  |
|     | Ĭ    |                    | 1: Channel 0 Interrupt generated                              |   |   |   |   |  |                                  |

## <u>PWM\_INT\_EN</u>

Address: Operational Base + offset (0x0044)

| Bit  | Attr | <b>Reset Value</b> | Description                               |
|------|------|--------------------|-------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                  |
|      |      |                    | CH3_pwr_Int_en                            |
| 7    | RW   | 0x0                | 0: Channel 3 power key Interrupt disabled |
|      |      |                    | 1: Channel 3 power key Interrupt enabled  |
| 6:4  | RO   | 0x0                | reserved                                  |
|      |      |                    | CH3_Int_en                                |
| 3    | RW   | 0x0                | 0: Channel 3 Interrupt disabled           |
|      |      |                    | 1: Channel 3 Interrupt enabled            |

| Bit | Attr | <b>Reset Value</b> | Description                     |
|-----|------|--------------------|---------------------------------|
|     |      |                    | CH2_Int_en                      |
| 2   | RW   | 0x0                | 0: Channel 2 Interrupt disabled |
|     |      |                    | 1: Channel 2 Interrupt enabled  |
|     |      |                    | CH1_Int_en                      |
| 1   | RW   | 0x0                | 0: Channel 1 Interrupt disabled |
|     |      |                    | 1: Channel 1 Interrupt enabled  |
|     |      |                    | CH0_Int_en                      |
| 0   | RW   | 0x0                | 0: Channel 0 Interrupt disabled |
|     |      |                    | 1: Channel 0 Interrupt enabled  |

**<u>PWM FIFO CTRL</u>** Address: Operational Base + offset (0x0050)

| Bit   | Attr | Reset Value | Description                                                                                                                                                              |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14 | RO   | 0x0         | reserved                                                                                                                                                                 |
| 13:12 | RW   | 0×0         | dma_ch_sel<br>2'b00: Select PWM0<br>2'b01: Select PWM1<br>2'b10: Select PWM2<br>2'b11: Select PWM3                                                                       |
| 11    | RO   | 0x0         | reserved                                                                                                                                                                 |
| 10    | RW   | 0×0         | <pre>dma_ch_sel_en 1'b1: Enable, use dma_ch_sel to select the channel to FIFO mode and DMA mode. 1'b0: Disable, select the channel PWM3 to FIFO mode and DMA mode.</pre> |
| 9     | RW   | 0x0         | timeout_en<br>fifo timeout enable                                                                                                                                        |
| 8     | RW   | 0×0         | dma_mode_en<br>1'b1: enable<br>1'b0: disable                                                                                                                             |
| 7     | RO   | 0x0         | reserved                                                                                                                                                                 |
| 6:4   | RW   | 0x0         | almost_full_watermark<br>Almost full Watermark level                                                                                                                     |
| 3     | RW   | 0x0         | watermark_int_en<br>Watermark full interrupt                                                                                                                             |
| 2     | RW   | 0x0         | overflow_int_en<br>When high, an interrupt asserts when the fifo overflow                                                                                                |
| 1     | RW   | 0x0         | full_int_en<br>When high, an interrupt asserts when the FIFO is full.                                                                                                    |
| 0     | RW   | 0x0         | fifo_mode_sel<br>When high, PWM FIFO mode is activated                                                                                                                   |

#### **PWM\_FIFO\_INTSTS**

Address: Operational Base + offset (0x0054)

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

| Bit  | Attr | <b>Reset Value</b> | Description                                   |
|------|------|--------------------|-----------------------------------------------|
| 31:5 | RO   | 0x0                | reserved                                      |
| 4    | RO   | 0x1                | fifo_empty_status                             |
| 4    | κυ   | 0.01               | This bit indicates the FIFO is empty          |
| 3    | W1   | 0x0                | timieout_intsts                               |
| 2    | С    | 0.00               | Timeout interrupt                             |
| 2    | W1   | 0.40               | fifo_watermark_full_intsts                    |
| Z    | С    | 0x0                | This bit indicates the FIFO is Watermark Full |
| 4    | W1   | 00                 | fifo_overflow_intsts                          |
| L    | С    | 0x0                | This bit indicates the FIFO is overflow       |
| 0    | W1   | 0.40               | fifo_full_intsts                              |
| 0    | С    | 0x0                | This bit indicates the FIFO is full           |

#### PWM FIFO TOUTTHR

Address: Operational Base + offset (0x0058)

| Bit   | Attr | <b>Reset Value</b> | Description                                             |
|-------|------|--------------------|---------------------------------------------------------|
| 31:20 | RO   | 0x0                | reserved                                                |
| 19:0  | RW   | 0x00000            | timeout_threshold<br>FIFO Timeout value(unit pwm clock) |

#### PWM\_VERSION\_ID

Address: Operational Base + offset (0x005c)

| Bit   | Attr | <b>Reset Value</b> | Description                              |
|-------|------|--------------------|------------------------------------------|
|       | RW   | 0x02               | main_version                             |
| 21.24 |      |                    | 8'h0:Base version                        |
| 51.24 |      |                    | 8'h1:Support DMA mode                    |
|       |      |                    | 8'h2:Support DMA mode and Power key mode |
| 23:16 | RW   | 0x12               | minor_version                            |
| 15:0  | RW   | 0x0b34             | svn_version                              |

#### PWM\_FIFO

Address: Operational Base + offset (0x0060)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                              |
|------|------|--------------------|------------------------------------------------------------------------------------------|
| 31   | RO   | 0×0                | pol<br>This bit indicates the polarity of the lower 31-bit counter.<br>0: Low<br>1: High |
| 30:0 | RO   | 0x00000000         | cycle_cnt<br>This 31-bit counter indicates the effective cycles of high/low<br>waveform. |

#### PWM PWRMATCH\_CTRL

Address: Operational Base + offset (0x0080)

| Bit   | Attr | <b>Reset Value</b> | Description                                                   |
|-------|------|--------------------|---------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                      |
|       |      |                    | CH3_pwrkey_int_ctrl                                           |
| 15    | RW   | 0x0                | 0: Assert interrupt after key capture with power key match    |
|       |      |                    | 1: Assert interrupt after key capture without power key match |
| 14:12 | RO   | 0x0                | reserved                                                      |
|       |      |                    | CH3_pwrkey_capture_ctrl                                       |
| 11    | RW   | 0x0                | 0: Capture the value after interrupt                          |
|       |      |                    | 1: Capture the value directly                                 |
| 10:8  | RO   | 0x0                | reserved                                                      |
|       |      |                    | CH3_pwrkey_polarity                                           |
| 7     | RW   | 0x0                | 0: pwm in polarity is positive                                |
|       |      |                    | 1: pwm in polarity is negative                                |
| 6:4   | RO   | 0x0                | reserved                                                      |
|       |      |                    | CH3_pwrkey_enable                                             |
| 3     | RW   | 0x0                | 0: Disabled                                                   |
|       |      |                    | 1: Enabled                                                    |
| 2:0   | RO   | 0x0                | reserved                                                      |

#### **PWM PWRMATCH LPRE**

Address: Operational Base + offset (0x0084)

| Bit   | Attr | <b>Reset Value</b> | Description               |
|-------|------|--------------------|---------------------------|
| 21.16 | RW   | 0x238c             | cnt_max                   |
| 51.10 |      |                    | The maximum counter value |
| 15.0  |      | W 0x22c4           | cnt_min                   |
| 15:0  | RW   |                    | The minimum counter value |

#### **PWM\_PWRMATCH\_HPRE**

Address: Operational Base + offset (0x0088)

| Bit   | Attr | <b>Reset Value</b> | Description               |
|-------|------|--------------------|---------------------------|
| 31:16 | DW   | 0x11f8             | cnt_max                   |
| 51.10 | K VV |                    | The maximum counter value |
| 15.0  | RW   | W 10x1130          | cnt_min                   |
| 15:0  |      |                    | The minimum counter value |

#### **PWM PWRMATCH LD**

Address: Operational Base + offset (0x008c)

| Bit   | Attr | <b>Reset Value</b> | Description               |
|-------|------|--------------------|---------------------------|
| 31:16 | RW   | 0x0294             | cnt_max                   |
|       |      |                    | The maximum counter value |
| 15:0  | RW   | W  0x01cc          | cnt_min                   |
| 15:0  | K VV |                    | The minimum counter value |

#### PWM PWRMATCH HD ZERO

#### Address: Operational Base + offset (0x0090)

| Bit   | Attr | <b>Reset Value</b> | Description                          |
|-------|------|--------------------|--------------------------------------|
| 31:16 | RW   | 0x0294             | cnt_max<br>The maximum counter value |
| 15:0  | RW   | $0 \times 01 cc$   | cnt_min<br>The minimum counter value |

#### **PWM PWRMATCH HD ONE**

Address: Operational Base + offset (0x0094)

| Bit   | Attr | <b>Reset Value</b> | Description               |
|-------|------|--------------------|---------------------------|
| 31:16 | DW   | 0x06fe             | cnt_max                   |
| 51.10 | K VV |                    | The maximum counter value |
| 15.0  |      | V 10x0636          | cnt_min                   |
| 15:0  | RW   |                    | The minimum counter value |

#### **PWM\_PWRMATCH\_VALUE0**

Address: Operational Base + offset (0x0098)

| Bit  | Attr | <b>Reset Value</b> | Description           |
|------|------|--------------------|-----------------------|
| 31:0 | RW   | 10X000000000       | pwrkey_match_value    |
| 31:0 | RW   |                    | Power key match value |

#### PWM\_PWRMATCH\_VALUE1

Address: Operational Base + offset (0x009c)

| Bit  | Attr | <b>Reset Value</b> | Description                                 |
|------|------|--------------------|---------------------------------------------|
| 31:0 | RW   | 0x00000000         | pwrkey_match_value<br>Power key match value |

#### PWM\_PWRMATCH\_VALUE2

Address: Operational Base + offset (0x00a0)

| Bit  | Attr | <b>Reset Value</b> | Description                                 |
|------|------|--------------------|---------------------------------------------|
| 31:0 | RW   | 02000000000        | pwrkey_match_value<br>Power key match value |

#### **PWM\_PWRMATCH\_VALUE3**

Address: Operational Base + offset (0x00a4)

| Bit  | Attr | <b>Reset Value</b> | Description                                 |  |
|------|------|--------------------|---------------------------------------------|--|
| 31:0 | RW   | UXUUUUUUUUU        | pwrkey_match_value<br>Power key match value |  |

#### PWM\_PWRMATCH\_VALUE4

Address: Operational Base + offset (0x00a8)

| Bit  | Attr | <b>Reset Value</b> | Description                                 |  |
|------|------|--------------------|---------------------------------------------|--|
| 31:0 | RW   | UX000000000        | pwrkey_match_value<br>Power key match value |  |

#### PWM PWRMATCH\_VALUE5

Address: Operational Base + offset (0x00ac)

| Bit  | Attr | <b>Reset Value</b> | Description                                 |  |
|------|------|--------------------|---------------------------------------------|--|
| 31:0 | RW   | 0X000000000        | pwrkey_match_value<br>Power key match value |  |

#### **PWM\_PWRMATCH\_VALUE6**

Address: Operational Base + offset (0x00b0)

| Bit  | Attr | <b>Reset Value</b> | Description           |  |
|------|------|--------------------|-----------------------|--|
| 31:0 | RW   | 0x00000000         | pwrkey_match_value    |  |
|      |      |                    | Power key match value |  |

#### **PWM PWRMATCH VALUE7**

Address: Operational Base + offset (0x00b4)

| Bit  | Attr | <b>Reset Value</b> | Description           |
|------|------|--------------------|-----------------------|
| 31:0 | RW   | 0x00000000         | pwrkey_match_value    |
| 51.0 |      |                    | Power key match value |

#### **PWM PWRMATCH VALUE8**

Address: Operational Base + offset (0x00b8)

| Bit  | Attr | <b>Reset Value</b> | Description                                 |  |
|------|------|--------------------|---------------------------------------------|--|
| 31:0 | RW   | 0x000000000        | pwrkey_match_value<br>Power key match value |  |

#### PWM PWRMATCH\_VALUE9

Address: Operational Base + offset (0x00bc)

| Bit  | Attr | <b>Reset Value</b> | Description           |
|------|------|--------------------|-----------------------|
| 31:0 | RW   | 0x00000000         | pwrkey_match_value    |
| 51:0 | 1    | 0,00000000         | Power key match value |

#### PWM PWM3 PWRCAPTURE VALUE

Address: Operational Base + offset (0x00cc)

| Bit  | Attr | <b>Reset Value</b> | Description             |  |
|------|------|--------------------|-------------------------|--|
| 31:0 | RO   | 0x00000000         | pwrkey_capture_value    |  |
|      | κυ   | 0,00000000         | Power key capture value |  |

#### PWM\_FILTER\_CTRL

Address: Operational Base + offset (0x00d0)

| Bit   | Attr | <b>Reset Value</b> | Description          |
|-------|------|--------------------|----------------------|
| 31:13 | RO   | 0x0                | reserved             |
| 12:4  | RW   | 0x000              | ilter_number         |
| 12:4  |      | 0,000              | Filter window number |

| Bit | Attr | <b>Reset Value</b> | Description             |
|-----|------|--------------------|-------------------------|
|     |      |                    | CH3_input_filter_enable |
| 3   | RW   | 0x0                | 0: Disabled             |
|     |      |                    | 1: Enabled              |
|     |      |                    | CH2_input_filter_enable |
| 2   | RW   | 0x0                | 0: Disabled             |
|     |      |                    | 1: Enabled              |
|     |      |                    | CH1_input_filter_enable |
| 1   | RW   | 0x0                | 0: Disabled             |
|     |      |                    | 1: Enabled              |
|     |      |                    | CH0_input_filter_enable |
| 0   | RW   | 0x0                | 0: Disabled             |
|     |      |                    | 1: Enabled              |

# **16.5 Interface Description**

| Table 16-1 PWM Interface D | escription |
|----------------------------|------------|
|                            | cocription |

| Module | Direction | Pin Name                  | IOMUX Setting                 |
|--------|-----------|---------------------------|-------------------------------|
| Pin    |           |                           |                               |
| PWM0   | I/O       | GPIO0_B5/PWM0             | GRF_GPIO0B_IOMUX[11:10]=2'b01 |
| PWM1   | I/O       | GPIO0_B6/PWM1             | GRF_GPIO0B_IOMUX[13:12]=2'b01 |
| PWM2   | I/O       | GPIO0_B7/PWM2/I2C3_SDA_M0 | GRF_GPIO0B_IOMUX[15:14]=2'b01 |
| PWM3   | I/O       | GPIO0_C0/PWM3/I2C3_SCL_M0 | GRF_GPIO0C_IOMUX[1:0]=2'b01   |

*Notes: I=input, O=output, I/O=input/output.* 

# **16.6 Application Notes**

# 16.6.1 PWM Capture Mode Standard Usage Flow

1. Set PWM\_PWMx\_CTRL.pwm\_en to '0' to disable the PWM channel.

2. Choose the prescale factor and the scale factor for clk\_pwm by programming PWM\_PWMx\_CTRL.prescale and PWM\_PWMx\_CTRL.scale, and select the clock needed by setting PWM\_PWMx\_CTRL.clk\_sel.

3. Configure the channel to work in the capture mode.

4. Enable the PWM\_INT\_EN.chx\_int\_en to enable the interrupt generation.

5. Set PWM\_FILTER\_CTRL. filter\_number, then Enable the PWM\_FILTER\_CTRL.

CHx\_input\_filter\_enable(Optional).

6. Enable the channel by writing '1' to PWM\_PWMx\_CTRL.pwm\_en bit to start the channel.

7. When an interrupt is asserted, refer to INTSTS register to know the raw interrupt status. If the corresponding polarity flag is set, turn to PWM\_PWMx\_PERIOD\_HPC register to know the effective high cycles of input waveforms, otherwise turn to PWM\_PWMx\_DUTY\_LPC register to know the effective low cycles.

8. Write '0' to PWM\_PWMx\_CTRL.pwm\_en to disable the channel.

# 16.6.2 PWM Capture DMA Mode Standard Usage Flow

1. Set PWM\_PWMx\_CTRL.pwm\_en to '0' to disable the PWM channel.

2. Choose the prescale factor and the scale factor for clk\_pwm by programming PWM\_PWMx\_CTRL.prescale and PWM\_PWMx\_CTRL.scale, and select the clock needed by setting PWM\_PWMx\_CTRL.clk\_sel.

3. Configure the channel 3 to work in the capture mode.

4. Configure the PWM\_FIFO\_CTRL.dma\_mode\_en and PWM\_FIFO\_CTRL.fifo\_mode\_sel to enable the DMA mode. Configure PWM\_FIFO\_CTRL.almost\_full\_watermark at appropriate value.

5. Configure DMAC\_BUS to tansfer data from PWM to DDR.

6. Set PWM\_FILTER\_CTRL. filter\_number, then Enable the PWM\_FILTER\_CTRL.

CHx\_input\_filter\_enable(Optional).

7. Enable the channel by writing `1' to PWM\_PWMx\_CTRL.pwm\_en bit to start the channel.8. When a dma\_req is asserted, DMAC\_BUS transfer the data of effective high cycles and low cycles of input waveforms to DDR.

9. Write '0' to PWM\_PWMx\_CTRL.pwm\_en to disable the channel.

# 16.6.3 PWM Power key Capture Mode Standard Usage Flow

1. Set PWM\_PWM3\_CTRL.pwm\_en to '0' to disable the PWM channel.

2. Choose the prescale factor and the scale factor for clk\_pwm by programming PWM\_PWM3\_CTRL.prescale and PWM\_PWM3\_CTRL.scale, and select the clock needed by setting PWM\_PWM3\_CTRL.clk\_sel. The clock should be 1 Mhz after division.

3. Configure the channel to work in the capture mode.

4. Enable the PWM\_INT\_EN.CH3\_int\_pwr to enable the interrupt generation.

5. Set the PWM\_PWRMATCH\_VALUE0~9 registers for the 10 power key match value.

6.Set max\_cnt and min\_cnt of follow register: PWM\_PWRMATCH\_LPRE,

PWM\_PWRMATCH\_HPRE, PWM\_PWRMATCH\_LD, PWM\_PWRMATCH\_HD\_ZERO,

PWM\_PWRMATCH\_HD\_ONE. It doesn't need to set these registers when the default value can meet the requirement.

7.Set PWM\_PWRMATCH\_CTRL.CH3\_pwrkey\_polarity for the polarity of power key signal, the default value is 0. Enable the PWM\_PWRMATCH\_CTRL.CH3\_pwrkey\_enable.

8. Set PWM\_FILTER\_CTRL. filter\_number, then Enable the PWM\_FILTER\_CTRL.

CH3\_input\_filter\_enable(Optional).

9. Enable the channel by writing '1' to PWM\_PWM3\_CTRL.pwm\_en bit to start the channel. 10. When an interrupt is asserted, refer to INTSTS register to know the raw interrupt status, and refer to PWM\_PWM3\_PWRCAPTURE\_VALUE to know the power key capture value. 11. Write '0' to PWM\_PWM3\_CTRL.pwm\_en to disable the channel.

# 16.6.4 PWM One-shot Mode/Continuous Standard Usage Flow

1. Set PWM\_PWMx\_CTRL.pwm\_en to '0' to disable the PWM channel.

2. Choose the prescale factor and the scale factor for pclk by programming

PWM\_PWMx\_CTRL.prescale and PWM\_PWMx\_CTRL.scale, and select the clock needed by setting PWM\_PWMx\_CTRL.clk\_sel.

3. Choose the output mode by setting PWM\_PWMx\_CTRL.output\_mode, and set the duty polarity and inactive polarity by programming PWM\_PWMx\_CTRL.duty\_pol and PWM PWMx\_CTRL.inactive pol.

4. Set the PWM\_PWMx\_CTRL.rpt if the channel is desired to work in the one-shot mode.

5. Configure the channel to work in the one-shot mode or the continuous mode.

6. Enable the PWM\_INT\_EN.chx\_int\_en to enable the interrupt generation if if the channel is desired to work in the one-shot mode.

7. If the channel is working in the one-shot mode, an interrupt is asserted after the end of operation, and the PWM\_PWMx\_CTRL.pwm\_en is automatically cleared. Whatever mode the channel is working in, write '0' to PWM\_PWMx\_CTRL.pwm\_en bit to disable the PWM channel.

# 16.6.5 Low-power Usage Flow

The default value of PWM\_PWMx\_CTRL.force\_clk\_en is '0' which make the channel enter the low-power mode. In low-power mode, When the PWM channel is inactive, the clk\_pwm to the clock prescale module is gated in order to reduce the power consumption. User can set PWM\_PWMx\_CTRL.force\_clk\_en to '1' which will make the channel quit the low-power mode. After the setting, the clk\_pwm to the clock prescale module is always enable.

# 16.6.6 Other notes

When the channel is active to produce waveforms, it is free to program the PWM\_PWMx\_PERIOD\_HPC and PWM\_PWMx\_DUTY\_LPC register. User can use

PWM\_PWMx\_CTRL.conlock to take period and duty effect at the same time. The usage flow is as follow:

1. Set PWM\_PWMx\_CTRL.conlock to `1'.

2. Set PWM\_PWMx\_PERIOD\_HPC and PWM\_PWMx\_DUTY\_LPC.

3. Set PWM\_PWMx\_CTRL.conlock to '0', others bits in PWM\_PWMx\_CTRL should be appropriate.

After above configuration, the change will not take effect immediately until the current period ends.

An active channel can be changed to another operation mode without disable the PWM channel. However, during the transition of the operation mode there may be some irregular output waveforms. So does changing the clock division factor when the channel is active.

# Chapter 17 I2C Interface

# 17.1 Overview

The Inter-Integrated Circuit (I2C) is a two wired (SCL and SDA), bi-directional serial bus that provides an efficient and simple method of information exchange between devices. This I2C bus controller supports master mode acting as a bridge between AMBA protocol and generic I2C bus system.

I2C Controller supports the following features:

- Support 4 independent I2C: I2C0, I2C1, I2C2, I2C3
- Item Compatible with I2C-bus
- AMBA APB slave interface
- Supports master mode of I2C bus
- Software programmable clock frequency and transfer rate up to 400Kbit/sec
- Supports 7 bits and 10 bits addressing modes
- Interrupt or polling driven multiple bytes data transfer
- Clock stretching and wait state generation
- Fiter out glitch on SCL and SDA

# 17.2 Block Diagram





# 17.2.1 I2C\_RF

I2C\_RF module is used to control the I2C controller operation by the host with APB interface. It implements the register set and the interrupt functionality. The CSR component operates synchronously with the pclk clock.

# 17.2.2 I2C\_PE

I2C\_PE module implements the I2C master operation for transmit data to and receive data from other I2C devices. The I2C master controller operates synchronously with the pclk.

## 17.2.3 I2C\_TOP

I2C\_TOP module is the top module of the I2C controller.

# **17.3 Function Description**

This chapter provides a description about the functions and behavior under various conditions.

The I2C controller supports only Masterfunction. Itsupports the 7-bits/10-bits addressing mode and support general call address. The maximum clock frequency and transfer rate can be up to 400Kbit/sec.

The operations of I2C controller is divided to 2 parts and described separately: initialization and master mode programming.

# 17.3.1 Initialization

The I2C controller is based on AMBA APB bus architecture and usually is part of a SOC. So before I2C operates, some system setting and configuration must be conformed, which includes:

- I2C interrupt connection type: CPU interrupt scheme should be considered. If the I2C interrupt is connected to extra Interrupt Controller module, we need decide the INTC vector.
- I2C Clock Rate: The I2C controller uses the APB clock as the working clock so the APB clock will determine the I2C bus clock. The correct register setting is subject to the system requirement.

# 17.3.2 Master Mode Programming

- SCL Clock
   When the I2C controller is programmed in Master mode, the SCL frequency is
   determined by I2C\_CLKDIV register. The SCL frequency is calculated by the following
   formula:
   SCL Divisor = 8\*(CLKDIVL + 1 + CLKDIVH + 1)
   SCL = PCLK/ SCLK Divisor
- Data Receiver Register Access

When the I2C controller received MRXCNT bytes data, CPU can get the data through register RXDATA0 ~ RXDATA7. The controller can receive up to 32 bytes' data in one transaction.

When MRXCNT register is written, the I2C controller will start to drive SCL to receive data.

- Transmit Transmitter Register
   Data to transmit are written to TXDATA0~7 by CPU. The controller can transmit up to 32 bytes' data in one transaction. The lower byte will be transmitted first.
   When MTXCNT register is written, the I2C controller will start to transmit data.
- Start Command Write 1 to I2C\_CON[3], the controller will send I2C start command.
- Stop Command Write 1 to I2C\_CON[4], the controller will send I2C stop command
- I2C Operation mode

There are four i2c operation modes.

- When I2C\_CON[2:1] is 2'b00, the controller transmit all valid data in TXDATA0~TXDATA7 byte by byte. The controller will transmit lower byte first.
- When I2C\_CON[2:1] is 2'b01, the controller will transmit device address in MRXADDR first (Write/Read bit = 0) and then transmit device register address in MRXRADDR. After that, the controller will assert restart signal and resend MRXADDR (Write/Read bit = 1). At last, the controller enter receive mode.
- When I2C\_CON[2:1] is 2'b10, the controller is in receive mode, it will trigger clock to read MRXCNT byte data.
- When I2C\_CON[2:1] is 2'b11, the controller will transmit device address in MRXADDR first (Write/Read bit = 1) and then transmit device register address in MRXRADDR. After that, the controller will assert restart signal and resend MRXADDR (Write/Read bit = 1). At last, the controller enter receive mode.
- Read/Write Command
  - When I2C\_OPMODE(I2C\_CON[2:1]) is 2'b01 or 2'b11, the Read/Write command bit is decided by controller itself.

- In RX only mode (I2C\_CON[2:1] is 2'b10), the Read/Write command bit is decided by MRXADDR[0].
- In TX only mode (I2C\_CON[[2:1] is 2'b00), the Read/Write command bit is decided by TXDATA[0].
- Master Interrupt Condition
  - There are 7 interrupt bits in I2C\_ISR register related to master mode.
  - Byte transmitted finish interrupt (Bit 0): The bit is asserted when Master completed transmitting a byte.
  - Byte received finish interrupt (Bit 1): The bit is asserted when Master completed receiving a byte.
  - MTXCNT bytes data transmitted finish interrupt (Bit 2): The bit is asserted when Master completed transmitting MTXCNT bytes.
  - MRXCNT bytes data received finish interrupt (Bit 3): The bit is asserted when Master completed receiving MRXCNT bytes.
  - Start interrupt (Bit 4): The bit is asserted when Master finished asserting start command to I2C bus.
  - Stop interrupt (Bit 5): The bit is asserted when Master finished asserting stop command to I2C bus.
  - NAK received interrupt (Bit 6): The bit is asserted when Master received a NAK handshake.
- Last byte acknowledge control
  - If I2C\_CON[5] is 1, the I2C controller will transmit NAK handshake to slave when the last byte received in RX only mode.
  - If I2C\_CON[5] is 0, the I2C controller will transmit ACK handshake to slave when the last byte received in RX only mode.
- How to handle NAK handshake received
  - If I2C\_CON[6] is 1, the I2C controller will stop all transactions when NAK handshake received. And the software should take responsibility to handle the problem.
  - If I2C\_CON[6] is 0, the I2C controller will ignore all NAK handshake received.
- I2C controller data transfer waveform
  - Bit transferring
    - Data Validity

The SDA line must be stable during the high period of SCL, and the data on SDA line can only be changed when SCL is in low state.



Fig. 17-2 I2C DATA Validity

START and STOP conditions
 START condition occurs when SDA goes low while SCL is in high period. STOP condition is generated when SDA line goes high while SCL is in high state.



Fig. 17-3 I2C Start and stop conditions

- Data transfer
  - Acknowledge

After a byte of data transferring (clocks labeled as  $1 \sim 8$ ), in 9th clock the receiver must assert an ACK signal on SDA line, if the receiver pulls SDA line to low, it means "ACK", on the contrary, it's "NOT ACK".



Fig. 17-4 I2C Acknowledge

Byte transfer

The master own I2C bus might initiate multi byte to transfer to a slave. The transfer starts from a "START" command and ends in a "STOP" command. After every byte transfer, the receiver must reply an ACK to transmitter.





# **17.4 Register Description**

## 17.4.1 Registers Summary

| Name                | Offset | Size | Reset<br>Value | Description                                                         |
|---------------------|--------|------|----------------|---------------------------------------------------------------------|
| RKI2C CON           | 0x0000 | W    | 0x00030300     | control register                                                    |
| <u>RKI2C_CLKDIV</u> | 0x0004 | W    | 0x00060006     | clock divider register, I2C CLK =<br>PCLK / (16*CLKDIV)             |
| RKI2C MRXADDR       | 0x0008 | W    | 0x00000000     | the slave address accessed for master rx mode                       |
| RKI2C MRXRADDR      | 0x000c | w    | 0x00000000     | the slave register address<br>accessed for master rx mode           |
| RKI2C MTXCNT        | 0x0010 | W    | 0x00000000     | master transmit count.specify the total bytes to be transmit (0~32) |
| RKI2C_MRXCNT        | 0x0014 | W    | 0x00000000     | master rx count.specify the total bytes to be recieved(0~32)        |
| <u>RKI2C IEN</u>    | 0x0018 | W    | 0x0000000      | interrupt enable register                                           |
| <u>RKI2C IPD</u>    | 0x001c | W    | 0x0000000      | interrupt pending register                                          |

| Name                   | Offset | Size | Reset<br>Value | Description                                                                                     |
|------------------------|--------|------|----------------|-------------------------------------------------------------------------------------------------|
| <u>RKI2C_FCNT</u>      | 0x0020 | w    | 0×00000000     | finished count: the count of data<br>which has been transmitted or<br>receivedfor debug purpose |
| <u>RKI2C SCL OE DB</u> | 0x0024 | w    | 0x00000020     | slave hold debounce configure<br>register                                                       |
| RKI2C_TXDATA0          | 0x0100 | W    | 0x00000000     | I2C tx data register 0                                                                          |
| RKI2C TXDATA1          | 0x0104 | W    | 0x00000000     | I2C tx data register 1                                                                          |
| RKI2C TXDATA2          | 0x0108 | W    | 0x00000000     | I2C tx data register 2                                                                          |
| RKI2C TXDATA3          | 0x010c | W    | 0x00000000     | I2C tx data register 3                                                                          |
| <u>RKI2C TXDATA4</u>   | 0x0110 | W    | 0x00000000     | I2C tx data register 4                                                                          |
| <u>RKI2C_TXDATA5</u>   | 0x0114 | W    | 0x00000000     | I2C tx data register 5                                                                          |
| <u>RKI2C_TXDATA6</u>   | 0x0118 | W    | 0x00000000     | I2C tx data register 6                                                                          |
| <u>RKI2C TXDATA7</u>   | 0x011c | W    | 0x00000000     | I2C tx data register 7                                                                          |
| RKI2C_RXDATA0          | 0x0200 | W    | 0x00000000     | I2C rx data register 0                                                                          |
| RKI2C RXDATA1          | 0x0204 | W    | 0x00000000     | I2C rx data register 1                                                                          |
| RKI2C RXDATA2          | 0x0208 | W    | 0x00000000     | I2C rx data register 2                                                                          |
| RKI2C RXDATA3          | 0x020c | W    | 0x00000000     | I2C rx data register 3                                                                          |
| RKI2C RXDATA4          | 0x0210 | W    | 0x00000000     | I2C rx data register 4                                                                          |
| RKI2C_RXDATA5          | 0x0214 | W    | 0x00000000     | I2C rx data register 5                                                                          |
| RKI2C RXDATA6          | 0x0218 | W    | 0x00000000     | I2C rx data register 6                                                                          |
| RKI2C RXDATA7          | 0x021c | W    | 0x00000000     | I2C rx data register 7                                                                          |
| RKI2C_ST               | 0x0220 | W    | 0x00000003     | status debug register                                                                           |
| RKI2C DBGCTRL          | 0x0224 | W    | 0x00000f00     | Debug config register                                                                           |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# **17.4.2 Detail Register Description**

#### RKI2C\_CON

Address: Operational Base + offset (0x0000)

| Bit      | Attr   | <b>Reset Value</b>        | Description                                          |
|----------|--------|---------------------------|------------------------------------------------------|
| 31:16 RO |        | O 0x0003                  | version                                              |
|          | 0x0003 | rki2c version information |                                                      |
| 15:14 RW |        | 0x0                       | stop_setup                                           |
|          | RW     |                           | stop setup config:                                   |
|          |        |                           | TSU;sto = (stop_setup + 1) * T(SCL_HIGH) + Tclk_i2c  |
| 13:12 RW |        | / 0×0                     | start_setup                                          |
|          |        |                           | start setup config:                                  |
|          | RVV    |                           | TSU;sta = (start_setup + 1) * T(SCL_HIGH) + Tclk_i2c |
|          |        |                           | THD;sta = (start_setup + 2) * T(SCL_HIGH) - Tclk_i2c |
| 11       | RO     | 0x0                       | reserved                                             |

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                        |
|------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8 | RW   | 0x0                | <pre>data_upd_st SDA update point config: Used to config sda change state when scl is low, used to adjust setup/hold time 4'bn:Thold = (n + 1) * Tclk_i2c Note: 0 &lt;= n &lt;= 5</pre>                                                                                                                                                                                            |
| 7    | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                           |
| 6    | RW   | 0x0                | act2nak<br>operation when NAK handshake is received:<br>1'b0: ignored<br>1'b1: stop transaction                                                                                                                                                                                                                                                                                    |
| 5    | RW   | 0×0                | ack<br>last byte acknowledge control in master receive mode:<br>1'b0: ACK<br>1'b1: NAK                                                                                                                                                                                                                                                                                             |
| 4    | RW   | 0×0                | stop<br>stop enable, when this bit is written to 1, I2C will generate stop<br>signal.                                                                                                                                                                                                                                                                                              |
| 3    | RW   | 0x0                | start<br>start enable, when this bit is written to 1, I2C will generate start<br>signal.                                                                                                                                                                                                                                                                                           |
| 2:1  | RW   | 0×0                | <pre>i2c_mode<br/>i2c_mode<br/>i2c mode select:<br/>2'b00: transmit only<br/>2'b01: transmit address (device + register address)&gt; restart -<br/>-&gt; transmit address -&gt; receive only<br/>2'b10: receive only<br/>2'b11: transmit address (device + register address, write/read bit<br/>is 1)&gt; restart&gt; transmit address (device address)&gt;<br/>receive data</pre> |
| 0    | RW   | 0×0                | i2c_en<br>i2c module enable:<br>1'b0:not enable<br>1'b1:enable                                                                                                                                                                                                                                                                                                                     |

**RKI2C\_CLKDIV** Address: Operational Base + offset (0x0004)

| Bit   | Attr | <b>Reset Value</b> | Description                                |
|-------|------|--------------------|--------------------------------------------|
|       |      |                    | CLKDIVH                                    |
| 31:16 | RW   | 0x0000             | scl high level clock count:                |
|       |      |                    | T(SCL_HIGH) = Tclk_i2c * (CLKDIVH + 1) * 8 |
|       |      |                    | CLKDIVL                                    |
| 15:0  | RW   | 0x0001             | scl low level clock count:                 |
|       |      |                    | T(SCL_LOW) = Tclk_i2c * (CLKDIVL + 1) * 8  |

## RKI2C\_MRXADDR

Address: Operational Base + offset (0x0008)

| Bit   | Attr | <b>Reset Value</b> | Description                           |
|-------|------|--------------------|---------------------------------------|
| 31:27 | RO   | 0x0                | reserved                              |
|       |      |                    | addhvld                               |
| 26    | RW   | 0x0                | address high byte valid:              |
| 20    | ĸw   | 0.00               | 1'b0:invalid                          |
|       |      |                    | 1'b1:valid                            |
|       |      |                    | addmvld                               |
| 25    | RW   | 0x0                | address middle byte valid:            |
| 25    | ĸw   |                    | 1'b0:invalid                          |
|       |      |                    | 1'b1:valid                            |
|       |      | W 0x0              | addlvld                               |
| 24    | DW   |                    | address low byte valid:               |
| 24    |      |                    | 1'b0:invalid                          |
|       |      |                    | 1'b1:valid                            |
|       |      | w 0x000000         | saddr                                 |
| 23:0  | DW   |                    | master address register.              |
| 25.0  |      |                    | the lowest bit indicate write or read |
|       |      |                    | 24 bits address register              |

## RKI2C MRXRADDR

Address: Operational Base + offset (0x000c)

| Bit   | Attr | <b>Reset Value</b> | Description                      |
|-------|------|--------------------|----------------------------------|
| 31:27 | RO   | 0x0                | reserved                         |
|       |      |                    | sraddhvld                        |
| 26    | RW   | 0x0                | address high byte valid:         |
| 20    | RVV  | 0.00               | 1'b0:invalid                     |
|       |      |                    | 1'b1:valid                       |
|       |      |                    | sraddmvld                        |
| 25    | RW   | 0x0                | address middle byte valid:       |
| 25    |      |                    | 1'b0:invalid                     |
|       |      |                    | 1'b1:valid                       |
|       |      | W 0x0              | sraddlvld                        |
| 24    | RW   |                    | address low byte valid:          |
| 24    | RW   |                    | 1'b0:invalid                     |
|       |      |                    | 1'b1:valid                       |
|       | RW   | W 0x000000         | sraddr                           |
| 23:0  |      |                    | slave register address accessed. |
|       |      |                    | 24 bits register address         |

## RKI2C MTXCNT

Address: Operational Base + offset (0x0010)

| Bit  | Attr | <b>Reset Value</b> | Description                                        |
|------|------|--------------------|----------------------------------------------------|
| 31:6 | RO   | 0x0                | reserved                                           |
| 5:0  | RW   | 0x00               | mtxcnt<br>master transmit count.<br>6 bits counter |

## RKI2C MRXCNT

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description      |
|------|------|--------------------|------------------|
| 31:6 | RO   | 0x0                | reserved         |
|      |      |                    | mrxcnt           |
| 5:0  | RW   | 0x00               | master rx count. |
|      |      |                    | 6 bits counter   |

#### RKI2C\_IEN

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                               |
|------|------|--------------------|-------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                                                  |
| 7    | RW   | 0x0                | slavehdsclen<br>slave hold scl interrupt enable:<br>1'b0:disable<br>1'b1:enable           |
| 6    | RW   | 0x0                | nakrcvien<br>NAK handshake received interrupt enable:<br>1'b0:disable<br>1'b1:enable      |
| 5    | RW   | 0×0                | stopien<br>stop operation finished interrupt enable:<br>1'b0:disable<br>1'b1:enable       |
| 4    | RW   | 0×0                | startien<br>start operation finished interrupt enable:<br>1'b0:disable<br>1'b1:enable     |
| 3    | RW   | 0x0                | mbrfien<br>MRXCNT data received finished interrupt enable:<br>1'b0:disable<br>1'b1:enable |
| 2    | RW   | 0×0                | mbtfien<br>MTXCNT data transfer finished interrupt enable:<br>1'b0:disable<br>1'b1:enable |
| 1    | RW   | 0x0                | brfien<br>byte rx finished interrupt enable:<br>1'b0:disable<br>1'b1:enable               |
| 0    | RW   | 0x0                | btfien<br>byte tx finished interrupt enable:<br>1'b0:disable<br>1'b1:enable               |

## <u>RKI2C\_IPD</u>

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

### Address: Operational Base + offset (0x001c)

| Bit  | Attr | Reset<br>Value | Description                                                                                                                                                                |
|------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0            | reserved                                                                                                                                                                   |
| 7    | RW   | 0×0            | slavehdsclipd<br>slave hold scl interrupt pending bit:<br>1'b0:no interrupt available<br>1'b1:slave hold scl interrupt appear, write 1 to clear                            |
| 6    | W1C  | 0x0            | nakrcvipd<br>NAK handshake received interrupt pending bit:<br>1'b0:no interrupt available<br>1'b1:NAK handshake received interrupt appear, write 1 to clear                |
| 5    | W1C  | 0×0            | stopipd<br>stop operation finished interrupt pending bit:<br>1'b0:no interrupt available<br>1'b1:stop operation finished interrupt appear, write 1 to clear                |
| 4    | W1C  | 0×0            | startipd<br>start operation finished interrupt pending bit:<br>1'b0:no interrupt available<br>1'b1:start operation finished interrupt appear, write 1 to clear             |
| 3    | W1C  | 0×0            | mbrfipd<br>MRXCNT data received finished interrupt pending bit:<br>1'b0:no interrupt available<br>1'b1:MRXCNT data received finished interrupt appear, write 1 to<br>clear |
| 2    | W1C  | 0×0            | mbtfipd<br>MTXCNT data transfer finished interrupt pending bit:<br>1'b0:no interrupt available<br>1'b1:MTXCNT data transfer finished interrupt appear, write 1 to<br>clear |
| 1    | W1C  | 0×0            | brfipd<br>byte rx finished interrupt pending bit:<br>1'b0:no interrupt available<br>1'b1:byte rx finished interrupt appear, write 1 to clear                               |
| 0    | W1C  | 0×0            | btfipd<br>byte tx finished interrupt pending bit:<br>1'b0:no interrupt available<br>1'b1:byte tx finished interrupt appear, write 1 to clear                               |

## RKI2C FCNT

Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                           |
|------|------|--------------------|---------------------------------------------------------------------------------------|
| 31:6 | RO   | 0x0                | reserved                                                                              |
| 5:0  | RO   | 0x00               | fcnt<br>the count of data which has been transmitted or received<br>for debug purpose |

## RKI2C SCL OE DB

Address: Operational Base + offset (0x0024)

| Bit  | Attr | <b>Reset Value</b> | Description                          |
|------|------|--------------------|--------------------------------------|
| 31:8 | RO   | 0x0                | reserved                             |
|      |      |                    | scl_oe_db                            |
| 7:0  | RW   | 0x20               | slave hold scl debounce.             |
|      |      |                    | cycles for debounce (unit: Tclk_i2c) |

## RKI2C\_TXDATA0

Address: Operational Base + offset (0x0100)

| Bit  | Attr | <b>Reset Value</b> | Description              |
|------|------|--------------------|--------------------------|
|      |      |                    | txdata0                  |
| 31:0 | RW   | 0x00000000         | data0 to be transmitted. |
|      |      |                    | 32 bits data             |

#### **RKI2C TXDATA1**

Address: Operational Base + offset (0x0104)

| Bit  | Attr | <b>Reset Value</b> | Description              |
|------|------|--------------------|--------------------------|
|      |      |                    | txdata1                  |
| 31:0 | RW   | 0x00000000         | data1 to be transmitted. |
|      |      |                    | 32 bits data             |

#### RKI2C\_TXDATA2

Address: Operational Base + offset (0x0108)

| Bit  | Attr | <b>Reset Value</b> | Description              |
|------|------|--------------------|--------------------------|
|      |      |                    | txdata2                  |
| 31:0 | RW   | 0x00000000         | data2 to be transmitted. |
|      |      |                    | 32 bits data             |

#### RKI2C TXDATA3

Address: Operational Base + offset (0x010c)

| Bit  | Attr | <b>Reset Value</b> | Description              |
|------|------|--------------------|--------------------------|
|      |      |                    | txdata3                  |
| 31:0 | RW   | 0x00000000         | data3 to be transmitted. |
|      |      |                    | 32 bits data             |

#### **RKI2C TXDATA4**

Address: Operational Base + offset (0x0110)

| Bit  | Attr | <b>Reset Value</b> | Description              |
|------|------|--------------------|--------------------------|
|      |      |                    | txdata4                  |
| 31:0 | RW   | 0x00000000         | data4 to be transmitted. |
|      |      |                    | 32 bits data             |

## RKI2C\_TXDATA5

Address: Operational Base + offset (0x0114)

| Bit  | Attr | <b>Reset Value</b> | Description              |
|------|------|--------------------|--------------------------|
|      |      |                    | txdata5                  |
| 31:0 | RW   | 0x00000000         | data5 to be transmitted. |
|      |      |                    | 32 bits data             |

#### **RKI2C TXDATA6**

Address: Operational Base + offset (0x0118)

| Bit  | Attr | <b>Reset Value</b> | Description              |
|------|------|--------------------|--------------------------|
|      |      |                    | txdata6                  |
| 31:0 | RW   | 0x00000000         | data6 to be transmitted. |
|      |      |                    | 32 bits data             |

## RKI2C TXDATA7

Address: Operational Base + offset (0x011c)

| Bit  | Attr | <b>Reset Value</b> | Description              |
|------|------|--------------------|--------------------------|
|      |      |                    | txdata7                  |
| 31:0 | RW   | 0x00000000         | data7 to be transmitted. |
|      |      |                    | 32 bits data             |

## RKI2C\_RXDATA0

Address: Operational Base + offset (0x0200)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | rxdata0         |
| 31:0 | RO   | 0x00000000         | data0 received. |
|      |      |                    | 32 bits data    |

#### **RKI2C RXDATA1**

Address: Operational Base + offset (0x0204)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | rxdata1         |
| 31:0 | RO   | 0x00000000         | data1 received. |
|      |      |                    | 32 bits data    |

#### RKI2C RXDATA2

Address: Operational Base + offset (0x0208)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | rxdata2         |
| 31:0 | RO   | 0x00000000         | data2 received. |
|      |      |                    | 32 bits data    |

## RKI2C RXDATA3

Address: Operational Base + offset (0x020c)

| Bit  | Attr | <b>Reset Value</b> | Description                |
|------|------|--------------------|----------------------------|
| 31:0 | RO   | 0x00000000         | rxdata3<br>data3 received. |
|      |      |                    | 32 bits data               |

#### **RKI2C RXDATA4**

Address: Operational Base + offset (0x0210)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | rxdata4         |
| 31:0 | RO   | 0x00000000         | data4 received. |
|      |      |                    | 32 bits data    |

## **RKI2C RXDATA5**

Address: Operational Base + offset (0x0214)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | rxdata5         |
| 31:0 | RO   | 0x00000000         | data5 received. |
|      |      |                    | 32 bits data    |

## **RKI2C RXDATA6**

Address: Operational Base + offset (0x0218)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | rxdata6         |
| 31:0 | RO   | 0x00000000         | data6 received. |
|      |      |                    | 32 bits data    |

#### **RKI2C RXDATA7**

Address: Operational Base + offset (0x021c)

| Bit  | Attr | <b>Reset Value</b> | Description     |
|------|------|--------------------|-----------------|
|      |      |                    | rxdata7         |
| 31:0 | RO   | 0x00000000         | data7 received. |
|      |      |                    | 32 bits data    |

#### RKI2C ST

Address: Operational Base + offset (0x0220)

| Bit  | Attr | <b>Reset Value</b> | Description           |
|------|------|--------------------|-----------------------|
| 31:2 | RO   | 0x0                | reserved              |
|      | RO   | 0×0                | scl_st                |
| 1    |      |                    | scl status:           |
| 1    |      |                    | 1'b0: scl status low  |
|      |      |                    | 1'b0: scl status high |

| Bit | Attr | <b>Reset Value</b> | Description           |
|-----|------|--------------------|-----------------------|
|     | RO   | 0×0                | sda_st                |
|     |      |                    | sda status:           |
| U   |      |                    | 1'b0: sda status low  |
|     |      |                    | 1'b0: sda status high |

# RKI2C DBGCTRL

Address: Operational Base + offset (0x0224)

| Bit   | Attr | <b>Reset Value</b> | Description                                                         |    |     |                                                                      |
|-------|------|--------------------|---------------------------------------------------------------------|----|-----|----------------------------------------------------------------------|
| 31:15 | RO   | 0x0                | reserved                                                            |    |     |                                                                      |
|       |      |                    | h0_check_scl                                                        |    |     |                                                                      |
| 14    | RW   | 0x0                | 0: Check if scl been pull down by slave at the whole SCL_HIGH.      |    |     |                                                                      |
| 14    |      | 0.00               | 1: Check if scl been pull down by slave only at the h0 of           |    |     |                                                                      |
|       |      |                    | SCL_HIGH(SCL_HIGH including h0~h7).                                 |    |     |                                                                      |
|       |      |                    | nak_release_scl                                                     |    |     |                                                                      |
| 13    | RW   | 0×0                | 0: Hold scl as low when recieved nack                               |    |     |                                                                      |
|       |      |                    | 1: Release scl as high when recieved nack                           |    |     |                                                                      |
|       |      | 0x0                | flt_en                                                              |    |     |                                                                      |
| 12    | RW   |                    | SCL edage glitch filter enable                                      |    |     |                                                                      |
| 12    |      |                    | 0: disable                                                          |    |     |                                                                      |
|       |      |                    | 1: enable                                                           |    |     |                                                                      |
| 11:8  | RW   | 0x0                | slv_hold_scl_th                                                     |    |     |                                                                      |
| 11.0  |      | 0.00               | Slave hold scl threshold = slv_hold_scl_th * Tclk_i2c               |    |     |                                                                      |
| 7:4   | RW   | .W 0x0             | flt_r                                                               |    |     |                                                                      |
| 7.4   |      | 0.00               | Filter scl rising edge glitches of width less than flt_r * Tclk_i2c |    |     |                                                                      |
| 2.0   |      | 0.20               | flt_f                                                               |    |     |                                                                      |
| 3:0   | KW   | KW                 | КW                                                                  | RW | 0x0 | Filter scl falling edge glitches of width less than flt_f * Tclk_i2c |

# **17.5 Interface Description**

Table 17-112C Interface Description

| Module<br>pin | Dire<br>ctio<br>n | Pin name                           | ΙΟΜUΧ                       |
|---------------|-------------------|------------------------------------|-----------------------------|
|               |                   | I2C0 Interface                     |                             |
| i2c0_sda      | I/O               | GPIO1_D0/UART1_RX/I2C0_SDA/SPI2_CL | GRF_GPIO1D_IOMUX[1:0]=2'b10 |
|               |                   | К                                  |                             |
| i2c0_scl      | I/O               | GPIO1_D1/UART1_TX/I2C0_SCL/SPI2_CS | GRF_GPIO1D_IOMUX[3:2]=2'b10 |
|               |                   | NO                                 |                             |
|               |                   | I2C1 Interface                     |                             |
| i2c1_sda      | I/O               | GPIO0_B3/I2C1_SDA                  | GRF_GPIO0B_IOMUX[7:6]=2'b01 |
| i2c1_scl      | I/O               | GPIO0_B4/I2C1_SCL                  | GRF_GPIO0B_IOMUX[9:8]=2'b01 |
|               |                   | I2C2 Interface                     |                             |
| i2c2_sda      | I/O               | GPIO2_A2/UART0_CTSN/SPI0_CLK/I2C2_ | GRF_GPIO2A_IOMUX[5:4]=2'b11 |
|               |                   | SDA                                |                             |
| i2c2_scl      | I/O               | GPIO2_A3/UART0_RTSN/SPI0_CSN0/I2C2 | GRF_GPIO2A_IOMUX[7:6]=2'b11 |
|               |                   | _SCL                               |                             |

|           | I2C3 M0 Interface |                                     |                                 |  |  |  |  |
|-----------|-------------------|-------------------------------------|---------------------------------|--|--|--|--|
| i2c3m0_sd | I/O               | GPIO0_B7/PWM2/I2C3_SDA_M0           | GRF_GPIO0B_IOMUX[15:14]=2'b10   |  |  |  |  |
| а         |                   |                                     |                                 |  |  |  |  |
| i2c3m0_sc | I/O               | GPIO0_C0/PWM3/I2C3_SCL_M0           | GRF_GPIO0C_IOMUX[1:0]=2'b10     |  |  |  |  |
| ļ         |                   |                                     |                                 |  |  |  |  |
|           |                   | I2C3 M1 Interface                   | e                               |  |  |  |  |
| i2c3m1_sd | I/O               | GPIO3_B4/FLASH_RDY/I2C3_SDA_M1/SPI  | GRF_GPIO3B_IOMUX[11:8]=4'b0010  |  |  |  |  |
| а         |                   | 1_MOSI/UART3_RX                     |                                 |  |  |  |  |
| i2c3m1_sc | I/O               | GPIO3_B5/FLASH_CSN0/I2C3_SCL_M1/SP  | GRF_GPIO3B_IOMUX[15:12]=4'b0010 |  |  |  |  |
| 1         |                   | I1_CSN0/UART3_TX 3scl_GPIO1B5vccio0 |                                 |  |  |  |  |

The I/O interface of I2C3 can be chosen by setting GRF\_SOC\_CON5[4] bit, if this bit is set to 1, I2C3 uses the I2C3m1 I/O interface, if those bit is set to 0, I2C3 uses the I2C3m0 I/O interface.

# **17.6 Application Notes**

The I2C controller core operation flow chart below is to describe how the software configures and performs an I2C transaction through this I2C controller core. Descriptions are divided into 3 sections, transmit only mode, receive only mode, and mix mode. Users are strongly advised to follow

• Transmit only mode (I2C\_CON[1:0]=2'b00)



Receive only mode (I2C\_CON[1:0]=2'b10)



Fig. 17-7 I2C Flow chat for receive only mode

Mix mode (I2C\_CON[1:0]=2'b01 or I2C\_CON[1:0]=2'b11)





# Chapter 18 I2S 2-channel

# **18.1 Overview**

The I2S/PCM controller is designed for interfacing between the AHB bus and the I2S bus. The I2S bus (Inter-IC sound bus) is a serial link for digital audio data transfer between devices in the system and is invented by Philips Semiconductor. Now it is widely used by many semiconductor manufacturers.

I2S bus is widely used in the devices such as ADC, DAC, DSP, CPU, etc. With the I2S interface, we can connect audio devices and the embedded SoC platform together and provide an audio interface solution for the system.

## 18.1.1 Features

Not only I2S but also PCM mode stereo audio output and input are supported in I2S/PCM controller.

- Support two internal 32-bit wide and 32-location deep FIFOs, one for transmitting and the other for receiving audio data
- Support AHB bus interface
- Support 16~32 bits audio data transfer
- Support master and slave mode
- Support DMA handshaking interface and configurable DMA water level
- Support transmit FIFO empty, underflow, receive FIFO full, overflow interrupt and all interrupts can be masked
- Support configurable water level of transmit FIFO empty and receive FIFO full interrupt
- Support combined interrupt output
- Support 2-channel audio transmitting in I2S mode and PCM mode
- Support 2-channel audio receiving in I2S and PCM mode
- Support up to 192kHz sample rate
- Support I2S normal, left and right justified mode serial audio data transfer
- Support PCM early, late1, late2, late3 mode serial audio data transfer
- Support MSB or LSB first serial audio data transfer
- Support 16 to 31 bit audio data left or right justified in 32-bit wide FIFO
- Support two 16-bit audio data store together in one 32-bit wide location
- Support 2 independent LRCK signals, one for receiving and the other for transmitting audio data
- Support configurable SCLK and LRCK polarity

# 18.2 Block Diagram



Fig. 18-1 I2S/PCM controller (2 channel) Block Diagram

#### System Interface

The system interface implements the AHB slave operation. It contains not only control

registers of transmitters and receiver inside but also interrupt and DMA handshaking interface.

#### **Clock Generator**

The Clock Generator implements clock generation function. The input source clock to the module is MCLK\_I2S, and by the divider of the module, the clock generator generates SCLK and LRCK to transmitter and receiver.

#### Transmitters

The Transmitters implement transmission operation. The transmitters can act as either a master or a slave, with I2S or PCM mode stereo serial audio interface.

#### Receiver

The Receiver implements receive operation. The receiver can act as either a master or a slave, with I2S or PCM mode stereo serial audio interface.

#### **Transmit FIFO**

The Transmit FIFO is the buffer to store transmitted audio data. The size of the FIFO is  $32bits \times 32$ .

#### **Receive FIFO**

The Receive FIFO is the buffer to store received audio data. The size of the FIFO is 32bits x 32.Function Description

# **18.3 Function description**

In the I2S/PCM controller, there are four types: transmitter-master & receiver-master; transmitter-master & receiver-slave; transmitter-slave & receiver-master; transmitter-slave & receiver-slave.

In broadcasting application, the I2S/PCM controller is used as a transmitter and external or internal audio CODEC is used as a receiver. In recording application, the I2S/PCM controller is used as a receiver and external or internal audio CODEC is used as a transmitter. Either the I2S/PCM controller or the audio CODEC can act as a master or a slave, but if one is master, the other must be slave.



Fig. 18-2 I2S transmitter-master & receiver-slave condition

When the transmitter acts as a master, it sends all signals to the receiver (the slave), and CPU controls when to send clock and data to the receiver. When acts as a slave, SD signal still goes from transmitter to receiver, but SCLK and LRCK signals are from the receiver (the master) to the transmitter. Based on three interface specifications, transmitting data should be ready before transmitter receives SCLK and LRCK signals. CPU should know when the receiver to initialize a transaction and when the transmitter to send data.



Fig. 18-3 I2S transmitter-slave & receiver-master condition

When the receiver acts as a master, it sends SCLK and LRCK signals to the transmitter (the slave) and receives serial data. So CPU must tell the transmitter when to start a transaction for it to prepare transmitting data then start a transfer and send clock and channel-select signals. When the receiver acts as a slave, CPU should only do initial setting and wait for all signals and then start reading data.

Before transmitting or receiving data, CPU need do initial setting to the I2S register. These includes CPU settings, I2S interface registers settings, and maybe the embedded SoC platform settings. These registers must be set before starting data transfer.

#### 18.3.1 I2S normal mode

This is the waveform of I2S normal mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes low to indicate left channel and high to right channel. For SD (i2s\_sdo, i2s\_sdi) signal, it starts sending the first bit (MSB or LSB) one SCLK clock cycle after LRCK changes. The range of SD signal width is from 16 to 32bits.



Fig. 18-4 I2S normal mode timing format

## 18.3.2 I2S left justified mode

This is the waveform of I2S left justified mode. For LRCK (i2s\_lrck\_rx / i2s\_lrck\_tx) signal, it goes high to indicate left channel and low to right channel. For SD (i2s\_sdo, i2s\_sdi) signal, it starts sending the first bit (MSB or LSB) at the same time when LRCK changes. The range of SD signal width is from 16 to 32bits.



Fig. 18-5 I2S left justified mode timing format

## 18.3.3 I2S right justified mode

This is the waveform of I2S right justified mode. For LRCK (i2s\_lrck\_rx/ i2s\_lrck\_tx) signal, it goes high to indicate left channel and low to right channel. For SD (i2s\_sdo, i2s\_sdi) signal, it transfers MSB or LSB first; but what is different from I2S normal or left justified mode, the last bit of the transferred data is aligned to the transition edge of the LRCK signal while one bit is transferred at one SCLK cycle. The range of SD signal width is from 16 to 32bits.



Fig. 18-6 I2S right justified mode timing format

## 18.3.4 PCM early mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo, i2s\_sdi) signal, it sends the first bit (MSB or LSB) at the same time when LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 18-7 PCM early mode timing format

## 18.3.5 PCM late1 mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo, i2s\_sdi) signal, it

sends the first bit (MSB or LSB) one SCLK clock cycle after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 18-8 PCM late1 mode timing format

#### 18.3.6 PCM late2 mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo, i2s\_sdi) signal, it sends the first bit (MSB or LSB)two SCLK clock cycles after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 18-9 PCM late2 mode timing format

#### 18.3.7 PCM late3 mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo, i2s\_sdi) signal, it sends the first bit (MSB or LSB) three SCLK clock cycles after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 18-10 PCM late3 mode timing format

# **18.4 Register Description**

## 18.4.1 Registers Summary

| Name       | Offset | Size | Reset<br>Value | Description                      |
|------------|--------|------|----------------|----------------------------------|
| I2S TXCR   | 0x0000 | w    | 0x00000000     | Transmit Operation Control       |
|            | 0,0000 | vv   | 0,00000000     | Register                         |
| I2S RXCR   | 0x0004 | w    | 0x00000000     | Receive Operation Control        |
| 125_RACK   | 0x0004 | vv   | 0x00000000     | Register                         |
| I2S CKR    | 0x0008 | W    | 0x00001f00     | Clock Generation Register        |
| I2S_FIFOLR | 0x000c | W    | 0x00000000     | FIFO Level Register              |
| I2S DMACR  | 0x0010 | W    | 0x001f0000     | DMA Control Register             |
| I2S_INTCR  | 0x0014 | W    | 0x0000000      | Interrupt Control Register       |
| I2S INTSR  | 0x0018 | W    | 0x0000000      | Interrupt Status Register        |
| I2S XFER   | 0x001c | W    | 0x0000000      | Transfer Start Register          |
| I2S CLR    | 0x0020 | W    | 0x0000000      | SCLK Domain Logic Clear Register |
| I2S TXDR   | 0x0024 | W    | 0x0000000      | Transmit FIFO Data Register      |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# 18.4.2 Detail Register Description

## I2S\_TXCR

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                    |
| 22:17 | RW   | 0×00        | RCNT<br>Right Jusitified Counter<br>(Can be written only when XFER[0] bit is 0.)<br>Only valid in I2S Right justified format and slave tx mode is<br>selected.<br>Start to transmit data RCNT sclk cycles after left channel valid.                                                                                                                                                         |
| 16:15 | RW   | 0×0         | CSR<br>Channel Select Register<br>2'b00: 2 channel<br>2'b01~2'b11: reserved                                                                                                                                                                                                                                                                                                                 |
| 14    | RW   | 0×0         | HWT<br>Halfword Word Transform<br>(Can be written only when XFER[0] bit is 0.)<br>Only valid when VDW select 16bit data.<br>1'b0: 32 bit data valid from AHB/APB bus. Low 16 bit for left<br>channel and high 16 bit for right channel.<br>1'b1: low 16bit data valid from AHB/APB bus, high 16 bit data<br>invalid.                                                                        |
| 13    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                    |
| 12    | RW   | 0×0         | SJM<br>Store Justified Mode<br>(Can be written only when XFER[0] bit is 0.)<br>16bit~31bit DATA stored in 32 bits width fifo.<br>If VDW select 16bit data, this bit is valid only when HWT select<br>0.Because if HWT is 1, every fifo unit contain two 16bit data and<br>32 bit space is full, it is impossible to choose justified mode.<br>1'b0: right justified<br>1'b1: left justified |
| 11    | RW   | 0×0         | FBM<br>First Bit Mode<br>(Can be written only when XFER[0] bit is 0.)<br>1'b0: MSB<br>1'b1: LSB                                                                                                                                                                                                                                                                                             |
| 10:9  | RW   | 0×0         | IBM<br>I2S Bus Mode<br>(Can be written only when XFER[0] bit is 0.)<br>2'b00: I2S normal<br>2'b01: I2S Left justified<br>2'b10: I2S Right justified<br>2'b11: reserved                                                                                                                                                                                                                      |

|     |    |      | РВМ                                          |
|-----|----|------|----------------------------------------------|
|     |    |      | PCM Bus Mode                                 |
|     |    |      | (Can be written only when XFER[0] bit is 0.) |
| 8:7 | RW | 0x0  | 2'b00: PCM no delay mode                     |
|     |    |      | 2'b01: PCM delay 1 mode                      |
|     |    |      | 2'b10: PCM delay 2 mode                      |
|     |    |      | 2'b11: PCM delay 3 mode                      |
| 6   | RO | 0x0  | reserved                                     |
|     |    |      | TFS                                          |
|     |    |      | Transfer Format Select                       |
| 5   | RW | 0x0  | (Can be written only when XFER[0] bit is 0.) |
|     |    |      | 1'b0: I2S format                             |
|     |    |      | 1'b1: PCM format                             |
|     |    |      | VDW                                          |
|     |    |      | Valid Data Width                             |
|     |    |      | (Can be written only when XFER[0] bit is 0.) |
|     |    |      | 5'b00000~5'b01110: reserved                  |
|     |    |      | 5'b01111: 16bit                              |
|     |    |      | 5'b10000: 17bit                              |
| 4:0 | RW | 0x00 | 5'b10001: 18bit                              |
|     |    |      | 5'b10010: 19bit                              |
|     |    |      |                                              |
|     |    |      | 5'b11100: 29bit                              |
|     |    |      | 5'b11101: 30bit                              |
|     |    |      | 5'b11110: 31bit                              |
|     |    |      | 5'b11111: 32bit                              |

**<u>I2S\_RXCR</u>** Address: Operational Base + offset (0x0004)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                      |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                         |
| 14    | RW   | 0×0                | HWT<br>Halfword Word Transform<br>(Can be written only when XFER[1] bit is 0.)<br>Only valid when VDW select 16bit data.<br>1'b0: 32 bit data valid to AHB/APB bus. Low 16 bit for left<br>channel and high 16 bit for right channel.<br>1'b1: low 16bit data valid to AHB/APB bus, high 16 bit data<br>invalid. |
| 13    | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                         |

| Bit  | Attr | Reset Value | Description                                                       |
|------|------|-------------|-------------------------------------------------------------------|
|      |      |             | SJM                                                               |
|      |      |             | Store Justified Mode                                              |
|      |      |             | (Can be written only when XFER[1] bit is 0.)                      |
|      |      |             | 16bit~31bit DATA stored in 32 bits width fifo.                    |
| 12   | RW   | 0x0         | If VDW select 16bit data, this bit is valid only when HWT select  |
|      |      |             | 0.Because if HWT is 1, every fifo unit contain two 16bit data and |
|      |      |             | 32 bit space is full, it is impossible to choose justified mode.  |
|      |      |             | 1'b0: right justified                                             |
|      |      |             | 1'b1: left justified                                              |
|      |      |             | FBM                                                               |
|      |      |             | First Bit Mode                                                    |
| 11   | RW   | 0x0         | (Can be written only when XFER[1] bit is 0.)                      |
|      |      |             | 1'b0: MSB                                                         |
|      |      |             | 1'b1: LSB                                                         |
|      |      |             | IBM                                                               |
|      |      |             | I2S Bus Mode                                                      |
|      |      |             | (Can be written only when XFER[1] bit is 0.)                      |
| 10:9 | RW   | 0x0         | 2'b00: I2S normal                                                 |
|      |      |             | 2'b01: I2S Left justified                                         |
|      |      |             | 2'b10: I2S Right justified                                        |
|      |      |             | 2'b11: reserved                                                   |
|      |      |             | РВМ                                                               |
|      |      |             | PCM Bus Mode                                                      |
|      |      |             | (Can be written only when XFER[1] bit is 0.)                      |
| 8:7  | RW   | 0x0         | 2'b00: PCM no delay mode                                          |
|      |      |             | 2'b01: PCM delay 1 mode                                           |
|      |      |             | 2'b10: PCM delay 2 mode                                           |
|      |      |             | 2'b11: PCM delay 3 mode                                           |
| 6    | RO   | 0x0         | reserved                                                          |
|      |      |             | TFS                                                               |
|      |      |             | Transfer Format Select                                            |
| 5    | RW   | 0x0         | (Can be written only when XFER[1] bit is 0.)                      |
|      |      |             | 1'b0: i2s                                                         |
|      |      |             | 1'b1: pcm                                                         |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                     |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | 0×00        | VDW<br>Valid Data Width<br>(Can be written only when XFER[1] bit is 0.)<br>5'b00000~5'b01110: reserved<br>5'b01111: 16bit<br>5'b10000: 17bit<br>5'b10001: 18bit<br>5'b10010: 19bit<br><br>5'b11100: 29bit<br>5'b11101: 30bit<br>5'b11111: 32bit |

## <u>125\_CKR</u>

Address: Operational Base + offset (0x0008)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 29:28 | RW   | 0×0                | TRCM<br>TX/RX LRCK as common<br>2'b00/2'b11: tx_lrck/rx_lrck are used as synchronous signal for<br>TX /RX respectively.<br>2'b01: only tx_lrck is used as synchronous signal for TX and RX.<br>2'b10: only rx_lrck is used as synchronous signal for TX and RX.<br>Note: When set to 2'b01 or 2'b10, if user wants to use both<br>transmitting and receiving in master mode, user should configure<br>as following:<br>a. The value of TSD and RSD should be same.<br>b. User should start TX transfer and RX transfer at the same<br>time. |
| 27    | RW   | 0x0                | MSS<br>Master/Slave Mode Select<br>(Can be written only when XFER[1] or XFER[0] bit is 0.)<br>1'b0: master mode(sclk output)<br>1'b1: slave mode(sclk input)                                                                                                                                                                                                                                                                                                                                                                                |
| 26    | RW   | 0×0                | CKP<br>Sclk Polarity<br>(Can be written only when XFER[1] or XFER[0] bit is 0.)<br>1'b0: sample data at posedge sclk and drive data at negedge sclk<br>1'b1: sample data at negedge sclk and drive data at posedge sclk                                                                                                                                                                                                                                                                                                                     |

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25    | RW   | 0×0                | RLP<br>Receive Lrck Polarity<br>(Can be written only when XFER[1] or XFER[0] bit is 0.)<br>1'b0: normal polarity<br>(I2S normal: low for left channel, high for right channel<br>I2S left/right just: high for left channel, low for right channel<br>PCM start signal: high valid)<br>1'b1: opposite polarity<br>(I2S normal: high for left channel, low for right channel<br>I2S left/right just: low for left channel, high for right channel<br>PCM start signal: high valid)  |
| 24    | RW   | 0×0                | TLP<br>Transmit Lrck Polarity<br>(Can be written only when XFER[1] or XFER[0] bit is 0.)<br>1'b0: normal polarity<br>(I2S normal: low for left channel, high for right channel<br>I2S left/right just: high for left channel, low for right channel<br>PCM start signal: high valid)<br>1'b1: opposite polarity<br>(I2S normal: high for left channel, low for right channel<br>I2S left/right just: low for left channel, high for right channel<br>PCM start signal: high valid) |
| 23:16 | RW   | 0×00               | MDIV<br>Mclk Divider<br>(Can be written only when XFER[1] or XFER[0] bit is 0.)<br>mclk divider = (mclk/sclk)-1.<br>For example, if mclk divider is 5, then the frequency of sclk is<br>mclk/6<br>RSD                                                                                                                                                                                                                                                                              |
| 15:8  | RW   | 0x1f               | Receive Sclk Divider<br>(Can be written only when XFER[1] or XFER[0] bit is 0.)<br>8'h00~8'h1e: reserved<br>8'h1f~8'hff: frequency of sclk = (RSD>>1 +1)*2*frequency of<br>rx_lrck                                                                                                                                                                                                                                                                                                 |
| 7:0   | RW   | 0×00               | TSD<br>Transmit Sclk Divider<br>(Can be written only when XFER[1] or XFER[0] bit is 0.)<br>8'h00~8'h1e: reserved<br>8'h1f~8'hff: frequency of sclk = (TSD>>1 + 1)*2*frequency of<br>tx_lrck                                                                                                                                                                                                                                                                                        |

**<u>I2S FIFOLR</u>** Address: Operational Base + offset (0x000c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
| 31:30 | RO   | 0x0                | reserved                                                        |
|       |      |                    | RFL                                                             |
| 29:24 | RO   | 0x00               | Receive FIFO Level                                              |
|       |      |                    | Contains the number of valid data entries in the receive FIFO.  |
| 23:6  | RO   | 0x0                | reserved                                                        |
|       |      |                    | TFL                                                             |
| 5:0   | RW   | 0x00               | Transmit FIFO0 Level                                            |
|       |      |                    | Contains the number of valid data entries in the transmit FIFO. |

## I2S\_DMACR

Address: Operational Base + offset (0x0010)

| Bit   | Attr | <b>Reset Value</b> | Description                                                          |
|-------|------|--------------------|----------------------------------------------------------------------|
| 31:25 | RO   | 0x0                | reserved                                                             |
|       |      |                    | RDE                                                                  |
| 24    | RW   | 0x0                | Receive DMA Enable                                                   |
| 24    | ĸw   | 0.00               | 1'b0: Receive DMA disabled                                           |
|       |      |                    | 1'b1: Receive DMA enabled                                            |
| 23:21 | RO   | 0x0                | reserved                                                             |
|       |      |                    | RDL                                                                  |
|       |      |                    | Receive Data Level                                                   |
| 20:16 |      | 0x1f               | This bit field controls the level at which a DMA request is made by  |
| 20.10 | ĸw   | UXIT               | the receive logic. The watermark level = DMARDL+1; that is,          |
|       |      |                    | dma_rx_req is generated when the number of valid data entries        |
|       |      |                    | in the receive FIFO is equal to or above this field value $+$ 1.     |
| 15:9  | RO   | 0x0                | reserved                                                             |
|       |      | 0×0                | TDE                                                                  |
| 8     | RW   |                    | Transmit DMA Enable                                                  |
| 0     |      |                    | 1'b0: Transmit DMA disabled                                          |
|       |      |                    | 1'b1: Transmit DMA enabled                                           |
| 7:5   | RO   | 0x0                | reserved                                                             |
|       |      |                    | TDL                                                                  |
|       |      | W 0×00             | Transmit Data Level                                                  |
| 4:0   |      |                    | This bit field controls the level at which a DMA request is made by  |
| 4:0   | RW   |                    | the transmit logic. It is equal to the watermark level; that is, the |
|       |      |                    | dma_tx_req signal is generated when the number of valid data         |
|       |      |                    | entries in the TXFIFO is equal to or below this field value.         |

## **I2S INTCR**

Address: Operational Base + offset (0x0014)

| Bit   | Attr | <b>Reset Value</b> | Description                                                          |
|-------|------|--------------------|----------------------------------------------------------------------|
| 31:25 | RO   | 0x0                | reserved                                                             |
|       |      |                    | RFT                                                                  |
| 24:20 |      | 0x00               | Receive FIFO Threshold                                               |
| 24:20 | RVV  | 0,000              | When the number of receive FIFO entries is more than or equal to     |
|       |      |                    | this threshold plus 1, the receive FIFO full interrupt is triggered. |
| 19    | RO   | 0x0                | reserved                                                             |
|       |      |                    | RXOIC                                                                |
| 18    | WO   | 0x0                | RX Overrun Interrupt Clear                                           |
|       |      |                    | Write 1 to clear RX overrun interrupt.                               |
|       |      |                    | RXOIE                                                                |
| 17    | RW   | 0x0                | RX Overrun Interrupt Enable                                          |
| 17    | K VV | 0.00               | 1'b0: disable                                                        |
|       |      |                    | 1'b1: enable                                                         |
|       |      |                    | RXFIE                                                                |
| 16    | RW   | 0x0                | RX Full Interrupt Enable                                             |
| 10    | K VV | UXU                | 1'b0: disable                                                        |
|       |      |                    | 1'b1: enable                                                         |
| 15:9  | RO   | 0x0                | reserved                                                             |
|       |      |                    | TFT                                                                  |
| 8:4   | RW   | 0x00               | Transmit FIFO Threshold                                              |
| 0:4   |      |                    | When the number of transmit FIFO entries is less than or equal to    |
|       |      |                    | this threshold, the transmit FIFO empty interrupt is triggered.      |
| 3     | RO   | 0x0                | reserved                                                             |
|       |      |                    | TXUIC                                                                |
| 2     | WO   | O 0x0              | TX Underrun Interrupt Clear                                          |
|       |      |                    | Write 1 to clear TX underrun interrupt.                              |
|       |      |                    | TXUIE                                                                |
| 1     | RW   | 0.20               | TX Underrun Interrupt Enable                                         |
| 1     | K VV | 0x0                | 1'b0: disable                                                        |
|       |      |                    | 1'b1: enable                                                         |
|       |      |                    | TXEIE                                                                |
| 0     |      |                    | TX empty Interrupt Enable                                            |
| 0     | RW   | XW 0x0             | 1'b0: disable                                                        |
|       |      |                    | 1'b1: enable                                                         |

## I2S\_INTSR

Address: Operational Base + offset (0x0018)

| Bit   | Attr | <b>Reset Value</b> | Description          |
|-------|------|--------------------|----------------------|
| 31:18 | RO   | 0x0                | reserved             |
|       |      | 0×0                | RXOI                 |
| 17    | RO   |                    | RX Overrun Interrupt |
| 17    |      |                    | 1'b0: inactive       |
|       |      |                    | 1'b1: active         |

| Bit  | Attr | Reset Value | Description           |
|------|------|-------------|-----------------------|
|      |      |             | RXFI                  |
| 16   | RO   | 0x0         | RX Full Interrupt     |
| 10   | RU   | 0.00        | 1'b0: inactive        |
|      |      |             | 1'b1: active          |
| 15:2 | RO   | 0x0         | reserved              |
|      |      | O 0x0       | TXUI                  |
| 1    |      |             | TX Underrun Interrupt |
| 1    | RO   |             | 1'b0: inactive        |
|      |      |             | 1'b1: active          |
|      |      | RO 0x0      | TXEI                  |
| 0    |      |             | TX Empty Interrupt    |
| 0    | RU   |             | 1'b0: inactive        |
|      |      |             | 1'b1: active          |

## I2S XFER

Address: Operational Base + offset (0x001c)

| Bit    | Attr | <b>Reset Value</b> | Description             |
|--------|------|--------------------|-------------------------|
| 31:2   | RO   | 0x0                | reserved                |
|        |      |                    | RXS                     |
| 1      |      | 0x0                | RX Transfer Start Bit   |
| 1<br>L | RW   |                    | 1'b0: stop RX transfer  |
|        |      |                    | 1'b1: start RX transfer |
|        |      | RW 0x0             | TXS                     |
| 0      |      |                    | TX Transfer Start Bit   |
| U      | K VV |                    | 1'b0: stop TX transfer  |
|        |      |                    | 1'b1: start TX transfer |

## <u>I2S\_CLR</u>

Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description                                                      |
|------|------|--------------------|------------------------------------------------------------------|
| 31:2 | RO   | 0x0                | reserved                                                         |
| 1    | RW   | 0x0                | RXC<br>RX Logic Clear                                            |
|      |      |                    | This is a self-cleared bit. Write 1 to clear all receive logic.  |
|      |      |                    | ТХС                                                              |
| 0    | RW   | 0x0                | TX Logic Clear                                                   |
|      |      |                    | This is a self-cleared bit. Write 1 to clear all transmit logic. |

## I2S\_TXDR

Address: Operational Base + offset (0x0024)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
|      |      |                    | TXDR                                                          |
| 31:0 | RW   | 0x00000000         | Transmit FIFO Data Register                                   |
|      |      |                    | When it is written to, data are moved into the transmit FIFO. |

#### I2S RXDR

Address: Operational Base + offset (0x0028)

| Bit  | Attr | <b>Reset Value</b> | Description                                                      |
|------|------|--------------------|------------------------------------------------------------------|
|      |      |                    | RXDR                                                             |
| 31:0 | RW   | 0x00000000         | Receive FIFO Data Register                                       |
|      |      |                    | When the register is read, data in the receive FIFO is accessed. |

# **18.5 Interface Description**

There are two 2-channel I2S in total. The I2S02CH is for transmitting and receiving audio data while the I2S12CH is only for receiving audio data. Signal i2s\_lrck\_tx will be shared if the I2S02CH works at transmitting and receiving modes at the same time.

| Module Pin      | Direction | PIN Name        | IOMUX Setting                 |  |  |  |  |  |  |  |
|-----------------|-----------|-----------------|-------------------------------|--|--|--|--|--|--|--|
| i2s02ch_clk     | 0         | I2S0_2CH_MCLK   | GRF_GPIO4B_IOMUX[9:8]=2'b01   |  |  |  |  |  |  |  |
| i2s02ch_sclk    | I/O       | I2S0_2CH_SCLK   | GRF_GPIO4B_IOMUX[11:10]=2'b01 |  |  |  |  |  |  |  |
| i2s02ch_lrck_tx | I/O       | I2S0_2CH_LRCK_T | GRF_GPIO4B_IOMUX[13:12]=2'b01 |  |  |  |  |  |  |  |
|                 | -         | X               |                               |  |  |  |  |  |  |  |
| i2s02ch_sdo     | 0         | I2S0_2CH_SDO    | GRF_GPIO4B_IOMUX[15:14]=2'b01 |  |  |  |  |  |  |  |
| i2s02ch_sdi     | Ι         | I2S0_2CH_SDI    | GRF_GPIO4C_IOMUX[1:0]=2'b01   |  |  |  |  |  |  |  |

The I2S12CH is connected to the audio codec which is used to receive audio data. It works at slave mode and receives audio data from audio codec by configuring GRF\_SOC\_CON1. Table 18-2 I2S12CH Interface Description

| Module Pin     | Direction | Module Pin      | IOMUX Setting             |  |  |  |  |  |  |
|----------------|-----------|-----------------|---------------------------|--|--|--|--|--|--|
| pin_adc_sck_o  | 0         | i2s12ch_sclk    |                           |  |  |  |  |  |  |
| pin_adc_ws_o   | 0         | i2s12ch_lrck_rx |                           |  |  |  |  |  |  |
| pin_adc_sd_o_0 | 0         |                 | GRF_SOC_CON1[13:12]=2'b00 |  |  |  |  |  |  |
| pin_adc_sd_o_1 | 0         | iJa1Jah adi     | GRF_SOC_CON1[13:12]=2'b01 |  |  |  |  |  |  |
| pin_adc_sd_o_2 | 0         | i2s12ch_sdi     | GRF_SOC_CON1[13:12]=2'b10 |  |  |  |  |  |  |
| pin_adc_sd_o_3 | 0         |                 | GRF_SOC_CON1[13:12]=2'b11 |  |  |  |  |  |  |

# **18.6 Application Notes**



Fig. 18-11 I2S/PCM controller transmit operation flow chart



Fig. 18-12 I2S/PCM controller receive operation flow chart

There are 3 operation modes which are normal mode, TX common mode and RX common mode. Following shows the normal mode connections, <u>I2S\_CKR[29:28]</u> should be set to 2'b00.



Fig. 18-13 I2S/PCM normal mode

For TX common mode, only IO\_LRCK\_TX is used and <u>I2S\_CKR[</u>29:28] should be set to 2'b01. TX/RX should work at the same time and at the same sample rate.



Fig. 18-14 I2S/PCM TX common mode For RX common mode, only IP\_LRCK\_RX is used and <u>I2S\_CKR[</u>29:28] should be set to 2'b10. TX/RX should work at the same time and at the same sample rate.



Fig. 18-15 I2S/PCM RX common mode

# Chapter 19 I2S 8-channel

# **19.1 Overview**

The I2S/PCM/TDM controller is designed for interfacing between the AHB bus and the I2S bus.

The I2S bus (Inter-IC sound bus) is a serial link for digital audio data transfer between devices in the system and is invented by Philips Semiconductor. Now it is widely used by many semiconductor manufacturers.

I2S bus is widely used in the devices such as ADC, DAC, DSP, CPU, etc. With the I2S interface, we can connect audio devices and the embedded SoC platform together and provide an audio interface solution for the system.

#### 19.1.1 Features

The I2S/PCM/TDM controller supports I2S, PCM and TDM mode stereo audio output and input.

- Support eight internal 32-bit wide and 32-location deep FIFOs, four for transmitting and the other for receiving audio data
- Support AHB bus interface
- Support 16 ~ 32 bits audio data transfer
- Support master and slave mode
- Support DMA handshaking interface and configurable DMA water level
- Support transmit FIFO empty, underflow, receive FIFO full, overflow interrupt and all interrupts can be masked
- Support configurable water level of transmit FIFO empty and receive FIFO full interrupt
- Support combined interrupt output
- Support 8-channel audio transmitting in I2S/TDM mode and 2-channel in PCM mode.
- Support 8-channel audio receiving in I2S/TDM mode and 2 channel in PCM mode
- Support up to 192kHz sample rate
- Support I2S normal, left and right justified mode serial audio data transfer
- Support PCM early, late1, late2, late3 mode serial audio data transfer
- Support TDM normal,1/2 cycle left shift ,1 cycle left shift,2 cycle left shift, right shift mode serial audio data transfer.
- Support MSB or LSB first serial audio data transfer
- Support 16 to 31 bits audio data left or right justified in 32-bit wide FIFO
- Support two 16-bit audio data store together in one 32-bit wide location
- Support 2 independent LRCK signals, one for receiving and the other for transmitting audio data. Single LRCK can be used for transmitting and receiving data if the sample rate are the same
- Support configurable SCLK and LRCK polarity
- Support TDM programmable slot bit width: 16~32bits
- Support TDM programmable frame width: 32~512bits
- Support TDM programmable FSYNC width
- Support SDI, SDO IOMUX.

# 19.2 Block Diagram



Fig. 19-1 I2S/PCM/TDM controller (8 channel) Block Diagram

#### **System Interface**

The system interface implements the AHB slave operation. It contains not only control registers of transmitters and receiver inside but also interrupt and DMA handshaking interface.

#### **Clock Generator**

The Clock Generator implements clock generation function. The input source clock to the module is MCLK\_I2S, and by the divider of the module, the clock generator generates SCLK and LRCK to transmitter and receiver.

#### Transmitters

The Transmitters implement transmission operation. The transmitters can act as either a master or a slave, with I2S, PCM or TDM mode surround serial audio interface.

#### Receiver

The Receiver implements receive operation. The receiver can act as either a master or a slave, with I2S, PCM or TDM mode stereo serial audio interface.

#### **Transmit FIFO**

The Transmit FIFO is the buffer to store transmitted audio data. The size of the FIFO is  $32bits \times 32$ .

## **Receive FIFO**

The Receive FIFO is the buffer to store received audio data. The size of the FIFO is 32bits x 32.

# **19.3 Function description**

In the I2S/PCM/TDM controller, there are four types: transmitter-master & receiver-master; transmitter-master & receiver-slave; transmitter-slave & receiver-master; transmitter-slave & receiver-slave.

In broadcasting application, the I2S/PCM/TDM controller is used as a transmitter and external or internal audio CODEC is used as a receiver. In recording application, the I2S/PCM/TDM controller is used as a receiver and external or internal audio CODEC is used as a transmitter. Either the I2S/PCM/TDM controller or the audio CODEC can act as a master or a slave, but if one is master, the other must be slave.





When the transmitter acts as a master, it sends all signals to the receiver (the slave), and CPU controls when to send clock and data to the receiver. When acts as a slave, SD signal still goes from transmitter to receiver, but SCLK and LRCK signals are from the receiver (the master) to the transmitter. Based on three interface specifications, transmitting data should be ready before transmitter receives SCLK and LRCK signals. CPU should know when the receiver to initialize a transaction and when the transmitter to send data.



Fig. 19-3 I2S transmitter-slave & receiver-master condition

When the receiver acts as a master, it sends SCLK and LRCK signals to the transmitter (the slave) and receives serial data. So CPU must tell the transmitter when to start a transaction for it to prepare transmitting data then start a transfer and send clock and channel-select signals. When the receiver acts as a slave, CPU should only do initial setting and wait for all signals and then start reading data.

Before transmitting or receiving data, CPU need do initial setting to the I2S register. These includes CPU settings, I2S interface registers settings, and maybe the embedded SoC platform settings. These registers must be set before starting data transfer.

## 19.3.1 I2S normal mode

This is the waveform of I2S normal mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes low to indicate left channel and high to right channel. For SD (i2s1\_sdo, i2s1\_sdi) signal, it starts sending the first bit (MSB or LSB) one SCLK clock cycle after LRCK changes. The range of SD signal width is from 16 to 32bits.



Fig. 19-4 I2S normal mode timing format

## 19.3.2 I2S left justified mode

This is the waveform of I2S left justified mode. For LRCK (i2s1\_lrck\_rx / i2s1\_lrck\_tx) signal, it goes high to indicate left channel and low to right channel. For SD (i2s1\_sdo, i2s1\_sdi) signal, it starts sending the first bit (MSB or LSB) at the same time when LRCK changes. The range of SD signal width is from 16 to 32bits.

| i2s1_sclk             |   |   | E    |        |    |    | L |   |   | <u> </u> |          |      |    |   |   |   |  |
|-----------------------|---|---|------|--------|----|----|---|---|---|----------|----------|------|----|---|---|---|--|
| i2s1_lrck_rx/         |   |   |      |        |    |    |   |   |   | R        | ight cha | nnel |    |   | ļ |   |  |
| i2s1_lrck_tx —        |   |   | Left | channe | 1  |    |   |   |   |          |          |      |    |   |   |   |  |
| i2s1_sdo/             |   |   |      |        |    |    | г |   |   |          |          |      |    |   |   |   |  |
| i2s1_sdo/<br>i2s1_sdi | 0 | 1 | LL   | 21     | 22 | 23 | L | 0 | I |          | 21       | 22   | 23 | L | 0 | 1 |  |

Fig. 19-5 I2S left justified mode timing format

## 19.3.3 I2S right justified mode

This is the waveform of I2S right justified mode. For LRCK (i2s1\_lrck\_rx/ i2s1\_lrck\_tx) signal, it goes high to indicate left channel and low to right channel. For SD (i2s1\_sdo, i2s1\_sdi) signal, it transfers MSB or LSB first; but what is different from I2S normal or left

justified mode, the last bit of the transferred data is aligned to the transition edge of the LRCK signal while one bit is transferred at one SCLK cycle. The range of SD signal width is from 16 to 32bits.

| i2s1_sclk                     |      |         |   |      |    |   |   |   |   |    |    |    |  |
|-------------------------------|------|---------|---|------|----|---|---|---|---|----|----|----|--|
| i2s1_lrck_rx/                 | Lefi | channel |   |      |    |   |   |   |   |    |    |    |  |
| i2s1_lrck_tx —<br>i2s1_sdo/ — |      |         |   |      |    |   |   |   |   |    |    |    |  |
| i2s1 sdi —                    | 0    | 1       | 2 | 1 22 | 23 | L | 0 | 1 | L | 21 | 22 | 23 |  |

Fig. 19-6 I2S right justified mode timing format

## 19.3.4 PCM early mode

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it sends the first bit (MSB or LSB) at the same time when LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 19-7 PCM early mode timing format

## 19.3.5 PCM late1 mode

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it sends the first bit (MSB or LSB) one SCLK clock cycle after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 19-8 PCM late1 mode timing format

## 19.3.6 PCM late2 mode

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it sends the first bit (MSB or LSB)two SCLK clock cycles after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 19-9 PCM late2 mode timing format

## 19.3.7 PCM late3 mode

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it sends the first bit (MSB or LSB) three SCLK clock cycles after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 19-10 PCM late3 mode timing format

## 19.3.8 TDM normal mode (PCM format)

This is the waveform of TDM normal mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it sends the first bit (MSB or LSB) on the second falling edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



## 19.3.9 TDM left shift mode0 (PCM format)

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it sends the first bit (MSB or LSB) on the second rising edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



## 19.3.10 TDM left shift mode1 (PCM format)

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it sends the first bit (MSB or LSB) on the first falling edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



## 19.3.11 TDM left shift mode2 (PCM format)

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it sends the first bit (MSB or LSB) on the first rising edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



## 19.3.12 TDM left shift mode3 (PCM format)

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck\_rx/i2s1\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s1\_sdo, i2s1\_sdi) signal, it sends the first bit (MSB or LSB) at the same time when LRCK goes high. The range of SD signal width is from 16 to 32bits.



## 19.3.13 TDM normal mode (I2S format)

This is the waveform of I2S normal mode. For SD (i2s1\_sdo, i2s1\_sdi) signal, it starts sending the first bit (MSB or LSB) on the first falling edge of SCLK after LRCK changes. The range of SD signal width is from 16 to 32bits.



This is the waveform of I2S left justified mode. For SD (i2s1\_sdo, i2s1\_sdi) signal, it starts sending the first bit (MSB or LSB) at the same time when LRCK changes. The range of SD signal width is from 16 to 32bits.



## 19.3.15 TDM right justified mode (I2S format)

This is the waveform of I2S right justified mode. For SD (i2s1\_sdo, i2s1\_sdi) signal, it transfers MSB or LSB first; but what is different from I2S normal or left justified mode. The range of SD signal width is from 16 to 32bits.





# **19.4 Register description**

# 19.4.1 Registers Summary

| Name                 | Offset | Size | Reset<br>Value | Description                                     |
|----------------------|--------|------|----------------|-------------------------------------------------|
| I2S_8CH_TXCR         | 0x0000 | w    | 0x7200000f     | Transmit operation control register.            |
| I2S 8CH RXCR         | 0x0004 | W    | 0x01c8000f     | Receive operation control register              |
| <u>12S_8CH_CKR</u>   | 0x0008 | W    | 0x00001f1f     | Clock generation register                       |
| I2S 8CH TXFIFOLR     | 0x000c | W    | 0x00000000     | TX FIFO level register                          |
| 12S 8CH DMACR        | 0x0010 | W    | 0x001f0000     | DMA control register                            |
| 12S 8CH INTCR        | 0x0014 | W    | 0x01f00000     | Interrupt control register                      |
| <u>I2S 8CH INTSR</u> | 0x0018 | W    | 0x00000000     | Interrupt status register                       |
| I2S_8CH_XFER         | 0x001c | W    | 0x00000000     | Transfer start register                         |
| <u>12S 8CH CLR</u>   | 0x0020 | W    | 0x00000000     | SCLK domain logic clear register                |
| <u>I2S 8CH TXDR</u>  | 0x0024 | W    | 0x00000000     | Transmit FIFO data register                     |
| I2S_8CH_RXDR         | 0x0028 | W    | 0x00000000     | Receive FIFO data register                      |
| 12S 8CH RXFIFOLR     | 0x002c | W    | 0x00000000     | RX FIFO level register                          |
| I2S_8CH_TDM_TXCTRL   | 0x0030 | W    | 0x00003eff     | TDM mode transmit operation<br>control register |
| I2S 8CH TDM RXCTRL   | 0x0034 | w    | 0x00003eff     | TDM mode receive operation<br>control register  |
| 12S_8CH_CLKDIV       | 0x0038 | W    | 0x00000707     | Clock divider register                          |
| 12S 8CH VERSION      | 0x003c | W    | 0x20150001     | I2S version register                            |
| I2S 8CH INCR RXDR    | 0x0800 | w    | 0x00000000     | Increment address receive FIFO data register    |

Notes: Size: B- Byte (8 bits) access, HW- Half WORD (16 bits) access, W-WORD (32 bits) access

#### **19.4.2 Detail Register Description <u>12S 8CH TXCR</u>**

Address: Operational Base + offset (0x0000)

| Bit   | Attr | <b>Reset Value</b> | Description                             |
|-------|------|--------------------|-----------------------------------------|
| 31    | RO   | 0x0                | reserved                                |
|       |      |                    | tx_path_select3                         |
|       |      |                    | Tx path select:                         |
|       |      |                    | 2'b00: sdo3 output data from path0;     |
| 30:29 | RW   | 0x3                | 2'b01: sdo3 output data from path1;     |
|       |      |                    | 2'b10: sdo3 output data from path2;     |
|       |      |                    | 2'b11: sdo3 output data from path3;     |
|       |      |                    | Note: when TDM mode, only path0 enable. |

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
|       |      |                    | tx_path_select2                                                   |
|       |      |                    | Tx path select:                                                   |
|       |      |                    | 2'b00: sdo2 output data from path0;                               |
| 28:27 | RW   | 0x2                | 2'b01: sdo2 output data from path1;                               |
|       |      |                    | 2'b10: sdo2 output data from path2;                               |
|       |      |                    | 2'b11: sdo2 output data from path3;                               |
|       |      |                    | Note: when TDM mode, only path0 enable.                           |
|       |      |                    | tx_path_select1                                                   |
|       |      |                    | Tx path select:                                                   |
|       |      |                    | 2'b00: sdo1 output data from path0;                               |
| 26:25 | RW   | 0x1                | 2'b01: sdo1 output data from path1;                               |
|       |      |                    | 2'b10: sdo1 output data from path2;                               |
|       |      |                    | 2'b11: sdo1 output data from path3;                               |
|       |      |                    | Note: when TDM mode, only path0 enable.                           |
|       |      |                    | tx_path_select0                                                   |
|       |      |                    | Tx path select:                                                   |
|       |      | V 0×0              | 2'b00: sdo0 output data from path0;                               |
| 24:23 | RW   |                    | 2'b01: sdo0 output data from path1;                               |
|       |      |                    | 2'b10: sdo0 output data from path2;                               |
|       |      |                    | 2'b11: sdo0 output data from path3;                               |
|       |      |                    | Note: when TDM mode, only path0 enable.                           |
|       |      |                    | RCNT                                                              |
|       |      |                    | right jusitified counter                                          |
|       |      |                    | (Can be written only when XFER[0] bit is 0.)                      |
| 22:17 | RW   | 0x00               | Only vailid in I2S Right justified format and slave tx mode is    |
|       |      |                    | selected.                                                         |
|       |      |                    | Start to transmit data RCNT sclk cycles after left channel valid. |
|       |      |                    | Note: Only function when TX TFS[1]=0;                             |
|       |      |                    | TCSR                                                              |
|       |      |                    | TX Channel select register                                        |
| 16:15 | RW   | 0x0                | 2'b00: two channel                                                |
|       |      |                    | 2'b01: four channel                                               |
|       |      |                    | 2'b10: six channel                                                |
|       |      |                    | 2'b11: eight channel                                              |
|       |      |                    | HWT                                                               |
|       |      |                    | Halfword word transform                                           |
|       |      |                    | (Can be written only when XFER[0] bit is 0.)                      |
| 14    | RW   | 0x0                | Only valid when VDW select 16bit data.                            |
|       |      |                    | 1'b0: 32 bit data valid from AHB/APB bus. Low 16 bit for left     |
|       |      |                    | channel and high 16 bit for right channel.                        |
|       |      |                    | 1'b1: low 16bit data valid from AHB/APB bus, high 16 bit data     |
| 10    |      |                    | invalid.                                                          |
| 13    | RO   | 0x0                | reserved                                                          |

| Bit  | Attr | Reset Value | Description                                                       |
|------|------|-------------|-------------------------------------------------------------------|
|      |      |             | SJM                                                               |
|      |      |             | Store justified mode                                              |
|      |      |             | (Can be written only when XFER[0] bit is 0.)                      |
|      |      |             | 16bit~31bit DATA stored in 32 bits width fifo.                    |
| 12   | RW   | 0x0         | If VDW select 16bit data, this bit is valid only when HWT select  |
|      |      |             | 0.Because if HWT is 1, every fifo unit contain two 16bit data and |
|      |      |             | 32 bit space is full, it is impossible to choose justified mode.  |
|      |      |             | 1'b0: right justified                                             |
|      |      |             | 1'b1: left justified                                              |
|      |      |             | FBM                                                               |
|      |      |             | First Bit Mode                                                    |
| 11   | RW   | 0x0         | (Can be written only when XFER[0] bit is 0.)                      |
|      |      |             | 1'b0: MSB                                                         |
|      |      |             | 1'b1: LSB                                                         |
|      |      |             | IBM                                                               |
|      |      |             | I2S bus mode                                                      |
|      |      | 0×0         | (Can be written only when XFER[0] bit is 0.)                      |
| 10:9 | RW   |             | 2'b00: I2S normal                                                 |
|      |      |             | 2'b01: I2S Left justified                                         |
|      |      |             | 2'b10: I2S Right justified                                        |
|      |      |             | 2'b11: reserved                                                   |
|      |      |             | Note: Only function when TX TFS[1:0] is 0;                        |
|      |      |             | PBM<br>DCM bus mode                                               |
|      |      |             | PCM bus mode                                                      |
|      |      |             | (Can be written only when XFER[0] bit is 0.)                      |
| 8:7  | RW   | 0x0         | 2'b00: PCM no delay mode                                          |
|      |      |             | 2'b01: PCM delay 1 mode<br>2'b10: PCM delay 2 mode                |
|      |      |             | 2'b11: PCM delay 3 mode                                           |
|      |      |             | Note: function when TX TFS[1:0] is 1;                             |
|      |      |             | TFS                                                               |
|      |      |             | Transfer format select                                            |
|      |      |             | (Can be written only when XFER[0] bit is 0.)                      |
| 6:5  | RW   | 0x0         | 2'b00: I2S format                                                 |
|      |      | -           | 2'b01: PCM format                                                 |
|      |      |             | 2'b10: TDM format 0 (PCM mode)                                    |
|      |      |             | 2'b11: TDM format 1 (I2S mode)                                    |

| Bit               | Attr | <b>Reset Value</b>         | Description                                                                                                                                                                                                                                                                                                                              |
|-------------------|------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b><br>4:0 |      | <b>Reset Value</b><br>0x0f | Description           VDW           Valid Data Width           (Can be written only when XFER[0] bit is 0.)           5'b0000~5'b01110: reserved           5'b01111: 16bit           5'b1111: 16bit           5'b10000: 17bit           5'b10001: 18bit           5'b10010: 19bit              5'b11100: 29bit           5'b11101: 30bit |
|                   |      |                            | 5'b11111: 32bit                                                                                                                                                                                                                                                                                                                          |

# I2S\_8CH\_RXCR

Address: Operational Base + offset (0x0004)

| Bit   | Attr | <b>Reset Value</b> | Description                    |
|-------|------|--------------------|--------------------------------|
| 31:25 | RO   | 0x0                | reserved                       |
|       |      |                    | rx_path_select3                |
|       |      |                    | Rx path select:                |
|       |      |                    | 2'b00: path3 data from sdi0;   |
| 24:23 | RW   | 0x3                | 2'b01: path3 data from sdi1;   |
|       |      |                    | 2'b10: path3 data from sdi2;   |
|       |      |                    | 2'b11: path3 data from sdi3;   |
|       |      |                    | Note: inoperative at TDM mode. |
|       |      |                    | rx_path_select2                |
|       |      |                    | Rx path select:                |
|       |      |                    | 2'b00: path2 data from sdi0;   |
| 22:21 | RW   | 0x2                | 2'b01: path2 data from sdi1;   |
|       |      |                    | 2'b10: path2 data from sdi2;   |
|       |      |                    | 2'b11: path2 data from sdi3;   |
|       |      |                    | Note: inoperative at TDM mode. |
|       |      | W 0x1              | rx_path_select1                |
|       |      |                    | Rx path select:                |
|       |      |                    | 2'b00: path1 data from sdi0;   |
| 20:19 | RW   |                    | 2'b01: path1 data from sdi1;   |
|       |      |                    | 2'b10: path1 data from sdi2;   |
|       |      |                    | 2'b11: path1 data from sdi3;   |
|       |      |                    | Note: inoperative at TDM mode. |
|       |      |                    | rx_path_select0                |
|       |      |                    | Rx path select:                |
| 18:17 | RW   | 0x0                | 2'b00: path0 data from sdi0;   |
|       |      |                    | 2'b01: path0 data from sdi1;   |
|       |      |                    | 2'b10: path0 data from sdi2;o  |
|       |      |                    | 2'b11: path0 data from sdi3;   |

| Bit   | Attr | Reset Value | Description                                                       |
|-------|------|-------------|-------------------------------------------------------------------|
|       |      |             | RCSR                                                              |
|       |      |             | RX Channel select register                                        |
|       |      |             | 2'b00: two channel                                                |
| 16:15 | RW   | 0x0         | 2'b01: four channel                                               |
|       |      |             | 2'b10: six channel                                                |
|       |      |             | 2'b11: eight channel                                              |
|       |      |             | HWT                                                               |
|       |      |             | Halfword word transform                                           |
|       |      |             | (Can be written only when XFER[1] bit is 0.)                      |
| 14    | RW   | 0x0         | Only valid when VDW select 16bit data.                            |
| 14    | RW   | UXU         | 1'b0: 32 bit data valid to AHB/APB bus. Low 16 bit for left       |
|       |      |             | channel and high 16 bit for right channel.                        |
|       |      |             | 1'b1: low 16bit data valid to AHB/APB bus, high 16 bit data       |
|       |      |             | invalid.id.                                                       |
| 13    | RO   | 0x0         | reserved                                                          |
|       |      |             | SJM                                                               |
|       |      |             | Store justified mode                                              |
|       |      |             | (Can be written only when XFER[1] bit is 0.)                      |
|       |      | 0×0         | 16bit~31bit DATA stored in 32 bits width fifo.                    |
| 12    | RW   |             | If VDW select 16bit data, this bit is valid only when HWT select  |
|       |      |             | 0.Because if HWT is 1, every fifo unit contain two 16bit data and |
|       |      |             | 32 bit space is full, it is impossible to choose justified mode.  |
|       |      |             | 1'b0: right justified                                             |
|       |      |             | 1'b1: left justified                                              |
|       |      |             | FBM                                                               |
| 11    | RW   | 0.40        | First Bit Mode                                                    |
| 11    | RW   | 0x0         | (Can be written only when XFER[1] bit is 0.)<br>1'b0: MSB         |
|       |      |             | 1'b1: LSB                                                         |
|       |      |             | IBM                                                               |
|       |      |             | I2S bus mode                                                      |
|       |      |             | (Can be written only when XFER[1] bit is 0.)                      |
|       |      |             | 2'b00: I2S normal                                                 |
| 10:9  | RW   | 0x0         | 2'b01: I2S Left justified                                         |
|       |      |             | 2'b10: I2S Right justified                                        |
|       |      |             | 2'b11: reserved                                                   |
|       |      |             | Note: Only function when RX TFS[1:0] is 0;                        |
|       |      |             | PBM                                                               |
|       |      |             | PCM bus mode                                                      |
|       |      |             | (Can be written only when XFER[1] bit is 0.)                      |
| 8:7   | RW   | 0x0         | 2'b00: PCM no delay mode                                          |
| 0.7   |      |             | 2'b01: PCM delay 1 mode                                           |
|       |      |             | 2'b10: PCM delay 2 mode                                           |
|       |      |             | 2'b11: PCM delay 3 mode                                           |
|       |      |             | Note: Only function when RX TFS[1:0] is 1;                        |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                     |
|-----|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:5 | RW   | 0×0                | TFS<br>Transfer format select<br>(Can be written only when XFER[1] bit is 0.)<br>2'b00: I2S format<br>2'b01: PCM format<br>2'b10: TDM format 0 (PCM mode)<br>2'b11: TDM format 1 (I2S mode)                                                     |
| 4:0 | RW   | 0×0f               | VDW<br>Valid Data width<br>(Can be written only when XFER[1] bit is 0.)<br>5'b00000~5'b01110: reserved<br>5'b01111: 16bit<br>5'b10000: 17bit<br>5'b10001: 18bit<br>5'b10010: 19bit<br><br>5'b11100: 29bit<br>5'b11101: 30bit<br>5'b11111: 32bit |

# 12S 8CH CKR

Address: Operational Base + offset (0x0008)

| Bit   | Attr | <b>Reset Value</b> | Description                                                        |
|-------|------|--------------------|--------------------------------------------------------------------|
| 31:30 | RO   | 0x0                | reserved                                                           |
|       |      |                    | TRCM                                                               |
|       |      |                    | TX/RX LRCK as common                                               |
|       |      |                    | 2'b00/2'b11: tx_lrck/rx_lrck are used as synchronous signal for    |
|       |      |                    | TX /RX respectively.                                               |
|       |      |                    | 2'b01: only tx_lrck is used as synchronous signal for TX and RX.   |
|       |      |                    | 2'b10: only rx_lrck is used as synchronous signal for TX and RX.   |
|       |      |                    | Note: When set to 2'b01 or 2'b10 , if user wants to use both       |
| 29:28 | RW   | 0x0                | transmitting and receiving in master mode, user should configure   |
|       |      |                    | as following:                                                      |
|       |      |                    | a. mclk_rx and mclk_tx should source from same clock.              |
|       |      |                    | b. The value of TX_MDIV/RX MDIV should be same, The value of       |
|       |      |                    | TSD and RSD should be same.                                        |
|       |      |                    | c. Before start TX/RX transfer, user should assert mresetn_tx and  |
|       |      |                    | mresetn_rx, then clear them at the same time after a delay.        |
|       |      |                    | d. user should start TX transfer and RX transfer at the same time. |
|       |      |                    | MSS                                                                |
|       |      |                    | Master/slave mode select                                           |
| 27    | RW   | 0x0                | (Can be written only when XFER[1] or XFER[0] bit is 0.)            |
|       |      |                    | 1'b0: master mode(sclk output)                                     |
|       |      |                    | 1'b1: slave mode(sclk input)                                       |

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
|       |      |                    | СКР                                                               |
|       |      |                    | Sclk polarity                                                     |
| 26    | RW   | 0x0                | (Can be written only when XFER[1] or XFER[0] bit is 0.)           |
|       |      |                    | 1'b0: sample data at posedge sclk and drive data at negedge sclk  |
|       |      |                    | 1'b1: sample data at negedge sclk and drive data at posedge sclk  |
|       |      |                    | RLP                                                               |
|       |      |                    | Receive Irck polarity                                             |
|       |      |                    | (Can be written only when XFER[1] or XFER[0] bit is 0.)           |
|       |      |                    | 1'b0: normal polartiy                                             |
|       |      |                    | (I2S normal: low for left channel, high for right channel         |
| 25    | RW   | 0x0                | I2S left/right just: high for left channel, low for right channel |
|       |      |                    | PCM start signal:high valid)                                      |
|       |      |                    | 1'b1: oppsite polarity                                            |
|       |      |                    | (I2S normal: high for left channel, low for right channel         |
|       |      |                    | I2S left/right just: low for left channel, high for right channel |
|       |      |                    | PCM start signal:low valid)                                       |
|       |      |                    | TLP                                                               |
|       |      |                    | Transmit Irck polarity                                            |
|       |      |                    | (Can be written only when XFER[1] or XFER[0] bit is 0.)           |
|       |      |                    | 1'b0: normal polartiy                                             |
|       |      |                    | (I2S normal: low for left channel, high for right channel         |
| 24    | RW   | 0×0                | I2S left/right just: high for left channel, low for right channel |
|       |      |                    | PCM start signal:high valid)                                      |
|       |      |                    | 1'b1: oppsite polarity                                            |
|       |      |                    | (I2S normal: high for left channel, low for right channel         |
|       |      |                    | I2S left/right just: low for left channel, high for right channel |
|       |      |                    | PCM start signal:low valid)                                       |
| 23:16 | RO   | 0x0                | reserved                                                          |
|       |      |                    | RSD                                                               |
|       |      |                    | Receive sclk divider                                              |
|       |      |                    | (Can be written only when XFER[1] or XFER[0] bit is 0.)           |
| 15:8  | RW   | 0x1f               | 8'h00~8'h1e: reserved                                             |
|       |      |                    | 8'h1f~8'hff: frequency of sclk = $(RSD >> 1 + 1)*2*$ frequency of |
|       |      |                    | rx_lrck                                                           |
|       |      |                    | Note: function when RX TFS[1:0] is 0 or 1;                        |
|       |      |                    | TSD                                                               |
|       |      |                    | Transmit sclk divider                                             |
|       |      |                    | (Can be written only when XFER[1] or XFER[0] bit is 0.)           |
| 7:0   | RW   | 0x1f               | 8'h00~8'h1e: reserved                                             |
|       |      |                    | 8'h1f~8'hff: frequency of sclk = $(TSD >> 1 + 1)*2*$ frequency of |
|       |      |                    | tx_lrck                                                           |
|       |      |                    | Note: function when TX TFS[1:0] is 0 or 1;                        |

# I2S\_8CH\_TXFIFOLR

Address: Operational Base + offset (0x000c)

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

| Bit   | Attr | <b>Reset Value</b> | Description                                                      |
|-------|------|--------------------|------------------------------------------------------------------|
| 31:24 | RO   | 0x0                | reserved                                                         |
|       |      |                    | TFL3                                                             |
| 23:18 | RW   | 0x00               | Transmit FIFO3 Level                                             |
|       |      |                    | Contains the number of valid data entries in the transmit FIFO3. |
|       |      |                    | TFL2                                                             |
| 17:12 | RW   | 0x00               | Transmit FIFO2 Level                                             |
|       |      |                    | Contains the number of valid data entries in the transmit FIFO2. |
|       |      |                    | TFL1                                                             |
| 11:6  | RW   | 0x00               | Transmit FIFO1 Level                                             |
|       |      |                    | Contains the number of valid data entries in the transmit FIFO1. |
|       |      |                    | TFLO                                                             |
| 5:0   | RO   | 0x00               | Transmit FIFO0 Level                                             |
|       |      |                    | Contains the number of valid data entries in the transmit FIFO0. |

# I2S\_8CH\_DMACR

Address: Operational Base + offset (0x0010)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 24    | RW   | 0×0                | RDE<br>Receive DMA Enable<br>1'b0 : Receive DMA disabled<br>1'b1 : Receive DMA enabled                                                                                                                                                                                                                                                                                                  |
| 23:21 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 20:16 | RW   | 0x1f               | RDL<br>Receive Data Level<br>This bit field controls the level at which a DMA request is made by<br>the receive logic. The watermark level = DMARDL+1; that is,<br>dma_rx_req is generated when the number of valid data entries<br>in the receive FIFO is equal to or above this field value + 1.                                                                                      |
| 15:9  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 8     | RW   | 0×0                | TDE<br>Transmit DMA Enable<br>1'b0 : Transmit DMA disabled<br>1'b1 : Transmit DMA enabled                                                                                                                                                                                                                                                                                               |
| 7:5   | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 4:0   | RW   | 0x00               | TDL<br>Transmit Data Level<br>This bit field controls the level at which a DMA request is made by<br>the transmit logic. It is equal to the watermark level; that is, the<br>dma_tx_req signal is generated when the number of valid data<br>entries in the TXFIFO(TXFIFO0 if CSR=00;TXFIFO1 if<br>CSR=01,TXFIFO2 if CSR=10,TXFIFO3 if CSR=11)is equal to or<br>below this field value. |

# **12S 8CH INTCR**

Address: Operational Base + offset (0x0014)

| Bit   |     | <b>Reset Value</b> | Description                                                          |
|-------|-----|--------------------|----------------------------------------------------------------------|
| 31:25 | RO  | 0x0                | reserved                                                             |
|       |     |                    | RFT                                                                  |
| 24.20 |     | 0.15               | Receive FIFO Threshold                                               |
| 24:20 | RW  | 0x1f               | When the number of receive FIFO entries is more than or equal to     |
|       |     |                    | this threshold plus 1, the receive FIFO full interrupt is triggered. |
| 19    | RO  | 0x0                | reserved                                                             |
|       |     |                    | RXOIC                                                                |
| 18    | WO  | 0x0                | RX overrun interrupt clear                                           |
|       |     |                    | Write 1 to clear RX overrun interrupt.                               |
|       |     |                    | RXOIE                                                                |
| 17    | RW  | 0x0                | RX overrun interrupt enable                                          |
| 17    |     | 0.00               | 1'b0: disable                                                        |
|       |     |                    | 1'b1: enable                                                         |
|       |     |                    | RXFIE                                                                |
| 16    | RW  | 0×0                | RX full interrupt enable                                             |
| 10    | RVV |                    | 1'b0: disable                                                        |
|       |     |                    | 1'b1: enable                                                         |
| 15:9  | RO  | 0x0                | reserved                                                             |
|       |     |                    | TFT                                                                  |
|       |     |                    | Transmit FIFO Threshold                                              |
| 8:4   | RW  | 0x00               | When the number of transmit FIFO (TXFIFO0 if CSR=00; TXFIFO1         |
| •••   |     |                    | if CSR=01, TXFIFO2 if CSR=10, TXFIFO3 if CSR=11) entries is          |
|       |     |                    | less than or equal to this threshold, the transmit FIFO empty        |
|       |     |                    | interrupt is triggered.                                              |
| 3     | RO  | 0x0                | reserved                                                             |
|       |     |                    | TXUIC                                                                |
| 2     | WO  | 0x0                | TX underrun interrupt clear                                          |
|       |     |                    | Write 1 to clear TX underrun interrupt.                              |
|       |     |                    | TXUIE                                                                |
| 1     | RW  | 0x0                | TX underrun interrupt enable                                         |
|       |     |                    | 1'b0: disable                                                        |
|       |     |                    | 1'b1: enable                                                         |
|       |     |                    | TXEIE                                                                |
| 0     | RW  | 0×0                | TX empty interrupt enable                                            |
|       |     |                    | 1'b0: disable                                                        |
|       |     |                    | 1'b1: enable                                                         |

## I2S 8CH INTSR

Address: Operational Base + offset (0x0018)

| Bit   | Attr | <b>Reset Value</b> | Description           |
|-------|------|--------------------|-----------------------|
| 31:18 | RO   | 0x0                | reserved              |
|       |      |                    | RXOI                  |
| 17    |      | 0.40               | RX overrun interrupt  |
| 17    | RO   | 0x0                | 1'b0: inactive        |
|       |      |                    | 1'b1: active          |
|       |      |                    | RXFI                  |
| 16    |      | 0x0                | RX full interrupt     |
| 10    | RO   |                    | 1'b0: inactive        |
|       |      |                    | 1'b1: active          |
| 15:2  | RO   | 0x0                | reserved              |
|       |      |                    | TXUI                  |
| 1     | RO   | 0x0                | TX underrun interrupt |
| T     | RU   | UXU                | 1'b0: inactive        |
|       |      |                    | 1'b1: active          |
|       |      |                    | TXEI                  |
| 0     | RO   | 0×0                | TX empty interrupt    |
| U     | κυ   | RO 0x0             | 1'b0: inactive        |
|       |      |                    | 1'b1: active          |

## I2S\_8CH\_XFER

Address: Operational Base + offset (0x001c)

| Bit  | Attr | <b>Reset Value</b> | Description             |
|------|------|--------------------|-------------------------|
| 31:2 | RO   | 0x0                | reserved                |
|      |      |                    | RXS                     |
| 4    |      | 0.40               | RX Transfer start bit   |
| L    | RW   | 0x0                | 1'b0: stop RX transfer. |
|      |      |                    | 1'b1: start RX transfer |
|      |      | RW 0x0             | TXS                     |
| 0    |      |                    | TX Transfer start bit   |
| 0    | ĸw   |                    | 1'b0: stop TX transfer. |
|      |      |                    | 1'b1: start TX transfer |

**I2S 8CH CLR** Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |
|------|------|--------------------|-----------------------------------------------------------------|
| 31:2 | RO   | 0x0                | reserved                                                        |
|      |      |                    | RXC                                                             |
| 1    | RW   | 0x0                | RX logic clear                                                  |
|      |      |                    | This is a self cleard bit. Write 1 to clear all receive logic.  |
|      |      |                    | TXC                                                             |
| 0    | RW   | 0x0                | TX logic clear                                                  |
|      |      |                    | This is a self cleard bit. Write 1 to clear all transmit logic. |

# I2S 8CH TXDR

#### Address: Operational Base + offset (0x0024)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
|      |      |                    | TXDR                                                          |
| 31:0 | WO   | 0x00000000         | Transimt FIFO Data Register.                                  |
|      |      |                    | When it is written to, data are moved into the transmit FIFO. |

#### I2S\_8CH\_RXDR

Address: Operational Base + offset (0x0028)

| Bit  | Attr | <b>Reset Value</b> | Description                                                      |
|------|------|--------------------|------------------------------------------------------------------|
|      |      |                    | RXDR                                                             |
| 31:0 | RO   | 0x00000000         | Receive FIFO data register.                                      |
|      |      |                    | When the register is read, data in the receive FIFO is accessed. |

#### **12S 8CH RXFIFOLR**

Address: Operational Base + offset (0x002c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
| 31:24 | RO   | 0x0                | reserved                                                        |
|       |      |                    | RFL3                                                            |
| 23:18 | RW   | 0x00               | Receive FIFO3 Level.                                            |
|       |      |                    | Contains the number of valid data entries in the Receive FIFO3. |
|       |      |                    | RFL2                                                            |
| 17:12 | RW   | 0x00               | Receive FIFO2 Level.                                            |
|       |      |                    | Contains the number of valid data entries in the Receive FIFO2. |
|       |      |                    | RFL1                                                            |
| 11:6  | RW   | 0x00               | Receive FIFO1 Level .                                           |
|       |      |                    | Contains the number of valid data entries in the Receive FIFO1. |
|       |      |                    | RFLO                                                            |
| 5:0   | RW   | 0x00               | Receive FIFO0 Level.                                            |
|       |      |                    | Contains the number of valid data entries in the Receive FIFO0. |

# 12S 8CH TDM TXCTRL

Address: Operational Base + offset (0x0030)

| Bit   | Attr | <b>Reset Value</b> | Description                                          |
|-------|------|--------------------|------------------------------------------------------|
| 31:21 | RO   | 0x0                | reserved                                             |
|       |      |                    | TX_TDM_FSYNC_WIDTH_SEL1                              |
|       |      |                    | Tx TDM FSYNC width selection, working at TDM format. |
|       |      |                    | (Can be written only when XFER[0] is 0.)             |
|       |      |                    | 3'b000: single period of the ASP_CLK.                |
| 20:18 | RW   | 0x0                | 3'b001: 2 period of the ASP_CLK.                     |
|       |      |                    | n: n+1 period of the ASP_CLK.                        |
|       |      |                    | 3'b110: 7 period of the ASP_CLK.                     |
|       |      |                    | 3'b111: the width is equivalent to a channel block   |
|       |      |                    | Note: function when TX TFS[1:0] is 2 or 3;           |

| Bit   | Attr | Reset Value | Description                                                             |
|-------|------|-------------|-------------------------------------------------------------------------|
|       |      |             | TX_TDM_FSYNC_WIDTH_SEL0                                                 |
|       |      |             | I2S tx TDM FSYNC width selection, working at TDM format.                |
| 17    |      | 00          | (Can be written only when XFER[0] is 0.)                                |
| 17    | RW   | 0x0         | 1'b0: 1/2 frame width. Aspc_ctrl1[8:0] should be set to an even         |
|       |      |             | number                                                                  |
|       |      |             | 1'b1: frame width                                                       |
|       |      |             | TDM_TX_SHIFT_CTRL                                                       |
|       |      |             | TDM tx shift control. Working at TDM mode.                              |
|       |      |             | (Can be written only when XFER[0] is 0.)                                |
|       |      |             | 3'b000:                                                                 |
|       |      |             | PCM format: normal mode, sample data on the third rising edge           |
|       |      |             | of TDM_CLK after rising edge of ASPC_FSYNC.                             |
|       |      |             | I2S format: normal mode                                                 |
|       |      |             | 3'b001:                                                                 |
|       |      |             | PCM format: 1/2 cycle shift left, sample data on second falling         |
|       |      |             | rising edge of TDM_CLK after rising edge of ASPC_FSYNC.                 |
|       |      |             | I2S format: left justified mode                                         |
|       |      |             | 3'b010:                                                                 |
| 16:14 | RW   | 0x0         | PCM format: 1 cycle shift left, sample data on second rising edge       |
|       |      |             | of TDM_CLK after rising edge of ASPC_FSYNC.                             |
|       |      |             | I2S format: right justified mode                                        |
|       |      |             | 3'b011:                                                                 |
|       |      |             | PCM format: 3/2 cycle shift left, sample data on first falling edge     |
|       |      |             | of TDM_CLK after rising edge of ASPC_FSYNC.                             |
|       |      |             | I2S format: not support                                                 |
|       |      |             | 3'b100:                                                                 |
|       |      |             | PCM format: 2 cycle shift left, sample data on first rising edge of     |
|       |      |             | TDM_CLK after rising edge of ASPC_FSYNC.                                |
|       |      |             | I2S format: not support                                                 |
|       |      |             | 3'b101~3'b111 not support<br>Note: function when TX TFS[1:0] is 2 or 3; |
|       |      |             | TDM_TX_SLOT_BIT_WIDTH                                                   |
|       |      |             | TDM tx slot bit width. Working at TDM mode.                             |
|       |      |             | (Can be written only when XFER[0] is 0.)                                |
|       |      |             | 0~14:reserved                                                           |
|       |      |             | 15:16bit                                                                |
|       |      |             | 16:17bit                                                                |
| 13:9  | RW   | 0x1f        | 17:18bit                                                                |
|       |      | UXII        | 18:19bit                                                                |
|       |      |             |                                                                         |
|       |      |             | n:(n+1)bit                                                              |
|       |      |             |                                                                         |
|       |      |             | 31:32bit                                                                |
|       |      |             | Note: function when TX TFS[1:0] is 2 or 3;                              |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                     |
|-----|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0 | RW   | 0×0ff              | TDM_TX_FRAME_WIDTH<br>TDM tx frame width. Working at TDM mode.<br>(Can be written only when XFER[0] is 0.)<br>0~30:reserved<br>31:32bit<br>32:33bit<br>33:34bit<br>34:35bit<br><br>n:(n+1)bit<br><br>511:512bit<br>Note: functional when TX TFS[1:0] is 2 or 3; |

# 12S\_8CH\_TDM\_RXCTRL

Address: Operational Base + offset (0x0034)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
| 31:21 | RO   | 0x0                | reserved                                                     |
|       |      |                    | RX_TDM_FSYNC_WIDTH_SEL1                                      |
|       |      |                    | Tx TDM FSYNC width selection, working at TDM format.         |
|       |      |                    | (Can be written only when XFER[0] is 0.)                     |
|       |      |                    | 3'b000: single period of the ASP_CLK.                        |
| 20:18 | RW   | 0x0                | 3'b001: 2 period of the ASP_CLK.                             |
|       |      |                    | n: n+1 period of the ASP_CLK.                                |
|       |      |                    | 3'b110: 7 period of the ASP_CLK.                             |
|       |      |                    | 3'b111: the width is equivalent to a channel block           |
|       |      |                    | Note: function when RX TFS[1:0] is 2 or 3;                   |
|       |      | $N = (0 \times 0)$ | RX_TDM_FSYNC_WIDTH_SEL0                                      |
|       |      |                    | I2S rx TDM FSYNC width selection, working at TDM format.     |
| 17    |      |                    | (Can be written only when XFER[0] is 0.)                     |
| 17    | RW   |                    | 0: 1/2 frame width. Aspc_ctrl1[8:0] should be set to an even |
|       |      |                    | number                                                       |
|       |      |                    | 1: frame width                                               |

| Bit   | Attr | Reset Value | Description                                                            |
|-------|------|-------------|------------------------------------------------------------------------|
|       |      |             | TDM_RX_SHIFT_CTRL                                                      |
|       |      |             | TDM rx shift control. Working at TDM mode.                             |
|       |      |             | (Can be written only when XFER[0] is 0.)                               |
|       |      |             | 3'b000:                                                                |
|       |      |             | PCM format: normal mode, sample data on the third rising edge          |
|       |      |             | of TDM_CLK after rising edge of ASPC_FSYNC.                            |
|       |      |             | I2S format: normal mode                                                |
|       |      |             | 3'b001:                                                                |
|       |      |             | PCM format: 1/2 cycle shift left, sample data on second falling        |
|       |      |             | rising edge of TDM_CLK after rising edge of ASPC_FSYNC.                |
|       |      |             | I2S format: left justified mode                                        |
|       |      |             | 3'b010:                                                                |
| 16:14 | RW   | 0x0         | PCM format: 1 cycle shift left, sample data on second rising edge      |
|       |      |             | of TDM_CLK after rising edge of ASPC_FSYNC.                            |
|       |      |             | I2S format: right justified mode                                       |
|       |      |             | 3'b011:                                                                |
|       |      |             | PCM format: 3/2 cycle shift left, sample data on first falling edge    |
|       |      |             | of TDM_CLK after rising edge of ASPC_FSYNC.<br>I2S format: not support |
|       |      |             | 3'b100:                                                                |
|       |      |             | PCM format: 2 cycle shift left, sample data on first rising edge of    |
|       |      |             | TDM_CLK after rising edge of ASPC_FSYNC.                               |
|       |      |             | I2S format: not support                                                |
|       |      |             | 3'b101~3'b111 not support                                              |
|       |      |             | Note: function when RX TFS[1:0] is 2 or 3;                             |
|       |      |             | TDM_RX_SLOT_BIT_WIDTH                                                  |
|       |      |             | TDM rx slot bit width. Working at TDM mode.                            |
|       |      |             | (Can be written only when XFER[0] is 0.)                               |
|       |      |             | 0~14:reserved                                                          |
|       |      |             | 15:16bit                                                               |
|       |      |             | 16:17bit                                                               |
| 13:9  | RW   | 0x1f        | 17:18bit                                                               |
|       |      |             | 18:19bit                                                               |
|       |      |             |                                                                        |
|       |      |             | n:(n+1)bit                                                             |
|       |      |             | <br>21.225:                                                            |
|       |      |             | 31:32bit                                                               |
|       |      |             | Note: function when RX TFS[1:0] is 2 or 3;                             |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                     |  |  |  |  |
|-----|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 8:0 | RW   | 0×0ff              | TDM_RX_FRAME_WIDTH<br>TDM rx frame width. Working at TDM mode.<br>(Can be written only when XFER[0] is 0.)<br>0~30:reserved<br>31:32bit<br>32:33bit<br>33:34bit<br>34:35bit<br><br>n:(n+1)bit<br><br>511:512bit<br>Note: functional when RX TFS[1:0] is 2 or 3; |  |  |  |  |

# I2S\_8CH\_CLKDIV

Address: Operational Base + offset (0x0038)

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                        |
|       |      |                    | RX_MDIV                                                         |
|       |      |                    | Mclk rx divider                                                 |
|       |      |                    | (Can be written only XFER[0] bit is 0.)                         |
|       |      |                    | Serial Clock Divider = Fmclk / Ftxsclk-1.(mclkfrequecy / txsclk |
|       |      |                    | frequecy-1)                                                     |
|       |      |                    | 0 :Fmclk=Ftxsclk;                                               |
|       |      |                    | 1 :Fmclk=2*Ftxsclk;                                             |
|       |      |                    | 2,3 :Fmclk=4*Ftxsclk;                                           |
| 15:8  | RW   | 0x07               | 4,5 :Fmclk=6*Ftxsclk;                                           |
|       |      |                    |                                                                 |
|       |      |                    | 2n,2n+1:Fmclk=(2n+2)*Ftxsclk;                                   |
|       |      |                    |                                                                 |
|       |      |                    | 60,61:Fmclk=62*Ftxsclk;                                         |
|       |      |                    | 62,63:Fmclk=64*Ftxsclk;                                         |
|       |      |                    |                                                                 |
|       |      |                    | 252,253:Fmclk=254*Ftxsclk;                                      |
|       |      |                    | 254,255:Fmclk=256*Ftxsclk;                                      |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RW   | 0×07               | TX_MDIV<br>Mclk tx divider<br>(Can be written only when XFER[1] bit is 0.)<br>Serial Clock Divider = Fmclk / Ftxsclk-1.(mclkfrequecy / txsclk<br>frequecy-1)<br>0 :Fmclk=Ftxsclk;<br>1 :Fmclk=2*Ftxsclk;<br>2,3 :Fmclk=2*Ftxsclk;<br>4,5 :Fmclk=6*Ftxsclk;<br>4,5 :Fmclk=6*Ftxsclk;<br><br>2n,2n+1:Fmclk=(2n+2)*Ftxsclk;<br><br>60,61:Fmclk=62*Ftxsclk;<br>62,63:Fmclk=64*Ftxsclk;<br><br>252,253:Fmclk=254*Ftxsclk;<br>254,255:Fmclk=256*Ftxsclk; |

# **I2S\_8CH\_VERSION**

Address: Operational Base + offset (0x003c)

| Bit  | Attr     | <b>Reset Value</b> | Description |
|------|----------|--------------------|-------------|
| 31:0 | PO       | 0x20150001         | I2S_VERSION |
| 51.0 | .:0 RO 0 |                    | i2s_version |

## **12S 8CH INCR RXDR**

Address: Operational Base + offset (0x0800)

| Bit  | Attr | <b>Reset Value</b> | Description                                                      |  |  |  |  |  |
|------|------|--------------------|------------------------------------------------------------------|--|--|--|--|--|
|      |      | 0x00000000         | INCR_RXDR                                                        |  |  |  |  |  |
| 31:0 | RO   |                    | Increment address receive FIFO data register.                    |  |  |  |  |  |
| 51.0 | ĸŬ   |                    | When the register is read, data in the receive FIFO is accessed. |  |  |  |  |  |
|      |      |                    | This register is used when the access address is Increment.      |  |  |  |  |  |

# **19.5 Interface Description**

Table 19-1 I2S Interface Description

| Module Pin       | Direc<br>tion | Pin Name                                       | IOMUX Setting                     |
|------------------|---------------|------------------------------------------------|-----------------------------------|
| i2s0_8ch_mclk    | I/O           | GPIO2_A4/I2S0_8CH_MCLK/PDM_8CH_<br>CLK_M_M2    | GRF_GPIO2A_IOMUX[9:8]=2'b01       |
| i2s0_8ch_sclk_tx | I/O           | GPIO2_A5/I2S0_8CH_SCLK_TX                      | GRF_GPIO2A_IOMUX[11:10]=2'b<br>01 |
| i2s0_8ch_sclk_rx | I/O           | GPIO2_A6/I2S0_8CH_SCLK_RX/PDM_8<br>CH_CLK_S_M2 | GRF_GPIO2A_IOMUX[13:12]=2'b<br>01 |
| i2s0_8ch_lrck_tx | I/O           | GPIO2_A7/I2S0_8CH_LRCK_TX                      | GRF_GPIO2A_IOMUX[15:14]=2'b<br>01 |
| i2s0_8ch_lrck_rx | I/O           | GPIO2_B0/I2S0_8CH_LRCK_RX                      | GRF_GPIO2B_IOMUX[1:0]=2'b01       |
| i2s0_8ch_sdo0    | 0             | GPIO2_B1/I2S0_8CH_SDO0                         | GRF_GPIO2B_IOMUX[3:2]=2'b01       |
| i2s0_8ch_sdo1    | 0             | GPIO2_B2/I2S0_8CH_SDO1                         | GRF_GPIO2B_IOMUX[5:4]=2'b01       |
| i2s0_8ch_sdo2    | 0             | GPIO2_B3/I2S0_8CH_SDO2                         | GRF_GPIO2B_IOMUX[7:6]=2'b01       |
| i2s0_8ch_sdo3    | 0             | GPIO2_B4/I2S0_8CH_SDO3                         | GRF_GPIO2B_IOMUX[9:8]=2'b01       |

| Module Pin       | Direc    | Pin Name                                           | IOMUX Setting                                             |
|------------------|----------|----------------------------------------------------|-----------------------------------------------------------|
|                  | tion     |                                                    |                                                           |
| i2s0_8ch_sdi0    | I        | GPIO2_B5/I2S0_8CH_SDI0/PDM_8CH_S<br>DI0_M2         | GRF_GPIO2B_IOMUX[11:10]=2'b<br>01                         |
| i2s0_8ch_sdi1    | I        | GPIO2_B6/I2S0_8CH_SDI1/PDM_8CH_S<br>DI1_M2         | GRF_GPIO2B_IOMUX[13:12]=2'b<br>01                         |
| i2s0_8ch_sdi2    | I        | GPIO2_B7/I2S0_8CH_SDI2/PDM_8CH_S<br>DI2_M2         | GRF_GPIO2B_IOMUX[15:14]=2'b<br>01                         |
| i2s0_8ch_sdi3    | I        | GPIO2_C0/I2S0_8CH_SDI3/PDM_8CH_<br>SDI3 M2         | GRF_GPIO2C_IOMUX[1:0]=2'b01                               |
| i2s1_8ch_mclk    | I/O      | GPIO1_A2/LCDC_VSYNC/I2S1_8CH_MC<br>LK_M0           | GRF_GPIO1A_IOMUX[5:4]=2'b10<br>GRF_SOC_CON2[3]=1'b0       |
|                  |          | GPIO1_B4/LCDC_D8/I2S1_8CH_MCLK_<br>M1/MAC_CLK      | GRF_GPI01B_IOMUX_L[9:8]=2'b<br>10<br>GRF_SOC_CON2[3]=1'b1 |
| i2s1_8ch_sclk_tx | I/O      | GPIO1_A3/LCDC_DEN/I2S1_8CH_SCLK_                   | GRF_GPI01A_IOMUX[7:6]=2'b10                               |
|                  | 1/0      | TX M0                                              | GRF_GPI0IA_IOM0x[7:0]=2 D10<br>GRF_SOC_CON2[3]=1'b0       |
|                  |          | GPIO1 B5/LCDC D9/I2S1 8CH SCLK T                   | GRF_GPI01B_IOMUX_L[11:10]=                                |
|                  |          | X_M1/MAC_MDC                                       | 2′b10<br>GRF_SOC_CON2[3]=1′b1                             |
| i2s1_8ch_sclk_rx | I/O      | GPIO1_A4/LCDC_D0/I2S1_8CH_SCLK_R                   | GRF_GPIO1A_IOMUX[9:8]=2'b10                               |
|                  | -, -     | X_M0/PDM_8CH_CLK_M0                                | GRF_SOC_CON2[3]=1'b0                                      |
|                  |          | GPIO1 B6/LCDC D10/I2S1 8CH SCLK                    | GRF_GPIO1B_IOMUX_L[15:12]=                                |
|                  |          | RX_M1/PDM_8CH_CLK_M1/MAC_MDIO                      | 4′b10                                                     |
|                  |          |                                                    | GRF_SOC_CON2[3]=1'b1                                      |
| i2s1_8ch_lrck_tx | I/O      | GPIO1_A5/LCDC_D1/I2S1_8CH_LRCK_T                   | GRF_GPIO1A_IOMUX[11:10]=2'b                               |
|                  |          | X_M0                                               | 10                                                        |
|                  |          |                                                    | GRF_SOC_CON2[3]=1'b0                                      |
|                  |          | GPIO1_B7/LCDC_D11/I2S1_8CH_LRCK_<br>TX_M1/MAC_RXER | GRF_GPIO1B_IOMUX_H[1:1]=2'b<br>10                         |
|                  |          |                                                    | GRF_SOC_CON2[3]=1'b1                                      |
| i2s1_8ch_lrck_rx | I/O      | GPIO1_A6/LCDC_D2/I2S1_8CH_LRCK_R                   | GRF_GPIO1A_IOMUX[13:12]=2′b                               |
|                  | -, -     | X_M0                                               | 10                                                        |
|                  |          |                                                    | GRF_SOC_CON2[3]=1'b0                                      |
|                  |          | GPIO1_C0/LCDC_D12/I2S1_8CH_LRCK_                   | GRF_GPIO1C_IOMUX_L[1:0]=2'b                               |
|                  |          | RX_M1/MAC_RXDV                                     | 10                                                        |
| i2s1 8ch sdo0    | <u> </u> |                                                    | GRF_SOC_CON2[3]=1′b1                                      |
| 1251_801_5000    | 0        | GPIO1_A7/LCDC_D3/I2S1_8CH_SDO0_<br>M0              | GRF_GPIO1A_IOMUX[15:14]=2'b<br>10                         |
|                  |          |                                                    | GRF_SOC_CON2[3]=1'b0                                      |
|                  |          | GPIO1_C1/LCDC_D13/I2S1_8CH_SD00                    | GRF_GPIO1C_IOMUX_L[3:2]=2'b                               |
|                  |          | _M1/MAC_TXEN                                       | 10                                                        |
|                  |          |                                                    | GRF_SOC_CON2[3]=1'b1                                      |
| i2s1_8ch_sdo1/s  | I/O      | GPIO1_B0/LCDC_D4/I2S1_8CH_SDO1_                    | GRF_GPIO1B_IOMUX_L[1:0]=2'b                               |
| di3              |          | SDI3_M0/PDM_8CH_SDI3_M0                            |                                                           |
|                  |          | GPIO1_C2/LCDC_D14/I2S1_8CH_SDO1                    | GRF_SOC_CON2[3]=1'b0<br>GRF GPIO1C IOMUX L[7:4]=4'b       |
|                  |          | _SDI3_M1/PDM_8CH_SDI3_M1/MAC_TX                    | 10                                                        |
|                  |          | D0                                                 | GRF SOC CON2[3]=1'b1                                      |
| i2s1_8ch_sdo2/s  | I/O      | GPIO1 B1/LCDC D5/I2S1 8CH SDO2                     | GRF GPIO1B IOMUX L[3:2]=2'b                               |
| di2              |          | SDI2_M0/PDM_8CH_SDI2_M0                            | 10                                                        |
|                  |          |                                                    | GRF_SOC_CON2[3]=1'b0                                      |
|                  |          | GPIO1_C3/LCDC_D15/I2S1_8CH_SDO2                    | GRF_GPIO1C_IOMUX_L[11:8]=4'                               |
|                  |          | _SDI2_M1/PDM_8CH_SDI2_M1/MAC_TX                    | b10                                                       |
| i2s1_8ch_sdo3/s  | I/O      | D1<br>GPIO1_B2/LCDC_D6/I2S1_8CH_SDO3_              | GRF_SOC_CON2[3]=1'b1<br>GRF_GPIO1B_IOMUX_L[5:4]=2'b       |
| di1              | 1/0      | SDI1_M0/PDM_8CH_SDI1_M0                            | GRF_GPIOIB_IOMOX_L[5:4]=2 D                               |
|                  |          |                                                    | GRF_SOC_CON2[3]=1'b0                                      |
|                  |          | GPIO1_C4/LCDC_D16/I2S1_8CH_SDO3                    | GRF_GPIO1C_IOMUX_L[15:12]=                                |
|                  |          | _SDI1_M1/PDM_8CH_SDI1_M1/MAC_R                     | 4′b10                                                     |
|                  |          | XD0                                                | GRF_SOC_CON2[3]=1'b1                                      |
| i2s1_8ch_sdi0    | Ι        | GPIO1_B3/LCDC_D7/I2S1_8CH_SDI0_M                   | GRF_GPIO1B_IOMUX_L[7:6]=2'b                               |
|                  |          | 0/PDM_8CH_SDI0_M0                                  | 10<br>CDF_COC_CON3[3]_1/b0                                |
|                  |          |                                                    | GRF_SOC_CON2[3]=1'b0                                      |

| Module Pin                                                                                                                                                                                                                                                                                                                       | Direc<br>tion                                                                                           | Pin Name                                                                                     | IOMUX Setting                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                  |                                                                                                         | GPIO1_C5/LCDC_D17/I2S1_8CH_SDI0_<br>M1/PDM_8CH_SDI0_M1/MAC_RXD1                              | GRF_GPIO1C_IOMUX_H[3:0]=4'b<br>10                                         |
|                                                                                                                                                                                                                                                                                                                                  |                                                                                                         |                                                                                              | GRF_SOC_CON2[3]=1'b1                                                      |
| 2. The direction of it<br>when GRF_SOC_CO<br>GRF_SOC_CON2[10<br>1'b1: input<br>1'b0: output<br>3. The direction of it<br>when GRF_SOC_CO<br>GRF_SOC_CON2[10<br>1'b1: input<br>1'b0: output<br>4. The direction of it<br>1'b1: sdo1 output<br>1'b0: sdi3 input<br>5. The direction of it<br>1'b1: sdo2 output<br>1'b0: sdi2 input | 2s0_8ch_<br>N2[10] is<br>0] is set to<br>2s1_8ch_<br>N2[2] is s<br>0] is set to<br>2s1_8ch_<br>2s1_8ch_ | mclk is controlled by CRU register, it's cont<br>set to 1'b0, it's controlled by CRU_CLKGATE | TE_CON13[5] when trolled by CRU_CLKGATE_CON13[6] E_CON13[7] when [5] [6]: |

# **19.6 Application Notes**



Fig. 19-11 I2S/PCM/TDM controller transmit operation flow chart



Fig. 19-12 I2S/PCM/TDM controller receive operation flow chart

*Note:* User should clear TX/RX logical by CLR[0]/CLR[1] and wait clear operation done before configure the other registers.

There are 3 operation modes which are normal mode, TX common mode and RX common mode. Following shows the normal mode connections, <u>I2S\_CKR[29:28]</u> should be set to 2'b00.



Fig. 19-13 I2S/PCM normal mode

For TX common mode, only IO\_LRCK\_TX is used and <u>I2S\_CKR</u>[29:28] should be set to 2'b01. TX/RX should work at the same time and at the same sample rate.



Fig. 19-14 I2S/PCM TX common mode

For RX common mode, only IP\_LRCK\_RX is used and <u>I2S\_CKR[29:28]</u> should be set to 2'b10. TX/RX should work at the same time and at the same sample rate.



Fig. 19-15 I2S/PCM RX common mode

# Chapter 20 Serial Peripheral Interface (SPI)

# 20.1 Overview

The serial peripheral interface is an APB slave device. A four wire full duplex serial protocol from Motorola. There are four possible combinations for the serial clock phase and polarity. The clock phase (SCPH) determines whether the serial transfer begins with the falling edge of slave select signals or the first edge of the serial clock. The slave select line is held high when the SPI is idle or disabled. This SPI controller can work as either master or slave mode.

SPI Controller supports the following features:

- Support Motorola SPI,TI Synchronous Serial Protocol and National Semiconductor Micro wire interface
- Support 32-bit APB bus
- Support two internal 16-bit wide and 32-location deep FIFOs, one for transmitting and the other for receiving serial data
- Support two chip select signals in master mode
- Support 4,8,16 bit serial data transfer
- Support configurable interrupt polarity
- Support asynchronous APB bus and SPI clock
- Support master and slave mode
- Support DMA handshake interface and configurable DMA water level
- Support transmit FIFO empty, underflow, receive FIFO full, overflow, interrupt and all interrupts can be masked
- Support configurable water level of transmit FIFO empty and receive FIFO full interrupt
- Support combine interrupt output
- Support up to half of SPI clock frequency transfer in master mode and one sixth of SPI clock frequency transfer in slave mode
- Support full and half duplex mode transfer
- Stop transmitting SCLK if transmit FIFO is empty or receive FIFO is full in master mode
- Support configurable delay from chip select active to SCLK active in master mode
- Support configurable period of chip select inactive between two parallel data in master mode
- Support big and little endian, MSB and LSB first transfer
- Support two 8-bit audio data store together in one 16-bit wide location
- Support sample RXD 0~3 SPI clock cycles later
- Support configurable SCLK polarity and phase
- Support fix and incremental address access to transmit and receive FIFO

# 20.2 Block Diagram

The SPI Controller comprises with:

- AMBA APB interface and DMA Controller Interface
- Transmit and receive FIFO controllers and an FSM controller
- Register block
- Shift control and interrupt



Fig. 20-1 SPI Controller Block diagram

## **APB INTERFACE**

The host processor accesses data, control, and status information on the SPI through the APB interface. The SPI supports APB data bus widths of 32 bits and 8 or 16 bits when reading or writing internal FIFO if data frame size(SPI\_CTRL0[1:0]) is set to 8 bits.

## DMA INTERFACE

This block has a handshaking interface to a DMA Controller to request and control transfers. The APB bus is used to perform the data transfer to or from the DMA Controller.

## **FIFO LOGIC**

For transmit and receive transfers, data transmitted from the SPI to the external serial device is written into the transmit FIFO. Data received from the external serial device into the SPI is pushed into the receive FIFO. Both fifos are 32x16bits.

#### **FSM CONTROL**

Control the state's transformation of the design.

#### **REGISTER BLOCK**

All registers in the SPI are addressed at 32-bit boundaries to remain consistent with the APB bus. Where the physical size of any register is less than 32-bits wide, the upper unused bits of the 32-bit boundary are reserved. Writing to these bits has no effect; reading from these bits returns 0.

#### SHIFT CONTROL

Shift control logic shift the data from the transmit fifo or to the receive fifo. This logic automatically right-justifies receive data in the receive FIFO buffer.

#### **INTERRUPT CONTROL**

The SPI supports combined and individual interrupt requests, each of which can be masked. The combined interrupt request is the ORed result of all other SPI interrupts after masking.

# **20.3 Function Description**



Fig. 20-2 SPI Master and Slave Interconnection

The SPI controller support dynamic switching between master and slave in a system. The diagram show how the SPI controller connects with other SPI devices.

#### **Operation Modes**

The SPI can be configured in the following two fundamental modes of operation: Master Mode when SPI\_CTRLR0 [20] is 1'b0, Slave Mode when SPI\_CTRLR0 [20] is 1'b1.

## **Transfer Modes**

The SPI operates in the following three modes when transferring data on the serial bus. 1). Transmit and Receive

When SPI\_CTRLR0 [19:18]== 2'b00, both transmit and receive logic are valid. 2).Transmit Only

When SPI\_CTRLR0 [19:18] == 2'b01, the receive data are invalid and should not be stored in the receive FIFO.

3).Receive Only

When SPI\_CTRLR0 [19:18]== 2'b10, the transmit data are invalid.

# **Clock Ratios**

A summary of the frequency ratio restrictions between the bit-rate clock (sclk\_out/sclk\_in) and the SPI peripheral clock (spi\_clk) are described as,

When SPI Controller works as master, the  $F_{spi\_clk} >= 2 \times (maximum F_{sclk\_out})$ When SPI Controller works as slave, the  $F_{spi\_clk} >= 6 \times (maximum F_{sclk\_in})$ 

With the SPI, the clock polarity (SCPOL) configuration parameter determines whether the inactive state of the serial clock is high or low. To transmit data, both SPI peripherals must have identical serial clock phase (SCPH) and clock polarity (SCPOL) values. The data frame can be 4/8/16 bits in length.

When the configuration parameter SCPH = 0, data transmission begins on the falling edge of the slave select signal. The first data bit is captured by the master and slave peripherals on the first edge of the serial clock; therefore, valid data must be present on the txd and rxd lines prior to the first serial clock edge. The following two figures show a timing diagram for a single SPI data transfer with SCPH = 0. The serial clock is shown for configuration parameters SCPOL = 0 and SCPOL = 1.



Fig. 20-3 SPI Format (SCPH=0 SCPOL=0)



#### Fig. 20-4 SPI Format (SCPH=0 SCPOL=1)

When the configuration parameter SCPH = 1, both master and slave peripherals begin transmitting data on the first serial clock edge after the slave select line is activated. The first data bit is captured on the second (trailing) serial clock edge. Data are propagated by the master and slave peripherals on the leading edge of the serial clock. During continuous data frame transfers, the slave select line may be held active-low until the last bit of the last frame has been captured. The following two figures show the timing diagram for the SPI format when the configuration parameter SCPH = 1.



Fig. 20-6 SPI Format (SCPH=1 SCPOL=1)

# **20.4 Register Description**

## 20.4.1 Registers Summary

| Name              | Offset | Size | Reset<br>Value | Description                   |
|-------------------|--------|------|----------------|-------------------------------|
| <u>SPI CTRLR0</u> | 0x0000 | W    | 0x0000002      | Control Register 0            |
| SPI_CTRLR1        | 0x0004 | W    | 0x00000000     | Control Register 1            |
| <u>SPI ENR</u>    | 0x0008 | W    | 0x00000000     | SPI Enable Register           |
| <u>SPI SER</u>    | 0x000c | W    | 0x00000000     | Slave Enable Register         |
| SPI BAUDR         | 0x0010 | W    | 0x00000000     | Baud Rate Select              |
| <u>SPI TXFTLR</u> | 0x0014 | W    | 0x00000000     | Transmit FIFO Threshold Level |
| <u>SPI_RXFTLR</u> | 0x0018 | W    | 0x00000000     | Receive FIFO Threshold Level  |
| <u>SPI TXFLR</u>  | 0x001c | W    | 0x00000000     | Transmit FIFO Level           |
| SPI RXFLR         | 0x0020 | W    | 0x00000000     | Receive FIFO Level            |
| <u>SPI SR</u>     | 0x0024 | W    | 0x000000c      | SPI Status                    |
| <u>SPI IPR</u>    | 0x0028 | W    | 0x00000000     | Interrupt Polarity            |
| <u>SPI_IMR</u>    | 0x002c | W    | 0x00000000     | Interrupt Mask                |
| <u>SPI ISR</u>    | 0x0030 | W    | 0x0000000      | Interrupt Status              |

| Name            | Offset | Size | Reset<br>Value | Description             |
|-----------------|--------|------|----------------|-------------------------|
| <u>SPI_RISR</u> | 0x0034 | W    | 0x0000001      | Raw Interrupt Status    |
| SPI ICR         | 0x0038 | W    | 0x00000000     | Interrupt Clear         |
| SPI DMACR       | 0x003c | W    | 0x00000000     | DMA Control             |
| SPI DMATDLR     | 0x0040 | W    | 0x00000000     | DMA Transmit Data Level |
| SPI DMARDLR     | 0x0044 | W    | 0x00000000     | DMA Receive Data Level  |
| SPI_TXDR        | 0x0400 | W    | 0x00000000     | Transmit FIFO Data      |
| <u>SPI RXDR</u> | 0x0800 | W    | 0x00000000     | Receive FIFO Data       |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# 20.4.2 Detail Register Description

#### SPI\_CTRLR0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                  |
| 21    | RW   | 0×0                | MTM<br>Valid when frame format is set to National Semiconductors<br>Microwire.<br>1'b0: non-sequential transfer<br>1'b1: sequential transfer                                                                                                                                                                                                                                                              |
| 20    | RW   | 0×0                | OPM<br>1'b0: Master Mode<br>1'b1: Slave Mode                                                                                                                                                                                                                                                                                                                                                              |
| 19:18 | RW   | 0x0                | XFM<br>2'b00: Transmit & Receive<br>2'b01: Transmit Only<br>2'b10: Receive Only<br>2'b11: Reserved                                                                                                                                                                                                                                                                                                        |
| 17:16 | RW   | 0x0                | FRF<br>2'b00: Motorola SPI<br>2'b01: Texas Instruments SSP<br>2'b10: National Semiconductors Microwire<br>2'b11: reserved                                                                                                                                                                                                                                                                                 |
| 15:14 | RW   | 0×0                | RSD<br>When SPI is configured as a master, if the rxd data cannot be<br>sampled by the sclk_out edge at the right time, this register<br>should be configured to define the number of the spi_clk cycles<br>after the active sclk_out edge to sample rxd data later when SPI<br>works at high frequency.<br>2'b00: do not delay<br>2'b01: 1 cycle delay<br>2'b10: 2 cycles delay<br>2'b11: 3 cycles delay |

| Bit | Bit Attr Reset Value |     | Description                                                       |
|-----|----------------------|-----|-------------------------------------------------------------------|
|     |                      |     | BHT                                                               |
| 10  | D14/                 |     | Valid when data frame size is 8bit.                               |
| 13  | RW                   | 0x0 | 1'b0: apb 16bit write/read, spi 8bit write/read                   |
|     |                      |     | 1'b1: apb 8bit write/read, spi 8bit write/read                    |
|     |                      |     | FBM                                                               |
| 12  | RW                   | 0x0 | 1'b0: first bit is MSB                                            |
|     |                      |     | 1'b1: first bit is LSB                                            |
|     |                      |     | EM                                                                |
|     |                      |     | Serial endian mode can be configured by this bit. Apb endian      |
| 11  | RW                   | 0x0 | mode is always little endian.                                     |
|     |                      |     | 1'b0: little endian                                               |
|     |                      |     | 1'b1: big endian                                                  |
|     |                      |     | SSD                                                               |
|     |                      | 0×0 | Valid when the frame format is set to Motorola SPI and SPI used   |
|     |                      |     | as a master.                                                      |
| 10  | RW                   |     | 1'b0: the period between ss_n active and sclk_out active is half  |
|     |                      |     | sclk_out cycles.                                                  |
|     |                      |     | 1'b1: the period between ss_n active and sclk_out active is one   |
|     |                      |     | sclk_out cycle.                                                   |
|     |                      |     | CSM                                                               |
|     |                      |     | Valid when the frame format is set to Motorola SPI and SPI used   |
|     |                      |     | as a master.                                                      |
|     |                      | 0×0 | 2'b00: ss_n keep low after every frame data is transferred.       |
| 9:8 | RW                   |     | 2'b01: ss_n be high for half sclk_out cycles after every frame    |
|     |                      |     | data is transferred.                                              |
|     |                      |     | 2'b10: ss_n be high for one sclk_out cycle after every frame data |
|     |                      |     | is transferred.                                                   |
|     |                      |     | 2'b11: reserved                                                   |
|     |                      |     | SCPOL                                                             |
| 7   | RW                   | 0x0 | Valid when the frame format is set to Motorola SPI.               |
|     |                      | -   | 1'b0: inactive state of serial clock is low                       |
|     |                      |     | 1'b1: inactive state of serial clock is high                      |
|     |                      |     | SCPH                                                              |
| 6   | RW                   | 0x0 | Valid when the frame format is set to Motorola SPI.               |
| -   |                      |     | 1'b0: serial clock toggles in middle of first data bit            |
|     |                      |     | 1'b1: serial clock toggles at start of first data bit             |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:2 | RW   | 0×0                | CFS<br>Selects the length of the control word for the Microwire frame<br>format.<br>4'b0000~0010: reserved<br>4'b0011: 4-bit serial data transfer<br>4'b0100: 5-bit serial data transfer<br>4'b0101: 6-bit serial data transfer<br>4'b0110: 7-bit serial data transfer<br>4'b0111: 8-bit serial data transfer<br>4'b1001: 9-bit serial data transfer<br>4'b1001: 10-bit serial data transfer<br>4'b1001: 10-bit serial data transfer<br>4'b1011: 12-bit serial data transfer<br>4'b1011: 12-bit serial data transfer<br>4'b1101: 13-bit serial data transfer<br>4'b1101: 14-bit serial data transfer<br>4'b1101: 14-bit serial data transfer<br>4'b1101: 15-bit serial data transfer<br>4'b1111: 16-bit serial data transfer |
| 1:0 | RW   | 0x2                | DFS<br>Selects the data frame length.<br>2'b00: 4bit data<br>2'b01: 8bit data<br>2'b10: 16bit data<br>2'b11: reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

## SPI\_CTRLR1

Address: Operational Base + offset (0x0004)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                               |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                  |
| 15:0  | RW   | 0×0000             | NDM<br>When Transfer Mode is receive only, this register field sets the<br>number of data frames to be continuously received by the SPI.<br>The SPI continues to receive serial data until the number of data<br>frames received is equal to this register value plus 1, which<br>enables you to receive up to 64 KB of data in a continuous<br>transfer. |

## <u>SPI\_ENR</u>

Address: Operational Base + offset (0x0008)

| Bit  | Attr | <b>Reset Value</b> | Description                                                      |
|------|------|--------------------|------------------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                         |
|      |      | W 0×0              | ENR                                                              |
| 0    | RW   |                    | Enables and disables all SPI operations.                         |
| 0    |      |                    | Transmit and receive FIFO buffers are cleared when the device is |
|      |      |                    | disabled.                                                        |

#### <u>SPI SER</u>

Address: Operational Base + offset (0x000c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
| 31:2 | RO   | 0x0                | reserved                                                       |
|      |      |                    | SER                                                            |
| 1:0  | RW   | 0x0                | This register is valid only when SPI is configured as a master |
|      |      |                    | device.                                                        |

## SPI BAUDR

Address: Operational Base + offset (0x0010)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:0  | RW   | 0×0000             | BAUDR<br>SPI Clock Divider.<br>This register is valid only when the SPI is configured as a master<br>device.<br>The LSB for this field is always set to 0 and is unaffected by a<br>write operation, which ensures an even value is held in this<br>register.<br>If the value is 0, the serial output clock (sclk_out) is disabled.<br>The frequency of the sclk_out is derived from the following<br>equation:<br>Fsclk_out = Fspi_clk/ SCKDV<br>Where SCKDV is any even value between 2 and 65534.<br>For example:<br>for Fspi_clk = 3.6864MHz and SCKDV =2 |
|       |      |                    | $Fsclk_out = 3.6864/2 = 1.8432MHz$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

# SPI\_TXFTLR

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description                                                       |
|------|------|--------------------|-------------------------------------------------------------------|
| 31:5 | RO   | 0x0                | reserved                                                          |
|      |      |                    | TXFTLR                                                            |
| 4:0  | RW   | 0x00               | When the number of transmit FIFO entries is less than or equal to |
|      |      |                    | this value, the transmit FIFO empty interrupt is triggered.       |

## SPI\_RXFTLR

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                       |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x0                | reserved                                                                                                                          |
|      |      |                    | RXFTLR                                                                                                                            |
| 4:0  | RW   |                    | When the number of receive FIFO entries is greater than or equal to this value + 1, the receive FIFO full interrupt is triggered. |

# SPI\_TXFLR

Address: Operational Base + offset (0x001c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                     |
|------|------|--------------------|-----------------------------------------------------------------|
| 31:6 | RO   | 0x0                | reserved                                                        |
| E.0  | RO   | 0x00               | TXFLR                                                           |
| 5:0  |      |                    | Contains the number of valid data entries in the transmit FIFO. |

#### SPI\_RXFLR

Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
| 31:6 | RO   | 0x0                | reserved                                                       |
| 5:0  | RO   | 0x00               | RXFLR                                                          |
| 5:0  |      |                    | Contains the number of valid data entries in the receive FIFO. |

#### <u>SPI\_SR</u>

Address: Operational Base + offset (0x0024)

| Bit  | Attr | Reset Value | Description                                                     |
|------|------|-------------|-----------------------------------------------------------------|
| 31:5 | RO   | 0x0         | reserved                                                        |
|      |      |             | RFF                                                             |
| 4    | RO   | 0x0         | 1'b0: Receive FIFO is not full                                  |
|      |      |             | 1'b1: Receive FIFO is full                                      |
|      |      |             | RFE                                                             |
| 3    | RO   | 0x1         | 1'b0: Receive FIFO is not empty                                 |
|      |      |             | 1'b1: Receive FIFO is empty                                     |
|      |      |             | TFE                                                             |
| 2    | RO   | 0x1         | 1'b0: Transmit FIFO is not empty                                |
|      |      |             | 1'b1: Transmit FIFO is empty                                    |
|      |      |             | TFF                                                             |
| 1    | RO   | 0x0         | 1'b0: Transmit FIFO is not full                                 |
|      |      |             | 1'b1: Transmit FIFO is full                                     |
|      |      |             | BSF                                                             |
|      |      |             | When set, indicates that a serial transfer is in progress; when |
| 0    | RO   | 0x0         | cleared indicates that the SPI is idle or disabled.             |
|      |      |             | 1'b0: SPI is idle or disabled                                   |
|      |      |             | 1'b1: SPI is actively transferring data                         |

#### <u>SPI\_IPR</u>

Address: Operational Base + offset (0x0028)

| 31:1       RO       0x0       reserved         0       RW       0x0       IPR<br>Interrupt Polarity Register<br>1'b0: Active Interrupt Polarity Level is HIGH | Bit  | Attr | <b>Reset Value</b> | Description                                                                                   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------------------|-----------------------------------------------------------------------------------------------|
| 0 RW 0x0 Interrupt Polarity Register<br>1'b0: Active Interrupt Polarity Level is HIGH                                                                         | 31:1 | RO   | 0x0                | reserved                                                                                      |
| 0 RW 0x0 1'b0: Active Interrupt Polarity Level is HIGH                                                                                                        |      |      | 0x0                |                                                                                               |
|                                                                                                                                                               | 0    | RW   |                    |                                                                                               |
|                                                                                                                                                               |      |      |                    | 1'b0: Active Interrupt Polarity Level is HIGH<br>1'b1: Active Interrupt Polarity Level is LOW |

# <u>SPI\_IMR</u>

Address: Operational Base + offset (0x002c)

| Bit  | Attr | <b>Reset Value</b> | Description                                |
|------|------|--------------------|--------------------------------------------|
| 31:5 | RO   | 0x0                | reserved                                   |
|      |      |                    | RFFIM                                      |
| 4    | RW   | 0x0                | 1'b0: spi_rxf_intr interrupt is masked     |
|      |      |                    | 1'b1: spi_rxf_intr interrupt is not masked |
|      |      |                    | RFOIM                                      |
| 3    | RW   | 0x0                | 1'b0: spi_rxo_intr interrupt is masked     |
|      |      |                    | 1'b1: spi_rxo_intr interrupt is not masked |
|      |      |                    | RFUIM                                      |
| 2    | RW   | 0x0                | 1'b0: spi_rxu_intr interrupt is masked     |
|      |      |                    | 1'b1: spi_rxu_intr interrupt is not masked |
|      |      |                    | TFOIM                                      |
| 1    | RW   | 0x0                | 1'b0: spi_txo_intr interrupt is masked     |
|      |      |                    | 1'b1: spi_txo_intr interrupt is not masked |
|      |      |                    | TFEIM                                      |
| 0    | RW   | 0x0                | 1'b0: spi_txe_intr interrupt is masked     |
|      |      |                    | 1'b1: spi_txe_intr interrupt is not masked |

#### <u>SPI\_ISR</u>

Address: Operational Base + offset (0x0030)

| Bit                          | Attr  | <b>Reset Value</b> | Description                                              |  |
|------------------------------|-------|--------------------|----------------------------------------------------------|--|
| 31:5                         | RO    | 0x0                | reserved                                                 |  |
|                              | RFFIS |                    |                                                          |  |
| 4                            | RO    | 0x0                | 1'b0: spi_rxf_intr interrupt is not active after masking |  |
|                              |       |                    | 1'b1: spi_rxf_intr interrupt is full after masking       |  |
|                              |       |                    | RFOIS                                                    |  |
| 3                            | RO    | 0x0                | 1'b0: spi_rxo_intr interrupt is not active after masking |  |
| 1'b1: spi_rxo_intr interrupt |       |                    | 1'b1: spi_rxo_intr interrupt is active after masking     |  |
|                              |       |                    | RFUIS                                                    |  |
| 2                            | RO    | 0x0                | 1'b0: spi_rxu_intr interrupt is not active after masking |  |
|                              |       |                    | 1'b1: spi_rxu_intr interrupt is active after masking     |  |
| TFOIS                        |       | TFOIS              |                                                          |  |
| 1                            | RO    | 0x0                | 1'b0: spi_txo_intr interrupt is not active after masking |  |
|                              |       |                    | 1'b1: spi_txo_intr interrupt is active after masking     |  |
| TFEIS                        |       |                    |                                                          |  |
| 0                            | RO    | 0x0                | 1'b0: spi_txe_intr interrupt is not active after masking |  |
|                              |       |                    | 1'b1: spi_txe_intr interrupt is active after masking     |  |

#### <u>SPI\_RISR</u>

Address: Operational Base + offset (0x0034)

| Bit  | Attr | <b>Reset Value</b> | Description |
|------|------|--------------------|-------------|
| 31:5 | RO   | 0x0                | reserved    |

| Bit | Attr                                                         | <b>Reset Value</b> | Description                                                 |
|-----|--------------------------------------------------------------|--------------------|-------------------------------------------------------------|
|     |                                                              |                    | RFFRIS                                                      |
| 4   | RO 0x0 1'b0: spi_rxf_intr interrupt is not active prior to n |                    | 1'b0: spi_rxf_intr interrupt is not active prior to masking |
|     |                                                              |                    | 1'b1: spi_rxf_intr interrupt is full prior to masking       |
|     |                                                              |                    | RFORIS                                                      |
| 3   | RO                                                           | 0x0                | 1'b0: spi_rxo_intr interrupt is not active prior to masking |
|     |                                                              |                    | 1'b1: spi_rxo_intr interrupt is active prior to masking     |
|     |                                                              |                    | RFURIS                                                      |
| 2   | RO                                                           | 0x0                | 1'b0: spi_rxu_intr interrupt is not active prior to masking |
|     |                                                              |                    | 1'b1: spi_rxu_intr interrupt is active prior to masking     |
|     | TFORIS                                                       |                    | TFORIS                                                      |
| 1   | RO                                                           | 0x0                | 1'b0: spi_txo_intr interrupt is not active prior to masking |
|     |                                                              |                    | 1'b1: spi_txo_intr interrupt is active prior to masking     |
|     |                                                              |                    | TFERIS                                                      |
| 0   | RO                                                           | 0x1                | 1'b0: spi_txe_intr interrupt is not active prior to masking |
|     |                                                              |                    | 1'b1: spi_txe_intr interrupt is active prior to masking     |

#### SPI ICR

Address: Operational Base + offset (0x0038)

| Bit  | Attr | <b>Reset Value</b> | Description                                       |  |
|------|------|--------------------|---------------------------------------------------|--|
| 31:4 | RO   | 0x0                | reserved                                          |  |
| 3    | W1   | 0x0                | CTFOI                                             |  |
| 3    | С    | 0.00               | Write 1 to Clear Transmit FIFO Overflow Interrupt |  |
| n    | W1   | 0x0                | CRFOI                                             |  |
| Z    | С    |                    | Write 1 to Clear Receive FIFO Overflow Interrupt  |  |
| 4    | W1   | 0.40               | CRFUI                                             |  |
| L    | С    | 0x0                | Write 1 to Clear Receive FIFO Underflow Interrupt |  |
| 0    | W1   | 0.20               | CCI                                               |  |
| 0    | С    | 0x0                | Write 1 to Clear Combined Interrupt               |  |

## SPI DMACR

Address: Operational Base + offset (0x003c)

| Bit  | Attr | Reset Value | Description                 |  |
|------|------|-------------|-----------------------------|--|
| 31:2 | RO   | 0x0         | reserved                    |  |
|      |      |             | TDE                         |  |
| 1    | RW   |             | 1'b0: Transmit DMA disabled |  |
|      |      |             | 1'b1: Transmit DMA enabled  |  |
|      | RW   | W 0x0       | RDE                         |  |
| 0    |      |             | 1'b0: Receive DMA disabled  |  |
|      |      |             | 1'b1: Receive DMA enabled   |  |

#### SPI\_DMATDLR

Address: Operational Base + offset (0x0040)

| Bit  | Attr | <b>Reset Value</b> | Description |
|------|------|--------------------|-------------|
| 31:5 | RO   | 0x0                | reserved    |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                               |  |
|-----|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 4:0 |      |                    | TDL<br>This bit field controls the level at which a DMA request is made by<br>the transmit logic. It is equal to the watermark level; that is, the<br>dma_tx_req signal is generated when the number of valid data<br>entries in the transmit FIFO is equal to or below this field value, |  |
|     |      |                    | and Transmit DMA Enable $(DMACR[1]) = 1$ .                                                                                                                                                                                                                                                |  |

#### SPI\_DMARDLR

Address: Operational Base + offset (0x0044)

| Bit  | Attr | <b>Reset Value</b> | Description                                                         |  |
|------|------|--------------------|---------------------------------------------------------------------|--|
| 31:5 | RO   | 0x0                | reserved                                                            |  |
|      | RW   | 0x00               | RDL                                                                 |  |
|      |      |                    | This bit field controls the level at which a DMA request is made by |  |
| 4:0  |      |                    | the receive logic. The watermark level = DMARDL+1; that is,         |  |
| 4.0  |      |                    | dma_rx_req is generated when the number of valid data entries       |  |
|      |      |                    | in the receive FIFO is equal to or above this field value + 1, and  |  |
|      |      |                    | Receive DMA Enable(DMACR[0])=1.                                     |  |

#### <u>SPI\_TXDR</u>

Address: Operational Base + offset (0x0400)

| Bit   | Attr        | <b>Reset Value</b> | Description                                                   |  |
|-------|-------------|--------------------|---------------------------------------------------------------|--|
| 31:16 | RO          | 0x0                | reserved                                                      |  |
| 15:0  | 0 WO 0x0000 |                    | TXDR                                                          |  |
|       |             | CACCOCC            | When it is written to, data are moved into the transmit FIFO. |  |

#### SPI RXDR

Address: Operational Base + offset (0x0800)

| Bit   | Attr | <b>Reset Value</b> | Description                                                              |  |
|-------|------|--------------------|--------------------------------------------------------------------------|--|
| 31:16 | RO   | 0x0                | reserved                                                                 |  |
| 15:0  | RW   | 0x0000             | RXDR<br>When the register is read, data in the receive FIFO is accessed. |  |

# **20.5 Interface Description**

| Module Pin | Direction | Pin Name                    | IOMUX Setting                 |
|------------|-----------|-----------------------------|-------------------------------|
| spi0 clk   | I/O       | GPIO2_A2/UART0_CTSN/SPI0_CL | GRF_GPIO2A_IOMUX[5:4]=2'b10   |
| spi0_clk   |           | K/I2C2_SDA                  | GRF_GP102A_10M0A[5:4]=2 010   |
| cni0 mico  | I         | GPIO2_A0/UART0_RX/SPI0_MISO | SPI Slave mode:               |
| spi0_miso  |           |                             | GRF_GPIO2A_IOMUX[1:0]=2'b10   |
| cni0 moci  | 0         | GPIO2_A1/UART0_TX/SPI0_MOSI | SPI Master mode:              |
| spi0_mosi  |           |                             | GRF_GPIO2A_IOMUX[3:2]=2'b10   |
| cni0 ccn0  | I/O       | GPIO2_A3/UART0_RTSN/SPI0_CS | CDE CDIO2A IOMUV[7:6] - 2/b10 |
| spi0_csn0  |           | N0/I2C2_SCL                 | GRF_GPIO2A_IOMUX[7:6]=2'b10   |

Table 20-1 1SPI interface description

| Module Pin | Direction | Pin Name                                               | IOMUX Setting                                            |
|------------|-----------|--------------------------------------------------------|----------------------------------------------------------|
| spi1_clk   | I/O       | GPIO3_B3/FLASH_ALE/EMMC_PW<br>REN/SPI1_CLK             | GRF_GPIO3B_IOMUX[7:6]=2'b11                              |
| spi1_miso  | I         | GPIO3_B2/FLASH_RDN/SPI1_MIS<br>O                       | SPI Slave mode:<br>GRF_GPIO3B_IOMUX[5:4]=2'b11           |
| spi1_mosi  | 0         | GPIO3_B4/FLASH_RDY/I2C3_SDA<br>_M1/SPI1_MOSI/UART3_RX  | SPI Master mode:<br>GRF_GPIO3B_IOMUX[11:8]=4'b0<br>011   |
| spi1_csn0  | 0         | GPIO3_B5/FLASH_CSN0/I2C3_SC<br>L_M1/SPI1_CSN0/UART3_TX | GRF_GPIO3B_IOMUX[15:12]=4'b<br>0011                      |
| spi2_clk   | I/O       | GPIO1_D0/UART1_RX/I2C0_SDA/<br>SPI2_CLK                | GRF_GPIO1D_IOMUX[1:0]=2'b11                              |
| spi2_miso  | Ι         | GPIO1_C6/UART1_CTSN/UART2_<br>RX_M0/SPI2_MISO/JTAG_TCK | SPI Slave mode:<br>GRF_GPIO1C_IOMUX_H[7:4]=4'b<br>0011   |
| spi2_mosi  | 0         | GPIO1_C7/UART1_RTSN/UART2_T<br>X_M0/SPI2_MOSI/JTAG_TMS | SPI Master mode:<br>GRF_GPIO1C_IOMUX_H[11:8]=4'<br>b0011 |
| spi2_csn0  | 0         | GPIO1_D1/UART1_TX/I2C0_SCL/<br>SPI2_CSN0               | GRF_GPIO1D_IOMUX[3:2]=2'b11                              |

Notes: I=input, O=output, I/O=input/output, bidirectional. spi\_csn1 can only be used in master mode

# **20.6 Application Notes**

## **Clock Ratios**

A summary of the frequency ratio restrictions between the bit-rate clock (sclk\_out/sclk\_in) and the SPI peripheral clock (spi\_clk) are described as,

When SPI Controller works as master, the Fspi\_clk>=  $2 \times (\text{maximum Fsclk}_out)$ When SPI Controller works as slave, the Fspi\_clk>=  $6 \times (\text{maximum Fsclk}_in)$ 

## **Master Transfer Flow**

When configured as a serial-master device, the SPI initiates and controls all serial transfers. The serial bit-rate clock, generated and controlled by the SPI, is driven out on the sclk\_out line. When the SPI is disabled (SPI\_ENR = 0), no serial transfers can occur and sclk\_out is held in "inactive" state, as defined by the serial protocol under which it operates.

## **Slave Transfer Flow**

When the SPI is configured as a slave device, all serial transfers are initiated and controlled by the serial bus master.

When the SPI serial slave is selected during configuration, it enables its txd data onto the serial bus. All data transfers to and from the serial slave are regulated on the serial clock line (sclk\_in), driven from the serial-master device. Data are propagated from the serial slave on one edge of the serial clock line and sampled on the opposite edge.



Fig. 20-7 SPI Master transfer flow diagram



Fig. 20-8 SPI Slave transfer flow diagram

# Chapter 21 Serial Flash Controller (SFC)

# 21.1 Overview

The serial flash controller (SFC) is used to control the data transfer between the chip system and the serial NOR/NAND flash device.

The SFC supports the following features:

- Support AHB slave interface to configure register and read/write serial flash
- Support AHB master interface to transfer data from/to SPI flash device
- Support AHB burst with INCR4 x32bits, or INCR x32bits
- Support two independent clock domain: AHB clock and SPI clock
- Support x1, x2, x4 data bits mode
- Support up to 1 chip selections
- Support interrupt output, interrupt maskable

# 21.2 Block Diagram





# **21.3 Function Description**

## 21.3.1 SFC AHB slave

The AHB slave is used to configure the register, and also write to/read from the serial NOR/NAND flash device.

The SFC\_CTRL register is a global control register, when the controller is in busy state (SFC\_SR), SFC\_CTRL cannot be set. The field sclk\_idle\_level\_cycles(SFC\_CTRL[7:4]) of this register are used to configure the idle level cycles of SFC core clock (sfc\_sclk) before reading the first bit of the read command.

Like the following picture shows: the red line of the sclk is the idle cycles, during these cycles, the chip pad is switched to output. When sclk\_idle\_level\_cycles=0, it means there will be not such idle level.



# **21.4 Register Description**

## 21.4.1 Registers Summary

| Name            | Offset | Size | Reset<br>Value | Description                                |
|-----------------|--------|------|----------------|--------------------------------------------|
| SFC CTRL        | 0x0000 | W    | 0x00000000     | Control Register                           |
| <u>SFC_IMR</u>  | 0x0004 | W    | 0x00000000     | Interrupt Mask                             |
| <u>SFC ICLR</u> | 0x0008 | W    | 0x00000000     | Interrupt Clear                            |
| <u>SFC_FTLR</u> | 0x000c | W    | 0x00000000     | FIFO Threshold Level                       |
| <u>SFC_RCVR</u> | 0x0010 | W    | 0x00000000     | SFC Recover                                |
| <u>SFC AX</u>   | 0x0014 | W    | 0x00000000     | SFC AX Value                               |
| <u>SFC ABIT</u> | 0x0018 | W    | 0x00000000     | Flash Address bits                         |
| <u>SFC_ISR</u>  | 0x001c | W    | 0x00000000     | Interrupt Status                           |
| SFC FSR         | 0x0020 | W    | 0x0000001      | FIFO Status                                |
| <u>SFC_SR</u>   | 0x0024 | W    | 0x00000000     | SFC Status                                 |
| SFC RISR        | 0x0028 | W    | 0x00000000     | Raw Interrupt Status                       |
| <u>SFC_VER</u>  | 0x002c | W    | 0x0a340003     | Version Register                           |
| SFC_QOP         | 0x0030 | W    | 0x00000000     | Quad line operation io level preset        |
| SFC DMATR       | 0x0080 | W    | 0x00000000     | DMA Trigger                                |
| SFC_DMAADDR     | 0x0084 | W    | 0x00000000     | DMA Address                                |
| SFC_CMD         | 0x0100 | W    | 0x00000000     | SFC CMD                                    |
| <u>SFC ADDR</u> | 0x0104 | W    | 0x00000000     | Address of data to read or write.          |
| <u>SFC_DATA</u> | 0x0108 | W    | 0x00000000     | DATA that write to or read from the flash. |

Notes: Size: B- Byte (8 bits) access, HW- Half WORD (16 bits) access, W-WORD (32 bits) access

## 21.4.2 Detail Register Description

#### SFC CTRL

Address: Operational Base + offset (0x0000)

| Bit   | Attr | <b>Reset Value</b> |          | Description |
|-------|------|--------------------|----------|-------------|
| 31:14 | RO   | 0x0                | reserved |             |

| Bit   | Attr | <b>Reset Value</b> | Description                                                         |
|-------|------|--------------------|---------------------------------------------------------------------|
|       |      |                    | DATB                                                                |
|       |      |                    | Data line width.                                                    |
| 13:12 |      | 0x0                | 2'b00: 1bit, x1 mode                                                |
| 13.12 | K VV | UXU                | 2'b01: 2bits, x2 mode                                               |
|       |      |                    | 2'b10: 4bits, x4 mode                                               |
|       |      |                    | 2'b11: reserved                                                     |
|       |      |                    | ADRB                                                                |
|       |      |                    | Address bits width.                                                 |
| 11:10 | DW   | 0x0                | 2'b00: 1bit, x1 mode                                                |
| 11.10 | L AA | 0.00               | 2'b01: 2bits, x2 mode                                               |
|       |      |                    | 2'b10: 4bits, x4 mode                                               |
|       |      |                    | 2'b11: reserved                                                     |
|       |      | 0x0                | СМДВ                                                                |
|       |      |                    | Command bits width.                                                 |
| 9:8   | RW   |                    | 2'b00: 1bit, x1 mode                                                |
| 9.0   |      |                    | 2'b01: 2bits, x2 mode                                               |
|       |      |                    | 2'b10: 4bits, x4 mode                                               |
|       |      |                    | 2'b11: reserved                                                     |
|       |      |                    | IDLE_CYCLE                                                          |
|       |      |                    | 4'd0: idle hold is disable                                          |
| 7:4   | RW   | N 0×0              | 4'd1: hold the sclk_out in idle for two cycles when switch to shift |
|       |      |                    | in                                                                  |
|       |      |                    |                                                                     |
| 3:2   | RO   | 0x0                | reserved                                                            |
|       |      |                    | SHIFTPHASE                                                          |
| 1     | RW   | 0x0                | 1'b0: shift in the data at posedge sclk_out                         |
|       |      |                    | 1'b1: shift in the data at negedge sclk_out                         |
|       |      |                    | SPIM                                                                |
| 0     | RW   | 0x0                | SPI MODE Select.                                                    |
|       |      |                    | 1'b0: mode 0                                                        |
|       |      |                    | 1'b1: mode 3                                                        |

# SFC IMR

Address: Operational Base + offset (0x0004)

| Bit  | Attr | <b>Reset Value</b> | Description                             |  |  |  |
|------|------|--------------------|-----------------------------------------|--|--|--|
| 31:8 | RO   | 0x0                | reserved                                |  |  |  |
|      |      |                    | DMAM                                    |  |  |  |
| -    |      | 0.40               | DMA finish interrupt mask               |  |  |  |
| /    | RW   | 0×0                | 1'b0: dma_intr interrupt is not masked  |  |  |  |
|      |      |                    | 1'b1: dma_intr interrupt is masked      |  |  |  |
|      |      |                    | NSPIM                                   |  |  |  |
| 6    |      | 0x0                | SPI error interrupt mask                |  |  |  |
| 6    | RW   |                    | 1'b0: nspi_intr interrupt is not masked |  |  |  |
|      |      |                    | 1'b1: nspi_intr interrupt is masked     |  |  |  |

| Bit | Attr | <b>Reset Value</b> | Description                               |
|-----|------|--------------------|-------------------------------------------|
|     |      |                    | АНВМ                                      |
| 5   | RW   | 0x0                | AHB error interrupt mask                  |
| 5   | RW   | UXU                | 1'b0: ahb_intr interrupt is not masked    |
|     |      |                    | 1'b1: ahb_intr interrupt is masked        |
|     |      |                    | TRANSM                                    |
| 4   | RW   | 0x0                | Transfer finish interrupt mask            |
| -   |      | 0.00               | 1'b0: transf_intr interrupt is not masked |
|     |      |                    | 1'b1: transf_intr interrupt is masked     |
|     |      |                    | ТХЕМ                                      |
| 3   | RW   | 0×0                | Transmit FIFO empty interrupt             |
| J   |      |                    | 1'b0: txe_intr interrupt is not masked    |
|     |      |                    | 1'b1: txe_intr interrupt is masked        |
|     |      |                    | ТХОМ                                      |
| 2   | RW   | V 0×0              | Transmit FIFO overflow interrupt mask     |
| 2   | 1    |                    | 1'b0: txo_intr interrupt is not masked    |
|     |      |                    | 1'b1: txo_intr interrupt is masked        |
|     |      |                    | RXUM                                      |
| 1   | RW   | 0x0                | Receive FIFO underflow interrupt mask     |
| T   | 1    | 0.00               | 1'b0: rxu_intr interrupt is not masked    |
|     |      |                    | 1'b1: rxu_intr interrupt is masked        |
|     |      |                    | RXFM                                      |
| 0   | RW   | 0x0                | Receive FIFO full interrupt mask          |
| U   |      |                    | 1'b0: rxf_intr interrupt is not masked    |
|     |      |                    | 1'b1: rxf_intr interrupt is masked        |

# <u>SFC\_ICLR</u>

Address: Operational Base + offset (0x0008)

| Bit  | Attr    | Reset Value | Description                             |
|------|---------|-------------|-----------------------------------------|
| 31:8 | RO      | 0x0         | reserved                                |
| 7    | W1C     | 0.40        | DMAC                                    |
| /    | WIC     | 0x0         | DMA finish Interrupt Clear.             |
| 6    |         |             | NSPIC                                   |
| 0    | W1C     | 0x0         | SPI Error Interrupt Clear.              |
| 5    | W1C     | 0x0         | АНВС                                    |
| 5    | WIC     | 0.00        | AHB Error Interrupt Clear.              |
| 4    | W1C     | 0.40        | TRANSC                                  |
| 4    | W1C 0x0 |             | Transfer finish Interrupt Clear.        |
| 3    | W1C     | 0.40        | TXEC                                    |
| 3    | WIC     | 0x0         | Transmit FIFO Empty Interrupt Clear.    |
| 2    | W1C     | 0x0         | ТХОС                                    |
| Z    | WIC     | UXU         | Transmit FIFO Overflow Interrupt Clear. |
| 1    | W1C     | 0.20        | RXUC                                    |
| 1    | W1C     | 0x0         | Receive FIFO Underflow Interrupt Clear. |

| Bit | Attr  | Reset Value | Description                        |
|-----|-------|-------------|------------------------------------|
| 0   | 0 W1C | 0x0         | RXFC                               |
| 0   | WIC   | 0.00        | Receive FIFO Full Interrupt Clear. |

#### SFC FTLR

Address: Operational Base + offset (0x000c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                          |
|       |      |                    | RXFTLR                                                            |
| 15:8  | RW   | 0x00               | When the number of receive FIFO entries is bigger than or equal   |
|       |      |                    | to this value, the receive FIFO full interrupt is triggered.      |
|       |      |                    | TXFTLR                                                            |
| 7:0   | RW   | 0x00               | When the number of transmit FIFO entries is less than or equal to |
|       |      |                    | this value, the transmit FIFO empty interrupt is triggered.       |

#### SFC RCVR

Address: Operational Base + offset (0x0010)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                       |
|      |      | SW 0x0             | RCVR                                                           |
|      |      |                    | SFC Recover.                                                   |
| 0    | RW   |                    | Write 1 to recover the SFC State Machine, FIFO state and other |
|      |      |                    | logic state.                                                   |

#### <u>SFC\_AX</u>

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description                                                 |
|------|------|--------------------|-------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                    |
|      |      |                    | AX                                                          |
| 7:0  | RW   | 0x00               | The AX Value when doing the continuous read (enhance mode). |
|      |      |                    | That is M7-M0 in "Continuous Read Mode".                    |

#### SFC ABIT

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description         |
|------|------|--------------------|---------------------|
| 31:5 | RO   | 0x0                | reserved            |
| 4:0  | RW   | / 0x00             | ABIT                |
| 4.0  | K VV | 0,000              | Flash Address bits. |

#### <u>SFC\_ISR</u>

Address: Operational Base + offset (0x001c)

| Bit  | Attr | <b>Reset Value</b> |          | Description |  |
|------|------|--------------------|----------|-------------|--|
| 31:8 | RO   | 0x0                | reserved |             |  |

| Bit | Attr | <b>Reset Value</b> | Description                              |
|-----|------|--------------------|------------------------------------------|
|     |      |                    | DMAS                                     |
| 7   | RO   | 00                 | DMA Finish Interrupt Status.             |
| /   | RU   | 0x0                | 1'b0: not active                         |
|     |      |                    | 1'b1: active                             |
|     |      |                    | NSPIS                                    |
| 6   | RO   | 0x0                | SPI Error Interrupt Status.              |
| 0   | RU   | 0.00               | 1'b0: not active                         |
|     |      |                    | 1'b1: active                             |
|     |      |                    | AHBS                                     |
| 5   | RO   | 0×0                | AHB Error Interrupt Status.              |
| 5   | RU   | 0.00               | 1'b0: not active                         |
|     |      |                    | 1'b1: active                             |
|     |      | 0x0                | TRANSS                                   |
| 4   | RO   |                    | Transfer finish Interrupt Status.        |
| 4   | RU   |                    | 1'b0: not active                         |
|     |      |                    | 1'b1: active                             |
|     |      |                    | TXES                                     |
| 3   | RO   | 0x0                | Transmit FIFO Empty Interrupt Status.    |
| 5   | KU   |                    | 1'b0: not active                         |
|     |      |                    | 1'b1: active                             |
|     |      |                    | TXOS                                     |
| 2   | RO   | 0x0                | Transmit FIFO Overflow Interrupt Status. |
|     |      |                    | 1'b1: active                             |
|     |      |                    | RXUS                                     |
| 1   | RO   | 0x0                | Receive FIFO Underflow Interrupt Status. |
| 1   | KU   | 0.00               | 1'b0: not active                         |
|     |      |                    | 1'b1: active                             |
|     |      |                    | RXFS                                     |
| 0   | RW   | 0x0                | Receive FIFO Full Interrupt Status.      |
|     |      | UXU                | 1'b0: not active                         |
|     |      |                    | 1'b1: active                             |

## <u>SFC\_FSR</u>

Address: Operational Base + offset (0x0020)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 31:21 | RO   | 0x0                | reserved                               |
|       |      |                    | RXWLVL                                 |
|       |      |                    | RX FIFO Water Level.                   |
| 20:16 |      |                    | 5'h0: FIFO is empty                    |
| 20.10 | r vv | 0x00               | 5'h1: 1 entry is taken                 |
|       |      |                    |                                        |
|       |      |                    | 5'h10: 16 entry is taken, FIFO is full |
| 15:13 | RO   | 0x0                | reserved                               |

| Bit  | Attr | Reset Value | Description                         |
|------|------|-------------|-------------------------------------|
|      |      |             | TXWLVL                              |
|      |      |             | TX FIFO Water Level.                |
| 12.0 |      | 0.400       | 5'h0: FIFO is full                  |
| 12:8 | RO   | 0x00        | 5'h1: left 1 entry                  |
|      |      |             |                                     |
|      |      |             | 5'h10: left 16 entry, FIFO is empty |
| 7:4  | RO   | 0x0         | reserved                            |
|      |      |             | RXFS                                |
| 3    | RO   | 0x0         | Receive FIFO Full Status.           |
| 5    | RU   | 0.00        | 1'b0: rx FIFO is not full           |
|      |      |             | 1'b1: rx FIFO is full               |
|      |      |             | RXES                                |
| 2    | RO   | 0x0         | Receive FIFO Empty Status.          |
| 2    | KU   | UXU         | 1'b0: rx FIFO is not empty          |
|      |      |             | 1'b1: rx FIFO is empty              |
|      |      |             | TXES                                |
| 1    | RO   | RO 0x0      | Transmit FIFO Empty Status.         |
| -    |      |             | 1'b0: tx FIFO is not empty          |
|      |      |             | 1'b1: tx FIFO is empty              |
|      |      |             | TXFS                                |
| 0    | RO   | 0x1         | Transmit FIFO Full Status.          |
|      | ĸŬ   |             | 1'b0: tx FIFO is not full           |
|      |      |             | 1'b1: tx FIFO is full               |

## <u>SFC\_SR</u>

Address: Operational Base + offset (0x0024)

| Bit  | Attr | <b>Reset Value</b> | Description                                                       |
|------|------|--------------------|-------------------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                          |
|      |      |                    | SR                                                                |
|      |      |                    | 1'b0: SFC is idle                                                 |
| 0    | RW   | 0x0                | 1'b1: SFC is busy                                                 |
|      |      |                    | When busy, don't set the control register. When idle, the rx FIFO |
|      |      |                    | and tx FIFO are all empty.                                        |

#### SFC\_RISR

Address: Operational Base + offset (0x0028)

| Bit  | Attr | <b>Reset Value</b> | Description                  |
|------|------|--------------------|------------------------------|
| 31:8 | RO   | 0x0                | reserved                     |
|      |      | 0×0                | DMAS                         |
| 7    |      |                    | DMA Finish Interrupt Status. |
| /    | RO   |                    | 1'b0: not active             |
|      |      |                    | 1'b1: active                 |

| Bit | Attr | Reset Value | Description                              |
|-----|------|-------------|------------------------------------------|
|     |      |             | NSPIS                                    |
| C   |      | 00          | SPI Error Interrupt Status.              |
| 6   | RO   | 0x0         | 1'b0: not active                         |
|     |      |             | 1'b1: active                             |
|     |      |             | AHBS                                     |
| 5   |      | 0x0         | AHB Error Interrupt Status.              |
| 5   | RO   | UXU         | 1'b0: not active                         |
|     |      |             | 1'b1: active                             |
|     |      |             | TRANSS                                   |
| 4   | RO   | 0.40        | Transfer finish Interrupt Status.        |
| 4   | RU   | 0x0         | 1'b0: not active                         |
|     |      |             | 1'b1: active                             |
|     |      | 0x0         | TXES                                     |
| 3   | RO   |             | Transmit FIFO Empty Interrupt Status.    |
| 5   | RU   |             | 1'b0: not active                         |
|     |      |             | 1'b1: active                             |
|     |      | 0×0         | TXOS                                     |
| 2   | RO   |             | Transmit FIFO Overflow Interrupt Status. |
| 2   | RU   |             | 1'b0: not active                         |
|     |      |             | 1'b1: active                             |
|     |      |             | RXUS                                     |
| 1   | RO   |             | Receive FIFO Underflow Interrupt Status. |
| 1   | RU   | 0x0         | 1'b0: not active                         |
|     |      |             | 1'b1: active                             |
|     |      |             | RXFS                                     |
| 0   |      | 0.40        | Receive FIFO Full Interrupt Status.      |
| 0   | RO   | 0×0         | 1'b0: not active                         |
|     |      |             | 1'b1: active                             |

# <u>SFC\_VER</u>

Address: Operational Base + offset (0x002c)

| Bit   | Attr | <b>Reset Value</b> | Description                   |
|-------|------|--------------------|-------------------------------|
| 31:16 | RO   | 0x0                | Reserved.                     |
| 15:0  | RW   | 0x3                | VER<br>The version id of sfc. |

## SFC QOP

Address: Operational Base + offset (0x0030)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                          |
|------|------|--------------------|--------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                                             |
| 0    | RW   | 0x0                | SO123<br>The value of SIO1, SIO2 and SIO3 during command and address<br>bits output. |

## SFC\_DMATR

Address: Operational Base + offset (0x0080)

| Bit  | Attr | <b>Reset Value</b> | Description                        |
|------|------|--------------------|------------------------------------|
| 31:1 | RO   | 0x0                | reserved                           |
| 0    | W1   | 0.40               | DMATR                              |
| 0    | С    | 0x0                | Write 1 to start the dma transfer. |

#### SFC\_DMAADDR

Address: Operational Base + offset (0x0084)

| Bit  | Attr | <b>Reset Value</b> | Description  |
|------|------|--------------------|--------------|
| 31:0 |      | 000000000          | DMAADDR      |
| 51.0 | RW   | 0x00000000         | DMA Address. |

#### SFC\_CMD

Address: Operational Base + offset (0x0100)

| Bit   |    | <b>Reset Value</b> | Description                                                                                                                |
|-------|----|--------------------|----------------------------------------------------------------------------------------------------------------------------|
|       |    |                    | CS<br>Flash chip select.                                                                                                   |
| 31:30 | WO | 0x0                | 2'b00: chip select 0                                                                                                       |
|       |    |                    | Others: reserved                                                                                                           |
|       |    |                    | TRB                                                                                                                        |
| 29:16 | WO | 0×0000             | Total Data Bytes number that will write to /read from the flash.<br>In DMA mode, this register must be aligned to 2 bytes. |
|       |    |                    | ADDRB                                                                                                                      |
|       |    |                    | Address bits number select, if there is not address command to                                                             |
|       |    | 0×0                | send, set to zero.                                                                                                         |
| 15:14 | WO |                    | 2'b00: 0bits                                                                                                               |
|       |    |                    | 2'b01: 24bits                                                                                                              |
|       |    |                    | 2'b10: 32bits                                                                                                              |
|       |    |                    | 2'b11: From the ABIT register                                                                                              |
|       |    |                    | CONT                                                                                                                       |
| 13    | wo | VO 0×0             | Continuous read mode.                                                                                                      |
|       |    |                    | 1'b0: disable continuous read mode                                                                                         |
|       |    |                    | 1'b1: enable continuous read mode                                                                                          |
|       |    |                    | WR                                                                                                                         |
| 12    | wo | 0x0                | Flash Write or Read.                                                                                                       |
|       |    |                    | 1'b0: read                                                                                                                 |
|       |    |                    | 1'b1: write                                                                                                                |
| 11:8  | wo | 0x0                | DUMM                                                                                                                       |
|       |    |                    | Dummy Bits Number.                                                                                                         |
| 7:0   | wo | 0x00               | CMD                                                                                                                        |
| -     | -  |                    | Flash Command.                                                                                                             |

#### SFC ADDR

Address: Operational Base + offset (0x0104)

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

| Bit  | Attr | <b>Reset Value</b> | Description              |
|------|------|--------------------|--------------------------|
| 31:0 | WO   | 0×00000000         | ADDR<br>Flash's address. |

## SFC\_DATA

Address: Operational Base + offset (0x0108)

| Bit  | Attr | <b>Reset Value</b>                                                          | Description |
|------|------|-----------------------------------------------------------------------------|-------------|
| 31:0 |      | V 0x00000000 DATA<br>Flash's Data. The LSB of this data will be sent first. | DATA        |
| 31:0 | RW   |                                                                             |             |

# **21.5 Interface Description**

| Table 21-11SFC interface description |
|--------------------------------------|
|--------------------------------------|

| Module<br>Pin | Direct<br>ion | Pin Name                                    | IOMUX Setting                         |
|---------------|---------------|---------------------------------------------|---------------------------------------|
| sfc_clk       | 0             | GPIO3_A4/FLASH_D4/EMMC_D4/SF<br>C_CLK       | GRF_GPIO3A_IOMUX_SEL[9:8]<br>=2'b11   |
| sfc_csn0      | 0             | GPIO3_A5/FLASH_D5/EMMC_D5/SF<br>C_CSN0      | GRF_GPIO3A_IOMUX_SEL[11:1<br>0]=2'b11 |
| sfc_sio0      | I/O           | GPIO3_A0/FLASH_D0/EMMC_D0/SF<br>C_SIO0      | GRF_GPIO3A_IOMUX_SEL[1:0]<br>=2'b11   |
| sfc_sio1      | I/O           | GPIO3_A1/FLASH_D1/EMMC_D1/SF<br>C_SIO1      | GRF_GPIO3A_IOMUX_SEL[3:2]<br>=2'b11   |
| sfc_sio2      | I/O           | GPIO3_A2/FLASH_D2/EMMC_D2/SF<br>C_WP_SIO2   | GRF_GPIO3A_IOMUX_SEL[5:4]<br>=2'b11   |
| sfc_sio3      | I/O           | GPIO3_A3/FLASH_D3/EMMC_D3/SF<br>C_HOLD_SIO3 | GRF_GPIO3A_IOMUX_SEL[7:6]<br>=2'b11   |

Notes: I=input, O=output, I/O=input/output, bidirectional.

# **21.6 Application Notes**

## 21.6.1 AHB Slave write flash flow (non-DMA mode)



Fig. 21-4 slave mode write

All the AHB bus write data to SFC\_CMD, SFC\_ADDR and SFC\_DATA will be marked with different header and then pushed into transmit FIFO by writing order.

# 21.6.2 AHB Slave read flash flow (non-DMA mode)



Fig. 21-5 slave mode read

## 21.6.3 AHB DMA transfer flow (DMA mode)



Fig. 21-6 master mode flow

The total transfer bytes is decided by TRB register in SFC\_CMD and must be aligned to 2 bytes.

## 21.6.4 SPI Mode and Shift Phase

The register SPIM in SFC\_CTRL will decide the default value of sclk\_out. When SPIM=0, the default value is 0. When SPIM=1, the default value is 1. The register SHIFTPAHSE in SFC\_CTRL will decide when to sample the SIO data. If SHIFTPAHSE=0, it will sample the data at the posedge of sclk\_out. If SHIFTPHASE=1, it will sample the data at the negedge of sclk\_out.



## 21.6.5 Other Notes

The SFC core clock(SFC\_sclk)need to be kept under 100MHZ and the SFC interface clock(sfc\_clk) is a half of the SFC\_sclk. It's better to soft reset the SFC before data transfer.

# Chapter 22 GPIO

# 22.1 Overview

GPIO is a programmable General Purpose Programming I/O peripheral. This component is an APB slave device.GPIO controls the output data and direction of external I/O pads. It also can read back thedata on external pads using memory-mapped registers. GPIO supports the following features:

- 32 bits APB bus width
- 32 independently configurable signals
- Separate data registers and data direction registers for each signal
- Software control for each signal, or for each bit of each signal
- Configurable interrupt mode

# 22.2 Block Diagram



#### **Block descriptions:**

#### **APB Interface**

The APB Interface implements the APB slave operation. Its data bus width is 32 bits.

#### Port I/O Interface

External data Interface to or from I/O pads.

#### **Interrupt Detection**

Interrupt interface to or from interrupt controller.

# 22.3 Function Description

## 22.3.1 Operation

#### **Control Mode (software)**

Under software control, the data and direction control for the signal aresourced from the data register (GPIO\_SWPORTA\_DR) and direction control register (GPIO\_SWPORTA\_DDR). The direction of the external I/O pad is controlled by a write to the Porta datadirection register (GPIO\_SWPORTA\_DDR). The data written to this memory-mapped register gets mapped onto an output signal, GPIO\_PORTA\_DDR, of the GPIO peripheral. This output signal controls thedirection of an external I/O pad.

The data written to the Porta data register (GPIO\_SWPORTA\_DR) drives the output buffer of the I/O pad.External data are input on the external data signal, GPIO\_EXT\_PORTA. Reading the external signal register(GPIO\_EXT\_PORTA) shows the value on the signal, regardless of the direction. This register is read-only, meaning that it cannot be written from the APB

software interface.

#### **Reading External Signals**

The data on the GPIO\_EXT\_PORTA external signal can always be read. The data on the external GPIO signal is read by an APB read of the memory-mapped register, GPIO\_EXT\_PORTA.

An APB read to the GPIO\_EXT\_PORTA register yields a value equal to that which is on the GPIO\_EXT\_PORTA signal.

#### Interrupts

Port A can be programmed to accept external signals as interrupt sources on any of the bits of the signal. The type of interrupt is programmable with one of the following settings:

- Active-high and level
- Active-low and level
- Rising edge
- Falling edge
- Both the rising edge and the falling edge

The interrupts can be masked by programming the GPIO\_INTMASK register. The interrupt status can be read before masking (called raw status) and after masking.

The interrupts are combined into a single interrupt output signal, which has the same polarity as the individual interrupts. In order to mask the combined interrupt, all individual interrupts have to be masked. The single combined interrupt does not have its own mask bit.

Whenever Port A is configured for interrupts, the data direction must be set to Input. If the data direction register is reprogrammed to Output, then any pending interrupts are not lost. However, no new interrupts are generated.

For edge-detected interrupts, the ISR can clear the interrupt by writing a 1 to the GPIO\_PORTA\_EOI register for the corresponding bit to disable the interrupt. This write also clears the interrupt status and raw status registers. Writing to the GPIO\_PORTA\_EOI register has no effect on level-sensitive interrupts. If level-sensitive interrupts cause the processor to interrupt, then the ISR can poll the GPIO\_INT\_RAWSTATUS register until the interrupt source disappears, or it can write to the GPIO\_INTMASK register to mask the interrupt before exiting the ISR. If the ISR exits without masking or disabling the interrupt prior to exiting, then the level-sensitive interrupt repeatedly requests an interrupt until the interrupt is cleared at the source.



Fig. 22-2 GPIO Interrupt RTL Block Diagram

#### **Debounce operation**

Port A has been configured to include the debounce capability interrupt feature. The external signal can be debounced to remove any spurious glitches that are less than one period of the external debouncing clock.

When input interrupt signals are debounced using a debounce clock (pclk), the signals must be active for a minimum of two cycles of the debounce clock to guarantee that they are registered. Any input pulse widths less than a debounce clock period are bounced. A pulse width between one and two debounce clock widths may or may not propagate, depending on its phase relationship to the debounce clock. If the input pulse spans two rising edges of the debounce clock, it is registered. If it spans only one risingedge, it is not registered.

#### Synchronization of Interrupt Signals to the System Clock

Interrupt signals are internally synchronized to pclk. Synchronization topclk must occur for edge-detect signals. With level-sensitive interrupts, synchronization is optional and under software control (GPIO\_LS\_SYNC).

## 22.3.2 Programming

#### **Programming Considerations**

- Reading from an unused location or unused bits in a particular register always returns zeros. There is no error mechanism in the APB.
- Programming the GPIO registers for interrupt capability, edge-sensitive or levelsensitive interrupts, and interrupt polarity should be completed prior to enabling the interrupts on Port A inorder to prevent spurious glitches on the interrupt lines to the interrupt controller.
- Writing to the interrupt clear register clears an edge-detected interrupt and has no effect on alevel-sensitive interrupt.

#### GPIOs' hierarchy in the chip

GPIO0/GPIO1/GPIO2/GPIO3/GPIO4 are all in PD\_LOGIC subsystem.

# 22.4 Register Description

This section describes the control/status registers of the design. Software should read and write these registers using 32-bits accesses. There are 5 GPIOs (GPIO0  $\sim$  GPIO4), and each of them has same register group. Therefore, 5 GPIOs' register groups have 5 different base addresses.

| Name                      | Offset | Size | Reset<br>Value | Description                     |
|---------------------------|--------|------|----------------|---------------------------------|
| <u>GPIO SWPORTA DR</u>    | 0x0000 | W    | 0x00000000     | Port A data register            |
| GPIO_SWPORTA_DDR          | 0x0004 | W    | 0x00000000     | Port A data direction register  |
| <u>GPIO INTEN</u>         | 0x0030 | W    | 0x00000000     | Interrupt enable register       |
| GPIO INTMASK              | 0x0034 | W    | 0x00000000     | Interrupt mask register         |
| <u>GPIO INTTYPE LEVEL</u> | 0x0038 | W    | 0x00000000     | Interrupt level register        |
| GPIO INT POLARITY         | 0x003c | W    | 0x00000000     | Interrupt polarity register     |
| GPIO_INT_STATUS           | 0x0040 | W    | 0x00000000     | Interrupt status of port A      |
| GPIO INT RAWSTATUS        | 0x0044 | W    | 0x00000000     | Raw Interrupt status of port A  |
| GPIO DEBOUNCE             | 0x0048 | W    | 0x00000000     | Debounce enable register        |
| <u>GPIO_PORTA_EOI</u>     | 0x004c | W    | 0x00000000     | Port A clear interrupt register |
| GPIO EXT PORTA            | 0x0050 | W    | 0x00000000     | Port A external port register   |
|                           | 0,0060 | ۱۸/  | 0,000,000,000  | Level_sensitive synchronization |
| <u>GPIO_LS_SYNC</u>       | 0x0060 | W    | 0x00000000     | enable register                 |
| <u>GPIO INT BOTHEDGE</u>  | 0x0068 | W    | 0x0000000      | Interrupt both edge type        |

#### 22.4.1 Registers Summary

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

## 22.4.2 Detail Register Description

#### GPIO SWPORTA DR

Address: Operational Base + offset (0x0000)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000         | gpio_swporta_dr<br>Values written to this register are output on the I/O signals for<br>Port A if the corresponding data direction bits for Port A are set to<br>Output mode. The value read back is equal to the last value<br>written to this register |

#### **GPIO\_SWPORTA\_DDR**

Address: Operational Base + offset (0x0004)

| Bit  | Attr | <b>Reset Value</b> | Description                                                         |
|------|------|--------------------|---------------------------------------------------------------------|
|      |      |                    | gpio_swporta_ddr                                                    |
|      |      |                    | Values written to this register independently control the direction |
| 31:0 | RW   | 0x00000000         | of the corresponding data bit in Port A.                            |
|      |      |                    | 1'b0: Input (default)                                               |
|      |      |                    | 1'b1: Output                                                        |

#### **GPIO\_INTEN**

Address: Operational Base + offset (0x0030)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000         | <ul> <li>gpio_int_en</li> <li>Allows each bit of Port A to be configured for interrupts.</li> <li>Whenever a 1 is written to a bit of this register, it configures the corresponding bit on Port A to become an interrupt; otherwise,</li> <li>Port A operates as a normal GPIO signal. Interrupts are disabled on the corresponding bits of Port A if the corresponding data direction register is set to Output.</li> <li>1'b0: Configure Port A bit as normal GPIO signal (default)</li> <li>1'b1: Configure Port A bit as interrupt</li> </ul> |

#### **GPIO\_INTMASK**

Address: Operational Base + offset (0x0034)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                         |
| 0    | RW   | 0x0                | <pre>gpio_int_mask<br/>Controls whether an interrupt on Port A can create an interrupt<br/>for the interrupt controller by not masking it. Whenever a 1 is<br/>written to a bit in this register, it masks the interrupt generation<br/>capability for this signal; otherwise interrupts are allowed<br/>through.<br/>1'b0: Interrupt bits are unmasked (default)<br/>1'b1: Mask interrupt</pre> |

#### **GPIO INTTYPE LEVEL**

Address: Operational Base + offset (0x0038)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                               |
|------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                                                                                                  |
| 0    | RW   |                    | gpio_inttype_level<br>Controls the type of interrupt that can occur on Port A.<br>1'b0: Level-sensitive (default)<br>1'b1: Edge-sensitive |

#### **<u>GPIO\_INT\_POLARITY</u>**

Address: Operational Base + offset (0x003c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                      |
|------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | gpio_int_polarity<br>Controls the polarity of edge or level sensitivity that can occur on<br>input of Port A.<br>1'b0: Active-low (default)<br>1'b1: Active-high |

#### **GPIO INT STATUS**

Address: Operational Base + offset (0x0040)

| Bit  | Attr | <b>Reset Value</b>                     | Description                                   |
|------|------|----------------------------------------|-----------------------------------------------|
| 31:0 | RO   | () ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( | gpio_int_status<br>Interrupt status of Port A |

#### **GPIO INT RAWSTATUS**

Address: Operational Base + offset (0x0044)

| Bit  | Attr | <b>Reset Value</b> | Description                                                               |
|------|------|--------------------|---------------------------------------------------------------------------|
| 31:0 | RO   |                    | gpio_int_rawstatus<br>Raw interrupt of status of Port A (premasking bits) |

#### **GPIO\_DEBOUNCE**

Address: Operational Base + offset (0x0048)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31:0 | RW   | 0×00000000         | <ul> <li>gpio_debounce</li> <li>Controls whether an external signal that is the source of an interrupt needs to be debounced to remove any spurious glitches.</li> <li>Writing a 1 to a bit in this register enables the debouncing circuitry. A signal must be valid for two periods of an external clock before it is internally processed.</li> <li>1'b0: No debounce (default)</li> <li>1'b1: Enable debounce</li> </ul> |  |  |  |  |  |

#### **<u>GPIO\_PORTA\_EOI</u>**

Address: Operational Base + offset (0x004c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                         |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | wo   | 0×00000000         | <ul> <li>gpio_porta_eoi</li> <li>Controls the clearing of edge type interrupts from Port A. When a 1 is written into a corresponding bit of this register, the interrupt is cleared. All interrupts are cleared when Port A is not configured for interrupts.</li> <li>1'b0: No interrupt clear (default)</li> <li>1'b1: Clear interrupt</li> </ul> |

## <u>GPIO EXT PORTA</u>

Address: Operational Base + offset (0x0050)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                            |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | gpio_ext_porta<br>When Port A is configured as Input, then reading this location<br>reads the values on the signal. When the data direction of Port A<br>is set as Output, reading this location reads the data register for<br>Port A |

#### GPIO LS SYNC

Address: Operational Base + offset (0x0060)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                     |  |  |  |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:0 | RW   | 0x00000000         | gpio_ls_sync<br>Writing a 1 to this register results in all level-sensitive interrupts<br>being synchronized to pclk_intr.<br>1'b0: No synchronization to pclk_intr (default)<br>1'b1: Synchronize to pclk_intr |  |  |  |

#### **GPIO INT BOTHEDGE**

Address: Operational Base + offset (0x0068)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31:0 | RW   | 0×00000000         | interrupt_both_edge_type<br>Controls the edge type of interrupt that can occur on Port A.<br>Whenever a particular bit is programmed to 1, it enables the<br>generation of interrupts on both the rising edge and the falling<br>edge of an external input signal corresponding to that bit on port<br>A. The values programmed in the registers gpio_intype_level and<br>gpio_int_polarity for this particular bit are not considered when<br>the corresponding bit of this register is set to 1. Whenever a<br>particular bit is programmed to 0, the interrupt type depends on<br>the value of the corresponding bits in the gpio_inttype_level and<br>gpio_int_polarity registers |  |  |  |  |  |

# 22.5 Interface Description

Table 22-1 GPIO interface description

| Module Pin         | Dir             | Pin Name     | IOMUX Setting                  |  |  |  |  |  |  |  |
|--------------------|-----------------|--------------|--------------------------------|--|--|--|--|--|--|--|
|                    |                 | GPIOC        | Interface                      |  |  |  |  |  |  |  |
| gpio0_porta[7:0]   | I/O             | GPIO0_A[7:0] | GRF_GPIO0A_IOMUX[15:0]=16'h0   |  |  |  |  |  |  |  |
| gpio0_porta[15:8]  | I/O             | GPIO0_B[7:0] | GRF_GPIO0B_IOMUX[15:0]=16'h0   |  |  |  |  |  |  |  |
| gpio0_porta[21:16] | I/O             | GPIO0_C[5:0] | GRF_GPIO0C_IOMUX[11:0]=12'h0   |  |  |  |  |  |  |  |
|                    | GPIO1 Interface |              |                                |  |  |  |  |  |  |  |
| gpio1_porta[7:0]   | I/O             | GPIO1_A[7:0] | GRF_GPIO1A_IOMUX[15:0]=16'h0   |  |  |  |  |  |  |  |
| gpio1_porta[13:8]  | I/O             | GPIO1_B[5:0] | GRF_GPIO1B_IOMUX_L[11:0]=12'h0 |  |  |  |  |  |  |  |
| gpio1_porta[14]    | I/O             | GPIO1_B[6]   | GRF_GPIO1B_IOMUX_L[15:12]=4'h0 |  |  |  |  |  |  |  |
| gpio1_porta[15]    | I/O             | GPIO1_B[7]   | GRF_GPIO1B_IOMUX_H[3:0]=4'h0   |  |  |  |  |  |  |  |
| gpio1_porta[17:16] | I/O             | GPIO1_C[1:0] | GRF_GPIO1C_IOMUX_L[3:0]=4'h0   |  |  |  |  |  |  |  |
| gpio1_porta[20:18] | I/O             | GPIO1_C[4:2] | GRF_GPIO1C_IOMUX_L[15:4]=12'h0 |  |  |  |  |  |  |  |
| gpio1_porta[23:21] | I/O             | GPIO1_C[7:5] | GRF_GPIO1C_IOMUX_H[11:0]=12'h0 |  |  |  |  |  |  |  |
| gpio1_porta[25:24] | I/O             | GPIO1_D[1:0] | GRF_GPIO1D_IOMUX[3:0]=4'h0     |  |  |  |  |  |  |  |
|                    |                 | GPIO2 I      | interface                      |  |  |  |  |  |  |  |
| gpio2_porta[7:0]   | I/O             | GPIO2_A[7:0] | GRF_GPIO2A_IOMUX[15:0]=16'h0   |  |  |  |  |  |  |  |
| gpio2_porta[15:8]  | I/O             | GPIO2_B[7:0] | GRF_GPIO2B_IOMUX[15:0]=16'h0   |  |  |  |  |  |  |  |
| gpio2_porta[16]    | I/O             | GPIO2_C[0]   | GRF_GPIO2C_IOMUX[1:0]=2'b0     |  |  |  |  |  |  |  |
|                    |                 | GPIO3 I      | interface                      |  |  |  |  |  |  |  |
| gpio3_porta[7:0]   | I/O             | GPIO3_A[7:0] | GRF_GPIO3A_IOMUX[15:0]=16'h0   |  |  |  |  |  |  |  |
| gpio3_porta[11:8]  | I/O             | GPIO3_B[3:0] | GRF_GPIO3B_IOMUX[7:0]=8'h0     |  |  |  |  |  |  |  |
| gpio3_porta[13:12] | I/O             | GPIO3_B[5:4] | GRF_GPIO3B_IOMUX[15:8]=8'h0    |  |  |  |  |  |  |  |
|                    |                 | GPIO4 I      | nterface                       |  |  |  |  |  |  |  |
| gpio4_porta[7:0]   | I/O             | GPIO4_A[7:0] | GRF_GPIO4A_IOMUX[15:0]=16'h0   |  |  |  |  |  |  |  |
| gpio4_porta[15:8]  | I/O             | GPIO4_B[7:0] | GRF_GPIO4B_IOMUX[15:0]=16'h0   |  |  |  |  |  |  |  |
| gpio4_porta[16]    | I/O             | GPIO4_C[0]   | GRF_GPIO4C_IOMUX[1:0]=2'b0     |  |  |  |  |  |  |  |
| gpio4_porta[30:24] | I/O             | GPIO4_D[6:0] | GRF_GPIO4D_IOMUX[13:0]=14'h0   |  |  |  |  |  |  |  |

Note: Unused Module Pin is tied to zero!

# 22.6 Application Notes

#### Steps to set GPIO's direction

- Write GPIO\_SWPORT\_DDR[x] as 1 to set this gpio as output direction and Write GPIO\_SWPORT\_DDR[x] as 0 to set this gpio as input direction.
- Default GPIO's direction is input direction.

## Steps to set GPIO's level

- Write GPIO\_SWPORT\_DDR[x] as 1 to set this gpio as output direction.
- Write GPIO\_SWPORT\_DR[x] as v to set this GPIO's value.

#### Steps to get GPIO's level

- Write GPIO\_SWPORT\_DDR[x] as 0 to set this gpio as input direction.
- Read from GPIO\_EXT\_PORT[x] to get GPIO's value

## Steps to set GPIO as interrupt source

- Write GPIO\_SWPORT\_DDR[x] as 0 to set this gpio as input direction.
- Write GPIO\_INTTYPE\_LEVEL[x] as v1 and write GPIO\_INT\_POLARITY[x] as v2 to set interrupt type
- Write GPIO\_INTEN[x] as 1 to enable GPIO's interrupt

Note: Please switch iomux to GPIO mode first!

# **Chapter 23 MAC Ethernet Interface**

# 23.1 Overview

The MAC Ethernet Controller provides a complete Ethernet interface from processor to a Reduced Media Independent Interface (RMII) compliant Ethernet PHY.

The MAC includes a DMA controller. The DMA controller efficiently moves packet data from microprocessor's RAM, formats the data for an IEEE 802.3-2002 compliant packet and transmits the data to an Ethernet Physical Interface (PHY). It also efficiently moves packet data from RXFIFO to microprocessor's RAM.

# 23.1.1 Feature

- Supports 10/100-Mbps data transfer rates with the RMII interfaces
  - Supports both full-duplex and half-duplex operation
    - Supports CSMA/CD Protocol for half-duplex operation
    - Supports IEEE 802.3x flow control for full-duplex operation
    - Optional forwarding of received pause control frames to the user application in fullduplex operation
    - Back-pressure support for half-duplex operation
    - Automatic transmission of zero-quanta pause frame on de-assertion of flow control input in full-duplex operation
- Preamble and start-of-frame data (SFD) insertion in Transmit, and deletion in Receive paths
- Automatic CRC and pad generation controllable on a per-frame basis
- Options for Automatic Pad/CRC Stripping on receive frames
- Programmable frame length to support Standard Ethernet frames
- Programmable InterFrameGap (40-96 bit times in steps of 8)
- Supports a variety of flexible address filtering modes:
  - 64-bit Hash filter (optional) for multicast and uni-cast (DA) addresses
  - Option to pass all multicast addressed frames
  - Promiscuous mode support to pass all frames without any filtering for network monitoring
  - Passes all incoming packets (as per filter) with a status report
- Separate 32-bit status returned for transmission and reception packets
- Supports IEEE 802.1Q VLAN tag detection for reception frames
- MDIO Master interface for PHY device configuration and management
- Support detection of LAN wake-up frames and AMD Magic Packet frames
- Support checksum off-load for received IPv4 and TCP packets encapsulated by the Ethernet frame
- Support checking IPv4 header checksum and TCP, UDP, or ICMP checksum encapsulated in IPv4 or IPv6 datagrams
- Comprehensive status reporting for normal operation and transfers with errors
- Support per-frame Transmit/Receive complete interrupt control
- Supports 4-KB receive FIFO depths on reception.
- Supports 2-KB FIFO depth on transmission
- Automatic generation of PAUSE frame control or backpressure signal to the MAC core based on Receive FIFO-fill (threshold configurable) level
- Handles automatic retransmission of Collision frames for transmission
- Discards frames on late collision, excessive collisions, excessive deferral and underrun conditions
- AXI interface to any CPU or memory
- Software can select the type of AXI burst (fixed and variable length burst) in the AXI Master interface
- Supports internal loopback on the RMII for debugging
- Debug status register that gives status of FSMs in Transmit and Receive data-paths and

FIFO fill-levels.

# 23.2 Block Diagram



Fig. 23-1 MAC Architecture

The MAC is broken up into multiple separate functional units. These blocks are interconnected in the MAC module. The block diagram shows the general flow of data and control signals between these blocks.

The MAC transfers data to system memory through the AXI master interface. The host CPU uses the APB Slave interface to access the MAC subsystem's control and status registers (CSRs).

The MAC supports the PHY interfaces of reduced MII (RMII).

The Transmit FIFO (Tx FIFO) buffers data read from system memory by the DMA before transmission by the MAC Core. Similarly, the Receive FIFO (Rx FIFO) stores the Ethernet frames received from the line until they are transferred to system memory by the DMA. These are asynchronous FIFOs, as they also transfer the data between the application clock and the MAC line clocks.



Fig. 23-2 MAC Block Diagram

The MAC controller named MAC2IO:

• MAC2IO Supports 10/100-Mbps data transfer rates with the RMII interfaces

# 23.3 Function Description

## 23.3.1 Frame Structure

Data frames transmitted shall have the frame format shown in Fig. 1-3.

Fig. 23-3 MAC Frame Structure

The preamble <preamble> begins a frame transmission. The bit value of the preamble field consists of 7 octets with the following bit values:

10101010 10101010 10101010 10101010 10101010 10101010 10101010

The SFD (start frame delimiter) <sfd> indicates the start of a frame and follows the preamble. The bit value is 10101011.

The data in a well formed frame shall consist of N octet's data.

# 23.3.2 RMII Interface timing diagram

The Reduced Media Independent Interface (RMII) specification reduces the pin count between Ethernet PHYs and Switch ASICs (only in 10/100 mode). According to the IEEE 802.3u standard, an MII contains 16 pins for data and control. In devices incorporating multiple MAC or PHY interfaces (such as switches), the number of pins adds significant cost with increase in port count. The RMII specification addresses this problem by reducing the pin count to 7 for each port - a 62.5% decrease in pin count.

The RMII module is instantiated between the MAC and the PHY. This helps translation of the MAC's MII into the RMII. The RMII block has the following characteristics:

- Supports 10-Mbps and 100-Mbps operating rates. It does not support 1000-Mbps operation.
- Two clock references are sourced externally or CRU, providing independent, 2-bit wide transmit and receive paths.

#### **Transmit Bit Ordering**

Each nibble from the MII must be transmitted on the RMII a di-bit at a time with the order of di-bit transmission shown in Fig.1-4. The lower order bits (D1 and D0) are transmitted first followed by higher order bits (D2 and D3).



Fig. 23-4 RMII transmission bit ordering

#### **RMII Transmit Timing Diagrams**

Fig.1-5 through 1-8 show MII-to-RMII transaction timing. The clk\_rmii\_i (REF\_CLK) frequency is 50MHz in RMII interface. In 10Mb/s mode, as the REF\_CLK frequency is 10 times as the data rate, the value on rmii\_txd\_o[1:0] (TXD[1:0]) shall be valid such that

TXD[1:0] may be sampled every 10th cycle, regard-less of the starting cycle within the group and yield the correct frame data.



Fig. 23-8 End of MII and RMII Transmission in 10-Mbps Mode

#### **Receive Bit Ordering**

Each nibble is transmitted to the MII from the di-bit received from the RMII in the nibble transmission order shown in Fig.1-9. The lower order bits (D0 and D1) are received first, followed by the higher order bits (D2 and D3).



Fig. 23-9 RMII receive bit ordering

## 23.3.3 Management Interface

The MAC management interface provides a simple, two-wire, serial interface to connect the MAC and a managed PHY, for the purposes of controlling the PHY and gathering status from the PHY. The management interface consists of a pair of signals that transport the management information across the MII bus: MDIO and MDC.

The MAC initiates the management write/read operation. The clock gmii\_mdc\_o(MDC) is a divided clock from the application clock pclk\_MAC. The divide factor depends on the clock range setting in the GMII address register. Clock range is set as follows:

| Selection | pclk_MAC    | MDC Clock    |
|-----------|-------------|--------------|
| 0000      | 60-100 MHz  | pclk_MAC/42  |
| 0001      | 100-150 MHz | pclk_MAC/62  |
| 0010      | 20-35 MHz   | pclk_MAC/16  |
| 0011      | 35-60 MHz   | pclk_MAC/26  |
| 0100      | 150-250 MHz | pclk_MAC/102 |
| 0101      | 250-300 MHz | pclk_MAC/124 |
| 0110,0111 | Reserved    | -            |

The MDC is the derivative of the application clock pclk\_MAC. The management operation is performed through the gmii\_mdi\_i, gmii\_mdo\_o and gmii\_mdo\_o\_e signals. A three-state buffer is implemented in the PAD.

The frame structure on the MDIO line is shown below.

| IDLE | PREAMBLE | START | OPCODE | PHY<br>ADDR | REG<br>ADDR | ТА | DATA | IDLE |  |
|------|----------|-------|--------|-------------|-------------|----|------|------|--|
|------|----------|-------|--------|-------------|-------------|----|------|------|--|

#### Fig. 23-10 MDIO frame structure

| IDLE:     | The mdio line is three-state; there is no clock on gmii_mdc_o          |
|-----------|------------------------------------------------------------------------|
| PREAMBLE: | 32 continuous bits of value 1                                          |
| START:    | Start-of-frame is 2'b01                                                |
| OPCODE:   | 2'b10 for read and 2'b01 for write                                     |
| PHY ADDR: | 5-bit address select for one of 32 PHYs                                |
| REG ADDR: | Register address in the selected PHY                                   |
| TA:       | Turnaround is 2'bZ0 for read and 2'b10 for Write                       |
| DATA:     | Any 16-bit value. In a write operation, the MAC drives mdio; in a read |
|           | operation, PHY drives it.                                              |
|           |                                                                        |

## 23.3.4 Power Management Block

Power management (PMT) supports the reception of network (remote) wake-up frames and Magic Packet frames. PMT does not perform the clock gate function, but generates interrupts for wake-up frames and Magic Packets received by the MAC. The PMT block sits on the receiver path of the MAC and is enabled with remote wake-up frame enable and Magic Packet enable. These enables are in the PMT control and status register and are programmed by the application.

When the power down mode is enabled in the PMT, then all received frames are dropped by the core and they are not forwarded to the application. The core comes out of the power down mode only when either a Magic Packet or a Remote Wake-up frame is received and the corresponding detection is enabled.

#### **Remote Wake-Up Frame Detection**

When the MAC is in sleep mode and the remote wake-up bit is enabled in register MAC\_PMT\_CTRL\_STA (0x002C), normal operation is resumed after receiving a remote wake-up frame. The application writes all eight wake-up filter registers, by performing a sequential write to address (0028). The application enables remote wake-up by writing a 1 to bit 2 of the register MAC\_PMT\_CTRL\_STA.

PMT supports four programmable filters that allow support of different receive frame patterns. If the incoming frame passes the address filtering of Filter Command, and if Filter CRC-16 matches the incoming examined pattern, then the wake-up frame is received. Filter\_offset (minimum value 12, which refers to the 13th byte of the frame) determines the offset from which the frame is to be examined. Filter Byte Mask determines which bytes of the frame must be examined. The thirty-first bit of Byte Mask must be set to zero. The remote wake-up CRC block determines the CRC value that is compared with Filter CRC-16. The wake-up frame is checked only for length error, FCS error, dribble bit error, GMII error, collision, and to ensure that it is not a runt frame. Even if the wake-up frame is more than 512 bytes long, if the frame has a valid CRC value, it is considered valid. Wake-up frame detection is updated in the register MAC\_PMT\_CTRL\_STA for every remote Wake-up frame received. A PMT interrupt to the application triggers a read to the MAC\_PMT\_CTRL\_STA register to determine received of a wake-up frame.

#### **Magic Packet Detection**

The Magic Packet frame is based on a method that uses Advanced Micro Device's Magic Packet technology to power up the sleeping device on the network. The MAC receives a specific packet of information, called a Magic Packet, addressed to the node on the network. Only Magic Packets that are addressed to the device or a broadcast address will be checked to determine whether they meet the wake-up requirements. Magic Packets that pass the address filtering (unicast or broadcast) will be checked to determine whether they meet the remote Wake-on-LAN data format of 6 bytes of all ones followed by a MAC Address appearing 16 times.

The application enables Magic Packet wake-up by writing a 1 to Bit 1 of the register MAC\_PMT\_CTRL\_STA. The PMT block constantly monitors each frame addressed to the node for a specific Magic Packet pattern. Each frame received is checked for a

48'hFF\_FF\_FF\_FF\_FF\_FF pattern following the destination and source address field. The PMT block then checks the frame for 16 repetitions of the MAC address without any breaks or interruptions. In case of a break in the 16 repetitions of the address, the

48'hFF\_FF\_FF\_FF\_FF\_FF pattern is scanned for again in the incoming frame. The 16 repetitions can be anywhere in the frame, but must be preceded by the synchronization stream (48'hFF\_FF\_FF\_FF\_FF\_FF\_FF). The device will also accept a multicast frame, as long as the 16 duplications of the MAC address are detected.

If the MAC address of a node is 48'h00\_11\_22\_33\_44\_55, then the MAC scans for the data sequence:

Destination Address Source Address ...... FF FFFFFFFFF 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 00 11 22 33 44 55 ...CRC

Magic Packet detection is updated in the PMT Control and Status register for Magic Packet received. A PMT interrupt to the Application triggers a read to the PMT CSR to determine whether a Magic Packet frame has been received.

## 23.3.5 MAC Management Counters

The counters in the MAC Management Counters (MMC) module can be viewed as an extension of the register address space of the CSR module. The MMC module maintains a set of registers for gathering statistics on the received and transmitted frames. These include a control register for controlling the behavior of the registers, two 32-bit registers containing interrupts generated (receive and transmit), and two 32-bit registers containing masks for the Interrupt register (receive and transmit). These registers are accessible from the Application through the MAC Control Interface (MCI). Non-32-bit accesses are allowed as long as the address is word-aligned.

The organization of these registers is shown in Register Description. The MMCs are accessed using transactions, in the same way the CSR address space is accessed. The Register Description in this chapter describe the various counters and list the address for each of the statistics counters. This address will be used for Read/Write accesses to the desired transmit/receive counter.

The MMC module gathers statistics on encapsulated IPv4, IPv6, TCP, UDP, or ICMP payloads in received Ethernet frames.

# 23.4 Register Description

| Name                   | Offset | Size | Reset<br>Value | Description                                                                                                                                                                                 |
|------------------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC_MAC_CONF           | 0x0000 | w    | 0x00000000     | MAC Configuration Register<br>This is the operation mode<br>register for the MAC                                                                                                            |
| MAC MAC FRM FILT       | 0x0004 | w    | 0×00000000     | MAC Frame Filter<br>Contains the frame filtering<br>controls                                                                                                                                |
| <u>MAC HASH TAB HI</u> | 0x0008 | w    | 0x00000000     | Hash Table High Register<br>Contains the higher 32 bits of the<br>Multicast Hash table. This register<br>is present only when the Hash<br>filter function is selected in core<br>Consultant |
| MAC_HASH_TAB_LO        | 0x000c | w    | 0x00000000     | Hash Table Low Register<br>Contains the lower 32 bits of the<br>Multicast Hash table. This register<br>is present only when the Hash<br>filter function is selected in core<br>Consultant   |

## 23.4.1 Registers Summary

## RK3308 TRM-Part1

| Name             | Offset | Size | Reset<br>Value | Description                                                                                                                                                                                                                                                                                    |
|------------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC GMII ADDR    | 0x0010 | w    | 0×00000000     | GMII Address Register<br>Controls the management cycles<br>to an external PHY                                                                                                                                                                                                                  |
| MAC GMII DATA    | 0x0014 | w    | 0×00000000     | GMII Data Register<br>Contains the data to be written to<br>or read from the PHY register                                                                                                                                                                                                      |
| MAC FLOW CTRL    | 0x0018 | w    | 0×00000000     | Flow Control Register<br>Controls the generation of control<br>frames                                                                                                                                                                                                                          |
| MAC VLAN TAG     | 0x001c | w    | 0×00000000     | VLAN Tag Register<br>Identifies IEEE 802.1Q VLAN type<br>frames                                                                                                                                                                                                                                |
| <u>MAC_DEBUG</u> | 0x0024 | w    | 0x00000000     | Debug register<br>This debug register gives the<br>status of all the main modules of<br>the transmit and receive data-<br>paths and the FIFOs. An all-zero<br>status indicates that the MAC core<br>is in idle state (and FIFOs are<br>empty) and no activity is going on<br>in the data-paths |
| MAC PMT CTRL STA | 0x002c | W    | 0x0000000      | PMT Control and Status Register<br>PMT Control and Status                                                                                                                                                                                                                                      |
| MAC INT STATUS   | 0x0038 | W    | 0×00000000     | Interrupt Status Register<br>Contains the interrupt status                                                                                                                                                                                                                                     |
| MAC INT MASK     | 0x003c | w    | 0x00000000     | Interrupt Mask Register<br>Contains the masks for generating<br>the interrupts                                                                                                                                                                                                                 |
| MAC_MAC_ADDR0_HI | 0x0040 | w    | 0x0000ffff     | MAC Address0 High Register<br>Contains the higher 16 bits of the<br>first MAC address                                                                                                                                                                                                          |
| MAC MAC ADDR0 LO | 0x0044 | w    | 0xffffffff     | MAC Address0 Low Register<br>Contains the lower 32 bits of the<br>first MAC address                                                                                                                                                                                                            |
| MAC AN CTRL      | 0x00c0 | w    | 0x00000000     | AN Control Register<br>Enables and/or restarts auto-<br>negotiation. It also enables PCS<br>loopback                                                                                                                                                                                           |
| MAC AN STATUS    | 0x00c4 | w    | 0×00000008     | AN Status Register<br>Indicates the link and auto-<br>negotiation status                                                                                                                                                                                                                       |

| Name                       | Offset | Size | Reset<br>Value | Description                                                                                                                                                                                                                                                                                     |
|----------------------------|--------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC AN ADV                 | 0x00c8 | w    | 0x000001e0     | Auto Negotiation Advertisement<br>Register<br>This register is configured before<br>auto-negotiation begins. It<br>contains the advertised ability of<br>the MAC                                                                                                                                |
| <u>MAC_AN_LINK_PART_AB</u> | 0x00cc | w    | 0×00000000     | Auto Negotiation Link Partner<br>Ability Register<br>Contains the advertised ability of<br>the link partner. Its value is valid<br>after successful completion of<br>auto-negotiation or when a new<br>base page has been received<br>(indicated in the Auto-Negotiation<br>Expansion Register) |
| MAC AN EXP                 | 0x00d0 | w    | 0x00000000     | Auto Negotiation Expansion<br>Register<br>Indicates whether a new base<br>page has been received from the<br>link partner                                                                                                                                                                       |
| MAC INTF MODE STA          | 0x00d8 | w    | 0x00000000     | RGMII Status Register<br>Indicates the status signals<br>received from the PHY through<br>the RGMII interface                                                                                                                                                                                   |
| MAC MMC CTRL               | 0x0100 | w    | 0x00000000     | MMC Control Register<br>The MMC Control register<br>establishes the operating mode of<br>the management counters                                                                                                                                                                                |

| Name            | Offset | Size | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|--------|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC MMC RX INTR | 0x0104 | w    | 0×00000000     | MMC Receive Interrupt Register<br>The MMC Receive Interrupt<br>register maintains the interrupts<br>generated when the receive<br>statistic counters reach half their<br>maximum values (0x8000_0000),<br>and when they cross their<br>maximum values (0xFFFF_FFF).<br>When Counter Stop Rollover is<br>set, then interrupts are set but<br>the counter remains at all-ones.<br>The MMC Receive Interrupt<br>register is a 32-bit wide register.<br>An interrupt bit is cleared when<br>the respective MMC counter that<br>caused the interrupt is read. The<br>least significant byte lane<br>(bits[7:0]) of the respective<br>counter must be read in order to<br>clear the interrupt bit |
| MAC MMC TX INTR | 0×0108 | w    | 0×00000000     | MMC Transmit Interrupt Register<br>The MMC Transmit Interrupt<br>register maintains the interrupts<br>generated when transmit statistic<br>counters reach half their<br>maximum values (0x8000_0000),<br>and when they cross their<br>maximum values (0xFFFF_FFF).<br>When Counter Stop Rollover is<br>set, then interrupts are set but<br>the counter remains at all-ones.<br>The MMC Transmit Interrupt<br>register is a 32-bit wide register.<br>An interrupt bit is cleared when<br>the respective MMC counter that<br>caused the interrupt is read. The<br>least significant byte lane<br>(bits[7:0]) of the respective<br>counter must be read in order to<br>clear the interrupt bit |

| Name                      | Offset | Size | Reset<br>Value | Description                                                                                                                                                                                                                                                      |
|---------------------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>MAC MMC RX INT MSK</u> | 0x010c | w    | 0×00000000     | MMC Receive Interrupt Mask<br>Register<br>The MMC Receive Interrupt Mask<br>register maintains the masks for<br>the interrupts generated when<br>receive statistic counters reach<br>half their maximum value, and<br>when they reach their maximum<br>values    |
| MAC_MMC_TX_INT_MSK        | 0x0110 | w    | 0x00000000     | MMC Transmit Interrupt Mask<br>Register<br>The MMC Transmit Interrupt Mask<br>register maintains the masks for<br>the interrupts generated when<br>transmit statistic counters reach<br>half their maximum value, and<br>when they reach their maximum<br>values |
| MAC MMC TXOCTETCNT        | 0x0114 | w    | 0×00000000     | MMC TX OCTET Good and Bad<br>Counter                                                                                                                                                                                                                             |
| MAC MMC TXFRMCNT G        | 0x0118 | w    | 0×00000000     | MMC TX OCTET Good and Bad<br>Counter                                                                                                                                                                                                                             |
| <u>MAC MMC TXUNDFLWER</u> | 0x0148 | w    | 0×00000000     | MMC TX Underflow Error                                                                                                                                                                                                                                           |
| MAC MMC TXCARERR          | 0x0160 | W    | 0x00000000     | MMC TX Carrier Error                                                                                                                                                                                                                                             |
| MAC_MMC_TXOCTETCNT_<br>G  | 0x0164 | w    | 0x00000000     | MMC TX OCTET Good Counter                                                                                                                                                                                                                                        |
| MAC MMC TXFRMCNT G        | 0x0168 | W    | 0x00000000     | MMC TX Frame Good Counter                                                                                                                                                                                                                                        |
| MAC MMC RXFRMCNT G        | 0x0180 | w    | 0x00000000     | MMC RX Frame Good and Bad<br>Counter                                                                                                                                                                                                                             |
| MAC_MMC_RXOCTETCNT_<br>GB | 0x0184 | w    | 0x00000000     | MMC RX OCTET Good and Bad<br>Counter                                                                                                                                                                                                                             |
| MAC_MMC_RXOCTETCNT_<br>G  | 0x0188 | w    | 0x00000000     | MMC RX OCTET Good Counter                                                                                                                                                                                                                                        |
| MAC_MMC_RXMCFRMCNT<br>_G  | 0x0190 | w    | 0x00000000     | MMC RX Multicast Frame Good<br>Counter                                                                                                                                                                                                                           |
| MAC MMC RXCRCERR          | 0x0194 | W    | 0x00000000     | MMC RX Carrier                                                                                                                                                                                                                                                   |
| MAC_MMC_RXLENERR          | 0x01c8 | W    | 0x0000000      | MMC RX Length Error                                                                                                                                                                                                                                              |
| MAC MMC RXFIFOOVRFL<br>W  | 0x01d4 | W    | 0×00000000     | MMC RX FIFO Overflow                                                                                                                                                                                                                                             |

| Name                       | Offset | Size | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------|--------|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC_MMC_IPC_INT_MSK        | 0x0200 | w    | 0×00000000     | MMC Receive Checksum Offload<br>Interrupt Mask Register<br>The MMC Receive Checksum<br>Offload Interrupt Mask register<br>maintains the masks for the<br>interrupts generated when the<br>receive IPC (Checksum Offload)<br>statistic counters reach half their<br>maximum value , and when they<br>reach their maximum values                                                                                                                                                                                                                                                                                                                   |
| MAC MMC IPC INTR           | 0x0208 | w    | 0×0000000      | MMC Receive Checksum Offload<br>Interrupt Register The MMC<br>Receive Checksum Offload<br>Interrupt register maintains the<br>interrupts generated when receive<br>IPC statistic counters reach half<br>their maximum values<br>(0x8000_0000), and when they<br>cross their maximum values<br>(0xFFFF_FFF). When Counter<br>Stop Rollover is set, then<br>interrupts are set but the counter<br>remains at all-ones. When the<br>MMC IPC counter that caused the<br>interrupt is read, its<br>corresponding interrupt bit is<br>cleared. The counter's least-<br>significant byte lane (bits[7:0])<br>must be read to clear the<br>interrupt bit |
| MAC MMC RXIPV4GFRM         | 0x0210 | W    | 0x00000000     | MMC RX IPV4 Good Frame                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| MAC MMC RXIPV4HDERR        | 0x0214 | w    | 0x0000000      | MMC RX IPV4 Head Error Frame                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| MAC MMC RXIPV6GFRM         | 0x0224 | W    | 0x00000000     | MMC RX IPV6 Good Frame                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| MAC_MMC_RXIPV6HDERR<br>FRM | 0x0228 | w    | 0×00000000     | MMC RX IPV6 Head Error Frame                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| MAC MMC RXUDPERRFR         | 0x0234 | w    | 0×00000000     | MMC RX UDP Error Frame                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| MAC MMC RXTCPERRFRM        | 0x023c | W    | 0x00000000     | MMC RX TCP Error Frame                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| MAC_MMC_RXICMPERRFR<br>M   | 0x0244 | w    |                | MMC RX ICMP Error Frame                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| MAC MMC RXIPV4HDERR<br>OCT | 0x0254 | W    | 0×00000000     | MMC RX OCTET IPV4 Head Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Name                                    | Offset | Size | Reset<br>Value | Description                                                                                                                                                                                                            |
|-----------------------------------------|--------|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAC_MMC_RXIPV6HDERR<br>OCT              | 0x0268 | W    | 0x00000000     | MMC RX OCTET IPV6 Head Error                                                                                                                                                                                           |
| MAC_MMC_RXUDPERROC                      | 0x0274 | W    | 0x0000000      | MMC RX OCTET UDP Error                                                                                                                                                                                                 |
| MAC MMC RXTCPERROCT                     | 0x027c | W    | 0x0000000      | MMC RX OCTET TCP Error                                                                                                                                                                                                 |
| MAC_MMC_RXICMPERROC                     | 0x0284 | W    | 0x00000000     | MMC RX OCTET ICMP Error                                                                                                                                                                                                |
| MAC BUS MODE                            | 0x1000 | W    | 0x00020101     | Bus Mode Register                                                                                                                                                                                                      |
| MAC_TX_POLL_DEMAND                      | 0x1004 | w    | 0x00000000     | Transmit Poll Demand Register<br>Used by the host to instruct the<br>DMA to poll the Transmit<br>Descriptor List                                                                                                       |
| MAC_RX_POLL_DEMAND                      | 0x1008 | w    | 0x00000000     | Receive Poll Demand Register<br>Used by the Host to instruct the<br>DMA to poll the Receive<br>Descriptor list                                                                                                         |
| MAC RX DESC LIST AD<br>DR               | 0x100c | w    | 0×00000000     | Receive Descriptor List Address<br>Register<br>Points the DMA to the start of the<br>Receive Descriptor list                                                                                                           |
| <u>MAC_TX_DESC_LIST_ADD</u><br><u>R</u> | 0x1010 | w    | 0x00000000     | Transmit Descriptor List Address<br>Register<br>Points the DMA to the start of the<br>Transmit Descriptor List                                                                                                         |
| MAC_STATUS                              | 0x1014 | w    | 0x00000000     | Status Register<br>The Software driver (application)<br>reads this register during<br>interrupt service routine or polling<br>to determine the status of the<br>DMA                                                    |
| MAC OP MODE                             | 0x1018 | w    | 0x00000000     | Operation Mode Register<br>Establishes the Receive and<br>Transmit operating modes and<br>command                                                                                                                      |
| MAC INT ENA                             | 0x101c | w    | 0×00000000     | Interrupt Enable Register<br>Enables the interrupts reported by<br>the Status Register                                                                                                                                 |
| MAC OVERFLOW CNT                        | 0×1020 | w    | 0×00000000     | Missed Frame and Buffer Overflow<br>Counter Register<br>Contains the counters for<br>discarded frames because no host<br>Receive Descriptor was available,<br>and discarded frames because of<br>Receive FIFO Overflow |

#### RK3308 TRM-Part1

| Name                                    | Offset | Size | Reset<br>Value | Description                                                                                                                         |
|-----------------------------------------|--------|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------|
| <u>MAC REC INT WDT TIM</u><br><u>ER</u> | 0x1024 | w    | 0×00000000     | Receive Interrupt Watchdog Timer<br>Register<br>Watchdog time-out for Receive<br>Interrupt (RI) from DMA                            |
| MAC AXI BUS MODE                        | 0x1028 | w    | 0×00110001     | AXI Bus Mode Register<br>Controls AXI Master behavior<br>(mainly controls burst splitting<br>and number of outstanding<br>requests) |
| MAC AXI STATUS                          | 0x102c | w    | 0×00000000     | AXI Status Register<br>Gives the idle status of the AXI<br>master's read/write channels                                             |
| MAC_CUR_HOST_TX_DES<br>C                | 0x1048 | w    | 0×00000000     | Current Host Transmit Descriptor<br>Register<br>Points to the start of current<br>Transmit Descriptor read by the<br>DMA            |
| <u>MAC CUR HOST RX DES</u><br><u>C</u>  | 0x104c | w    | 0×00000000     | Current Host Receive Descriptor<br>Register<br>Points to the start of current<br>Receive Descriptor read by the<br>DMA              |
| MAC_CUR_HOST_TX_BUF<br>_ADDR            | 0x1050 | w    | 0×00000000     | Current Host Transmit Buffer<br>Address Register<br>Points to the current Transmit<br>Buffer address read by the DMA                |
| MAC CUR HOST RX BUF<br>ADDR             | 0x1054 | w    | 0×00000000     | Current Host Receive Buffer<br>Address Register<br>Points to the current Receive<br>Buffer address read by the DMA                  |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# 23.4.2 Detail Register Description

#### MAC\_MAC\_CONF

Address: Operational Base + offset (0x0000)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                            |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | RO   | 0x0                | reserved                                                                                                                                                                                                                                               |
| 24    | RW   | 0x0                | TC<br>Transmit Configuration in RGMII<br>When set, this bit enables the transmission of duplex mode, link<br>speed, and link up/down information to the PHY in the RGMII<br>ports. When this bit is reset, no such information is driven to the<br>PHY |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 23    | RW   | 0x0         | WD<br>Watchdog Disable<br>When this bit is set, the MAC disables the watchdog timer on the<br>receiver, and can receive frames of up to 16,384 bytes.<br>When this bit is reset, the MAC allows no more than 2,048 bytes<br>(10,240 if JE is set high) of the frame being received and cuts off<br>any bytes received after that                                                                                                        |  |  |
| 22    | RW   | 0x0         | JD<br>Jabber Disable<br>When this bit is set, the MAC disables the jabber timer on the<br>transmitter, and can transfer frames of up to 16,384 bytes.<br>When this bit is reset, the MAC cuts off the transmitter if the<br>application sends out more than 2,048 bytes of data (10,240 if JE<br>is set high) during transmission                                                                                                       |  |  |
| 21    | RW   | 0×0         | BE<br>Frame Burst Enable<br>When this bit is set, the MAC allows frame bursting during<br>transmission in GMII Half-Duplex mode                                                                                                                                                                                                                                                                                                         |  |  |
| 20    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| 19:17 | RW   | 0×0         | IFG<br>Inter-Frame Gap<br>These bits control the minimum IFG between frames during<br>transmission.<br>3'b000: 96 bit times<br>3'b001: 88 bit times<br>3'b010: 80 bit times<br><br>3'b111: 40 bit times                                                                                                                                                                                                                                 |  |  |
| 16    | RW   | 0x0         | DCRS<br>Disable Carrier Sense During Transmission<br>When set high, this bit makes the MAC transmitter ignore the<br>(G)MII CRS signal during frame transmission in Half-Duplex<br>mode. This request results in no errors generated due to Loss of<br>Carrier or No Carrier during such transmission. When this bit is<br>low, the MAC transmitter generates such errors due to Carrier<br>Sense and will even abort the transmissions |  |  |
| 15    | RW   | 0×0         | PS<br>Port Select<br>Selects between GMII and MII:<br>1'b0: GMII (1000 Mbps)<br>1'b1: MII (10/100 Mbps)                                                                                                                                                                                                                                                                                                                                 |  |  |

| Bit | Attr | Reset Value | Description                                                         |
|-----|------|-------------|---------------------------------------------------------------------|
|     |      |             | FES                                                                 |
|     |      |             | Speed                                                               |
| 14  | l RW | 0x0         | Indicates the speed in Fast Ethernet (MII) mode:                    |
|     |      |             | 1'b0: 10 Mbps                                                       |
|     |      |             | 1'b1: 100 Mbps                                                      |
|     |      |             | DO                                                                  |
|     |      |             | Disable Receive Own                                                 |
| 13  | RW   | 0x0         | When this bit is set, the MAC disables the reception of frames      |
| 15  |      | 0.00        | when the gmii_txen_o is asserted in Half-Duplex mode.               |
|     |      |             | When this bit is reset, the MAC receives all packets that are given |
|     |      |             | by the PHY while transmitting                                       |
|     |      |             | LM                                                                  |
|     |      |             | Loopback Mode                                                       |
| 12  | RW   | 0x0         | When this bit is set, the MAC operates in loopback mode at          |
| 12  |      | 0,0         | GMII/MII. The (G)MII Receive clock input (clk_rx_i) is required     |
|     |      |             | for the loopback to work properly, as the Transmit clock is not     |
|     |      |             | looped-back internally                                              |
|     |      |             | DM                                                                  |
|     |      |             | Duplex Mode                                                         |
| 11  | RW   | 0x0         | When this bit is set, the MAC operates in a Full-Duplex mode        |
|     |      |             | where it can transmit and receive simultaneously. This bit is RO    |
|     |      |             | with default value of 1'b1 in Full-Duplex-only configuration        |
|     |      |             | IPC                                                                 |
|     |      |             | Checksum Offload                                                    |
|     |      |             | When this bit is set, the MAC calculates the 16-bit one's           |
|     |      |             | complement of the one's complement sum of all received              |
|     |      |             | Ethernet frame payloads. It also checks whether the IPv4 Header     |
|     |      |             | checksum (assumed to be bytes 25-26 or 29-30 (VLAN-tagged)          |
|     |      |             | of the received Ethernet frame) is correct for the received frame   |
|     |      |             | and gives the status in the receive status word. The MAC core       |
| 10  | RW   | 0x0         | also appends the 16-bit checksum calculated for the IP header       |
|     |      |             | datagram payload (bytes after the IPv4 header) and appends it       |
|     |      |             | to the Ethernet frame transferred to the application (when Type 2   |
|     |      |             | COE is deselected).                                                 |
|     |      |             | When this bit is reset, this function is disabled.                  |
|     |      |             | When Type 2 COE is selected, this bit, when set, enables IPv4       |
|     |      |             | checksum checking for received frame payloads TCP/UDP/ICMP          |
|     |      |             | headers. When this bit is reset, the COE function in the receiver   |
|     |      |             | is disabled and the corresponding PCE and IP HCE status bits are    |
|     |      |             | always cleared                                                      |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | RW   | 0×0                | DR<br>Disable Retry<br>When this bit is set, the MAC will attempt only 1 transmission.<br>When a collision occurs on the GMII/MII, the MAC will ignore the<br>current frame transmission and report a Frame Abort with<br>excessive collision error in the transmit frame status.<br>When this bit is reset, the MAC will attempt retries based on the<br>settings of BL                                                                                                                                                                                                                                   |
| 8   | RW   | 0×0                | LUD<br>Link Up/Down<br>Indicates whether the link is up or down during the transmission<br>of configuration in RGMII interface:<br>1'b0: Link Down<br>1'b1: Link Up                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7   | RW   | 0×0                | ACS<br>Automatic Pad/CRC Stripping<br>When this bit is set, the MAC strips the Pad/FCS field on incoming<br>frames only if the length's field value is less than or equal to<br>1,500 bytes. All received frames with length field greater than or<br>equal to 1,501 bytes are passed to the application without<br>stripping the Pad/FCS field.<br>When this bit is reset, the MAC will pass all incoming frames to<br>the Host unmodified                                                                                                                                                                |
| 6:5 | RW   | 0×0                | BL<br>Back-Off Limit<br>The Back-Off limit determines the random integer number (r) of<br>slot time delays (4,096 bit times for 1000 Mbps and 512 bit times<br>for 10/100 Mbps) the MAC waits before rescheduling a<br>transmission attempt during retries after a collision. This bit is<br>applicable only to Half-Duplex mode and is reserved (RO) in Full-<br>Duplex-only configuration.<br>2'b00: k = min (n, 10)<br>2'b01: k = min (n, 8)<br>2'b10: k = min (n, 4)<br>2'b11: k = min (n, 1),<br>Where n = retransmission attempt. The random integer r takes<br>the value in the range 0 = $r < 2^k$ |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | RW   | 0×0         | DC<br>Deferral Check<br>When this bit is set, the deferral check function is enabled in the<br>MAC. The MAC will issue a Frame Abort status, along with the<br>excessive deferral error bit set in the transmit frame status when<br>the transmit state machine is deferred for more than 24,288 bit<br>times in 10/100-Mbps mode. If the Core is configured for 1000<br>Mbps operation, the threshold for deferral is 155,680 bits times.<br>Deferral begins when the transmitter is ready to transmit, but is<br>prevented because of an active CRS (carrier sense) signal on the<br>GMII/MII. Defer time is not cumulative. If the transmitter defers<br>for 10,000 bit times, then transmits, collides, backs off, and then<br>has to defer again after completion of back-off, the deferral timer<br>resets to 0 and restarts.<br>When this bit is reset, the deferral check function is disabled and<br>the MAC defers until the CRS signal goes inactive |
| 3   | RW   | 0×0         | TE<br>Transmitter Enable<br>When this bit is set, the transmit state machine of the MAC is<br>enabled for transmission on the GMII/MII. When this bit is reset,<br>the MAC transmit state machine is disabled after the completion<br>of the transmission of the current frame, and will not transmit<br>any further frames                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2   | RW   | 0×0         | RE<br>Receiver Enable<br>When this bit is set, the receiver state machine of the MAC is<br>enabled for receiving frames from the GMII/MII. When this bit is<br>reset, the MAC receive state machine is disabled after the<br>completion of the reception of the current frame, and will not<br>receive any further frames from the GMII/MII                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1:0 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

# MAC MAC FRM FILT

Address: Operational Base + offset (0x0004)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0×0                | RA<br>Receive All<br>When this bit is set, the MAC Receiver module passes to the<br>Application all frames received irrespective of whether they pass<br>the address filter. The result of the SA/DA filtering is updated<br>(pass or fail) in the corresponding bits in the Receive Status<br>Word. When this bit is reset, the Receiver module passes to the<br>Application only those frames that pass the SA/DA address filter |
| 30:11 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10  | RW   | 0×0         | HPF<br>Hash or Perfect Filter<br>When set, this bit configures the address filter to pass a frame if<br>it matches either the perfect filtering or the hash filtering as set<br>by HMC or HUC bits. When low and if the HUC/HMC bit is set, the<br>frame is passed only if it matches the Hash filter                                                                                                                                                                                                                                                                                                                           |
| 9   | RW   | 0x0         | SAF<br>Source Address Filter Enable<br>The MAC core compares the SA field of the received frames with<br>the values programmed in the enabled SA registers. If the<br>comparison matches, then the SAMatch bit of RxStatus Word is<br>set high. When this bit is set high and the SA filter fails, the MAC<br>drops the frame.<br>When this bit is reset, then the MAC Core forwards the received<br>frame to the application and with the updated SA Match bit of the<br>RxStatus depending on the SA address comparison                                                                                                       |
| 8   | RW   | 0×0         | SAIF<br>SA Inverse Filtering<br>When this bit is set, the Address Check block operates in inverse<br>filtering mode for the SA address comparison. The frames whose<br>SA matches the SA registers will be marked as failing the SA<br>Address filter.<br>When this bit is reset, frames whose SA does not match the SA<br>registers will be marked as failing the SA Address filter                                                                                                                                                                                                                                            |
| 7:6 | RW   | 0×0         | PCF<br>Pass Control Frames<br>These bits control the forwarding of all control frames (including<br>unicast and multicast PAUSE frames). Note that the processing of<br>PAUSE control frames depends only on RFE of Register<br>MAC_FLOW_CTRL[2].<br>2'b00: MAC filters all control frames from reaching the<br>application.<br>2'b01: MAC forwards all control frames except PAUSE control<br>frames to application even if they fail the Address filter.<br>2'b10: MAC forwards all control frames to application even if they<br>fail the Address Filter.<br>2'b11: MAC forwards control frames that pass the Address Filter |
| 5   | RW   | 0×0         | DBF<br>Disable Broadcast Frames<br>When this bit is set, the AFM module filters all incoming<br>broadcast frames.<br>When this bit is reset, the AFM module passes all received<br>broadcast frames                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Bit | Attr | Reset Value | Description                                                          |
|-----|------|-------------|----------------------------------------------------------------------|
|     |      |             | РМ                                                                   |
|     |      |             | Pass All Multicast                                                   |
| 1   | RW   | 0x0         | When set, this bit indicates that all received frames with a         |
| 4   | RW   | UXU         | multicast destination address (first bit in the destination address  |
|     |      |             | field is '1') are passed.                                            |
|     |      |             | When reset, filtering of multicast frame depends on HMC bit          |
|     |      |             | DAIF                                                                 |
|     |      |             | DA Inverse Filtering                                                 |
| 3   | RW   | 0x0         | When this bit is set, the Address Check block operates in inverse    |
| 5   |      | 0.00        | filtering mode for the DA address comparison for both unicast        |
|     |      |             | and multicast frames.                                                |
|     |      |             | When reset, normal filtering of frames is performed                  |
|     |      |             | НМС                                                                  |
|     |      | 0×0         | Hash Multicast                                                       |
|     |      |             | When set, MAC performs destination address filtering of received     |
| 2   | RW   |             | multicast frames according to the hash table.                        |
|     |      |             | When reset, the MAC performs a perfect destination address           |
|     |      |             | filtering for multicast frames, that is, it compares the DA field    |
|     |      |             | with the values programmed in DA registers                           |
|     |      |             | HUC                                                                  |
|     |      |             | Hash Unicast                                                         |
|     |      | 0×0         | When set, MAC performs destination address filtering of unicast      |
| 1   | RW   |             | frames according to the hash table.                                  |
|     |      |             | When reset, the MAC performs a perfect destination address           |
|     |      |             | filtering for unicast frames, that is, it compares the DA field with |
|     |      |             | the values programmed in DA registers                                |
|     |      |             | PR<br>Deservices Made                                                |
|     |      |             | Promiscuous Mode                                                     |
| 0   | RW   | 0x0         | When this bit is set, the Address Filter module passes all           |
|     |      |             | incoming frames regardless of its destination or source address.     |
|     |      |             | The SA/DA Filter Fails status bits of the Receive Status Word will   |
|     |      |             | always be cleared when PR is set                                     |

# MAC HASH TAB HI

Address: Operational Base + offset (0x0008)

| Bit  | Attr | <b>Reset Value</b> | Description                                         |
|------|------|--------------------|-----------------------------------------------------|
|      |      |                    | НТН                                                 |
| 31:0 | RW   | 0x00000000         | Hash Table High                                     |
|      |      |                    | This field contains the upper 32 bits of Hash table |

MAC HASH TAB LO Address: Operational Base + offset (0x000c)

| Bit    | Attr   | <b>Reset Value</b> | Description                                                     |
|--------|--------|--------------------|-----------------------------------------------------------------|
|        |        |                    | HTL                                                             |
| 31:0   | RW     | 0x00000000         | Hash Table Low                                                  |
|        |        |                    | This field contains the lower 32 bits of Hash table             |
|        |        | ADDR               |                                                                 |
| Addres | ss: Op | perational Base    | + offset (0x0010)                                               |
| Bit    | Attr   | <b>Reset Value</b> | Description                                                     |
| 31:16  | RO     | 0x0                | reserved                                                        |
|        |        | w 0×00             | РА                                                              |
| 15:11  |        |                    | Physical Layer Address                                          |
| 12:11  | RW     |                    | This field tells which of the 32 possible PHY devices are being |
|        |        |                    | accessed                                                        |
|        |        |                    | GR                                                              |
| 10.0   |        | W 0x00             | GMII Register                                                   |
| 10:6   | RW     |                    | These bits select the desired GMII register in the selected PHY |
|        |        |                    | device                                                          |

| Bit        | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b> | Attr | Reset Value | CR<br>APB Clock Range<br>The APB Clock Range selection determines the frequency of the<br>MDC clock as per the pclk_MAC frequency used in your design.<br>The suggested range of pclk_MAC frequency applicable for each<br>value below (when Bit[5] = 0) ensures that the MDC clock is<br>approximately between the frequency range 1.0 MHz - 2.5 MHz.<br>Selection pclk_MAC MDC Clock<br>0000 60-100 MHz pclk_MAC/42<br>0001 100-150 MHz pclk_MAC/62<br>0010 20-35 MHz pclk_MAC/16<br>0011 35-60 MHz pclk_MAC/16<br>0101 250-300 MHz pclk_MAC/102<br>0101 250-300 MHz pclk_MAC/124<br>0110, 0111 Reserved<br>When bit 5 is set, you can achieve MDC clock of frequency higher<br>than the IEEE 802.3 specified frequency limit of 2.5 MHz and<br>program a clock divider of lower value. For example, when<br>pclk_MAC is of frequency 100 MHz and you program these bits as<br>"1010", then the resultant MDC clock will be of 12.5 MHz which is<br>outside the limit of IEEE 802.3 specified range. Please program<br>the values given below only if the interfacing chips supports<br>faster MDC clocks.<br>Selection MDC Clock<br>1000 pclk_MAC/4<br>1001 pclk_MAC/6 |
|            |      |             | 1001       pclk_MAC/6         1010       pclk_MAC/8         1011       pclk_MAC/10         1100       pclk_MAC/12         1101       pclk_MAC/14         1101       pclk_MAC/14         1110       pclk_MAC/16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1          | RW   | 0x0         | 1111pclk_MAC/18GWGMII WriteWhen set, this bit tells the PHY that this will be a Write operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            |      |             | using register MAC_GMII_DATA. If this bit is not set, this will be a<br>Read operation, placing the data in register MAC_GMII_DATA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Bit | Attr    | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|---------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | W1<br>C | 0×0                | GB<br>GMII Busy<br>This bit should read a logic 0 before writing to Register<br>GMII_ADDR and Register GMII_DATA. This bit must also be set to<br>0 during a Write to Register GMII_ADDR. During a PHY register<br>access, this bit will be set to 1'b1 by the Application to indicate<br>that a Read or Write access is in progress. Register GMII_DATA<br>(GMII Data) should be kept valid until this bit is cleared by the<br>MAC during a PHY Write operation. The Register GMII_DATA is<br>invalid until this bit is cleared by the MAC during a PHY Read<br>operation. The Register GMII_ADDR (GMII Address) should not<br>be written to until this bit is cleared |

**MAC GMII DATA** Address: Operational Base + offset (0x0014)

| Bit   | Attr | <b>Reset Value</b> | Description                                                   |
|-------|------|--------------------|---------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                      |
|       |      |                    | GD                                                            |
|       |      |                    | GMII Data                                                     |
| 15:0  | RW   | 0x0000             | This contains the 16-bit data value read from the PHY after a |
|       |      |                    | Management Read operation or the 16-bit data value to be      |
|       |      |                    | written to the PHY before a Management Write operation        |

# MAC\_FLOW\_CTRL

Address: Operational Base + offset (0x0018)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000             | PT<br>Pause Time<br>This field holds the value to be used in the Pause Time field in the<br>transmit control frame. If the Pause Time bits is configured to be<br>double-synchronized to the (G)MII clock domain, then<br>consecutive writes to this register should be performed only after<br>at least 4 clock cycles in the destination clock domain                                                        |
| 15:8  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7     | RW   | 0×0                | DZPQ<br>Disable Zero-Quanta Pause<br>When set, this bit disables the automatic generation of Zero-<br>Quanta Pause Control frames on the de-assertion of the flow-<br>control signal from the FIFO layer (MTL or external sideband flow<br>control signal sbd_flowctrl_i/mti_flowctrl_i).<br>When this bit is reset, normal operation with automatic Zero-<br>Quanta Pause Control frame generation is enabled |
| 6     | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                       |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:4 | RW   | 0×0                | PLT<br>Pause Low Threshold<br>This field configures the threshold of the PAUSE timer at which<br>the input flow control signal mti_flowctrl_i (or sbd_flowctrl_i) is<br>checked for automatic retransmission of PAUSE Frame. The<br>threshold values should be always less than the Pause Time<br>configured in Bits[31:16]. For example, if PT = 100H (256 slot-<br>times), and PLT = 01, then a second PAUSE frame is<br>automatically transmitted if the mti_flowctrl_i signal is asserted<br>at 228 (256-28) slot-times after the first PAUSE frame is<br>transmitted.<br>Selection Threshold<br>00 Pause time minus 4 slot times<br>10 Pause time minus 144 slot times<br>11 Pause time minus 256 slot times<br>Slot time is defined as time taken to transmit 512 bits (64 bytes)<br>on the GMII/MII interface |
| 3   | RW   | 0×0                | UP<br>Unicast Pause Frame Detect<br>When this bit is set, the MAC will detect the Pause frames with<br>the station's unicast address specified in MAC Address0 High<br>Register and MAC Address0 Low Register, in addition to the<br>detecting Pause frames with the unique multicast address. When<br>this bit is reset, the MAC will detect only a Pause frame with the<br>unique multicast address specified in the 802.3x standard                                                                                                                                                                                                                                                                                                                                                                               |
| 2   | RW   | 0x0                | RFE<br>Receive Flow Control Enable<br>When this bit is set, the MAC will decode the received Pause<br>frame and disable its transmitter for a specified (Pause Time)<br>time. When this bit is reset, the decode function of the Pause<br>frame is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1   | RW   | 0×0                | TFE<br>Transmit Flow Control Enable<br>In Full-Duplex mode, when this bit is set, the MAC enables the<br>flow control operation to transmit Pause frames. When this bit is<br>reset, the flow control operation in the MAC is disabled, and the<br>MAC will not transmit any Pause frames.<br>In Half-Duplex mode, when this bit is set, the MAC enables the<br>back-pressure operation. When this bit is reset, the backpressure<br>feature is disabled                                                                                                                                                                                                                                                                                                                                                             |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   |      | 0×0                | FCB_BPA<br>Flow Control Busy/Backpressure Activate<br>This bit initiates a Pause Control frame in Full-Duplex mode and<br>activates the backpressure function in Half-Duplex mode if TFE<br>bit is set.<br>In Full-Duplex mode, this bit should be read as 1'b0 before<br>writing to the register MAC_FLOW_CTRL. To initiate a pause<br>control frame, the application must set this bit to 1'b1. During a<br>transfer of the control frame, this bit will continue to be set to<br>signify that a frame transmission is in progress. After the<br>completion of Pause control frame transmission, the MAC will<br>reset this bit to 1'b0. The register MAC_FLOW_CTRL should not<br>be written to until this bit is cleared.<br>In Half-Duplex mode, when this bit is set (and TFE is set), then<br>backpressure is asserted by the MAC Core. During backpressure,<br>when the MAC receives a new frame, the transmitter starts<br>sending a JAM pattern resulting in a collision. This control register<br>bit is logically OR'ed with the mti_flowctrl_i input signal for the<br>backpressure function |

MAC\_VLAN\_TAG Address: Operational Base + offset (0x001c)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 16    | RW   | 0x0         | ETV<br>Enable 12-Bit VLAN Tag Comparison<br>When this bit is set, a 12-bit VLAN identifier, rather than the<br>complete 16-bit VLAN tag, is used for comparison and filtering.<br>Bits[11:0] of the VLAN tag are compared with the corresponding<br>field in the received VLAN-tagged frame.<br>When this bit is reset, all 16 bits of the received VLAN frame's<br>fifteenth and sixteenth bytes are used for comparison                                                                                                                                                                                                                                                        |
| 15:0  | RW   | 0×0000      | VL<br>VLAN Tag Identifier for Receive Frames<br>This contains the 802.1Q VLAN tag to identify VLAN frames, and<br>is compared to the fifteenth and sixteenth bytes of the frames<br>being received for VLAN frames. Bits[15:13] are the User Priority,<br>Bit[12] is the Canonical Format Indicator (CFI) and bits[11:0] are<br>the VLAN tag's VLAN Identifier (VID) field. When the ETV bit is<br>set, only the VID (Bits[11:0]) is used for comparison.<br>If VL (VL[11:0] if ETV is set) is all zeros, the MAC does not check<br>the fifteenth and sixteenth bytes for VLAN tag comparison, and<br>declares all frames with a Type field value of 0x8100 to be VLAN<br>frames |

# MAC\_DEBUG

| Address: Operational | Base + offset | (0x0024) |
|----------------------|---------------|----------|
|----------------------|---------------|----------|

| Bit   |            | Reset Value | + offset (0x0024) Description                                     |
|-------|------------|-------------|-------------------------------------------------------------------|
| 31:26 |            | 0x0         | reserved                                                          |
| 51.20 | itto       | 0,0         | TFIFO3                                                            |
|       |            |             | When high, it indicates that the MTL TxStatus FIFO is full and    |
| 25    | RW         | 0x0         | hence the MTL will not be accepting any more frames for           |
|       |            |             | transmission                                                      |
|       |            |             | TFIFO2                                                            |
| 24    | RW         | 0x0         | When high, it indicates that the MTL TxFIFO is not empty and has  |
|       |            |             | some data left for transmission                                   |
| 23    | RO         | 0x0         | reserved                                                          |
|       |            |             | TFIF01                                                            |
| 22    | RW         | 0x0         | When high, it indicates that the MTL TxFIFO Write Controller is   |
|       |            |             | active and transferring data to the TxFIFO                        |
|       |            |             | TFIFOSTA                                                          |
|       |            |             | This indicates the state of the TxFIFO read Controller:           |
| 21 20 | D.4/       |             | 2'b00: IDLE state                                                 |
| 21:20 | RW         | 0x0         | 2'b01: READ state (transferring data to MAC transmitter)          |
|       |            |             | 2'b10: Waiting for TxStatus from MAC transmitter                  |
|       |            |             | 2'b11: Writing the received TxStatus or flushing the TxFIFO       |
|       |            |             | PAUSE                                                             |
| 10    |            | 00          | When high, it indicates that the MAC transmitter is in PAUSE      |
| 19    | RW         | 0×0         | condition (in full-duplex only) and hence will not schedule any   |
|       |            |             | frame for transmission                                            |
|       |            |             | TSAT                                                              |
|       |            |             | This indicates the state of the MAC Transmit Frame Controller     |
|       |            |             | module:                                                           |
|       |            |             | 2'b00: IDLE                                                       |
| 18:17 | RW         | 0x0         | 2'b01: Waiting for Status of previous frame or IFG/backoff period |
|       |            |             | to be over                                                        |
|       |            |             | 2'b10: Generating and transmitting a PAUSE control frame (in full |
|       |            |             | duplex mode)                                                      |
|       |            |             | 2'b11: Transferring input frame for transmission                  |
|       |            |             | ТАСТ                                                              |
| 16    | RW         | 0x0         | When high, it indicates that the MAC GMII/MII transmit protocol   |
|       |            |             | engine is actively transmitting data and not in IDLE state        |
| 15:10 | RO         | 0x0         | reserved                                                          |
|       |            |             | RFIFO                                                             |
|       |            |             | This gives the status of the RxFIFO Fill-level:                   |
| 9:8   | RW         | 0x0         | 2'b00: RxFIFO Empty                                               |
| -     |            |             | 2'b01: RxFIFO fill-level below flow-control de-activate threshold |
|       |            |             | 2'b10: RxFIFO fill-level above flow-control activate threshold    |
| _     | <b>D O</b> |             | 2'b11: RxFIFO Full                                                |
| 7     | RO         | 0x0         | reserved                                                          |

| Bit | Attr | Reset Value | Description                                                     |
|-----|------|-------------|-----------------------------------------------------------------|
|     |      |             | RFIFORD                                                         |
|     |      |             | It gives the state of the RxFIFO read Controller:               |
| 6:5 | RW   | 0×0         | 2'b00: IDLE state                                               |
| 0.5 |      | 0.00        | 2'b01: Reading frame data                                       |
|     |      |             | 2'b10: Reading frame status (or time-stamp)                     |
|     |      |             | 2'b11: Flushing the frame data and Status                       |
|     |      |             | RFIFOWR                                                         |
| 4   | RW   | 0×0         | When high, it indicates that the MTL RxFIFO Write Controller is |
|     |      |             | active and transferring a received frame to the FIFO            |
| 3   | RO   | 0x0         | reserved                                                        |
|     |      |             | ACT                                                             |
| 2.1 | RW   | 0.40        | When high, it indicates the active state of the small FIFO Read |
| 2:1 | K VV | W 0×0       | and Write controllers respectively of the MAC receive Frame     |
|     |      |             | Controller module                                               |
|     |      |             | RDB                                                             |
| 0   | RW   | / 0x0       | When high, it indicates that the MAC GMII/MII receive protocol  |
|     |      |             | engine is actively receiving data and not in IDLE state         |

MAC PMT CTRL STA Address: Operational Base + offset (0x002c)

| Bit   | Attr    | <b>Reset Value</b> | Description                                                                                                                                                                                        |
|-------|---------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | W1<br>C | 0×0                | WFFRPR<br>Wake-Up Frame Filter Register Pointer Reset<br>When set, resets the Remote Wake-up Frame Filter register                                                                                 |
|       | )       |                    | pointer to 3'b000. It is automatically cleared after 1 clock cycle                                                                                                                                 |
| 30:10 | RO      | 0x0                | reserved                                                                                                                                                                                           |
| 9     | RW      | 0×0                | GU<br>Global Unicast<br>When set, enables any unicast packet filtered by the MAC (DAF)<br>address recognition to be a wake-up frame                                                                |
| 8:7   | RO      | 0x0                | reserved                                                                                                                                                                                           |
| 6     | RC      | 0×0                | WFR<br>Wake-Up Frame Received<br>When set, this bit indicates the power management event was<br>generated due to reception of a wake-up frame. This bit is<br>cleared by a read into this register |
| 5     | RC      | 0×0                | MPR<br>Magic Packet Received<br>When set, this bit indicates the power management event was<br>generated by the reception of a Magic Packet. This bit is cleared<br>by a read into this register   |
| 4:3   | RO      | 0x0                | reserved                                                                                                                                                                                           |

| Bit | Attr | Reset Value | Description                                                          |
|-----|------|-------------|----------------------------------------------------------------------|
|     |      |             | WFE                                                                  |
| 2   | RW   | 0×0         | Wake-Up Frame Enable                                                 |
| 2   | r vv | 0.00        | When set, enables generation of a power management event due         |
|     |      |             | to wake-up frame reception                                           |
|     |      |             | MPE                                                                  |
| 1   | RW   | 0x0         | Magic Packet Enable                                                  |
| 1   |      | 0.00        | When set, enables generation of a power management event due         |
|     |      |             | to Magic Packet reception                                            |
|     |      |             | PD                                                                   |
|     |      |             | Power Down                                                           |
|     |      |             | When set, all received frames will be dropped. This bit is cleared   |
| 0   | R/W  | 0x0         | automatically when a magic packet or Wake-Up frame is                |
| U   | SC   | SC UXU      | received, and Power-Down mode is disabled. Frames received           |
|     |      |             | after this bit is cleared are forwarded to the application. This bit |
|     |      |             | must only be set when either the Magic Packet Enable or Wake-        |
|     |      |             | Up Frame Enable bit is set high                                      |

# MAC\_INT\_STATUS

Address: Operational Base + offset (0x0038)

| Bit  | Attr | <b>Reset Value</b> | Description                                                           |
|------|------|--------------------|-----------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                              |
|      |      |                    | MRCOIS                                                                |
|      |      |                    | MMC Receive Checksum Offload Interrupt Status                         |
| 7    | RO   | 0x0                | This bit is set high whenever an interrupt is generated in the MMC    |
|      |      |                    | Receive Checksum Offload Interrupt Register. This bit is cleared      |
|      |      |                    | when all the bits in this interrupt register are cleared              |
|      |      |                    | MTIS                                                                  |
|      |      |                    | MMC Transmit Interrupt Status                                         |
| 6    | RO   | 0x0                | This bit is set high whenever an interrupt is generated in the MMC    |
| Ŭ    |      | 0.00               | Transmit Interrupt Register. This bit is cleared when all the bits in |
|      |      |                    | this interrupt register are cleared. This bit is only valid when the  |
|      |      |                    | optional MMC module is selected during configuration                  |
|      |      |                    | MRIS                                                                  |
|      |      | RO 0x0             | MMC Receive Interrupt Status                                          |
| 5    | RO   |                    | This bit is set high whenever an interrupt is generated in the MMC    |
| 5    |      |                    | Receive Interrupt Register. This bit is cleared when all the bits in  |
|      |      |                    | this interrupt register are cleared. This bit is only valid when the  |
|      |      |                    | optional MMC module is selected during configuration                  |
|      |      |                    | MIS                                                                   |
|      |      | O 0x0              | MMC Interrupt Status                                                  |
| 4    | RO   |                    | This bit is set high whenever any of bits 7:5 is set high and         |
|      |      |                    | cleared only when all of these bits are low. This bit is valid only   |
|      |      |                    | when the optional MMC module is selected during configuration         |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                    |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RO   | 0×0                | PIS<br>PMT Interrupt Status<br>This bit is set whenever a Magic packet or Wake-on-LAN frame is<br>received in Power-Down mode). This bit is cleared when both<br>bits[6:5] are cleared due to a read operation to the register |
| 2:1 | RO   | 0x0                | MAC_PMT_CTRL_STA reserved                                                                                                                                                                                                      |
| 0   | RO   | 0×0                | RIS<br>RGMII Interrupt Status<br>This bit is set due to any change in value of the Link Status of<br>RGMII interface. This bit is cleared when the user makes a read<br>operation the RGMII Status register                    |

# MAC INT MASK

Address: Operational Base + offset (0x003c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                           |
|------|------|--------------------|-----------------------------------------------------------------------|
| 31:4 | RO   | 0x0                | reserved                                                              |
|      |      |                    | PIM                                                                   |
|      |      |                    | PMT Interrupt Mask                                                    |
| 3    | RW   | 0x0                | This bit when set, will disable the assertion of the interrupt signal |
|      |      |                    | due to the setting of PMT Interrupt Status bit in Register            |
|      |      |                    | MAC_INT_STATUS                                                        |
| 2:1  | RO   | 0x0                | reserved                                                              |
|      |      |                    | RIM                                                                   |
|      |      |                    | RGMII Interrupt Mask                                                  |
| 0    | RW   | 0x0                | This bit when set, will disable the assertion of the interrupt signal |
|      |      |                    | due to the setting of RGMII Interrupt Status bit in Register          |
|      |      |                    | MAC_INT_STATUS                                                        |

# MAC MAC ADDRO HI

Address: Operational Base + offset (0x0040)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                        |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                           |
| 15:0  | RW   | 0xffff             | A47_A32<br>MAC Address0 [47:32]<br>This field contains the upper 16 bits (47:32) of the 6-byte first<br>MAC address. This is used by the MAC for filtering for received<br>frames and for inserting the MAC address in the Transmit Flow<br>Control (PAUSE) Frames |

## MAC MAC ADDRO LO

Address: Operational Base + offset (0x0044)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0xffffffff         | A31_A0<br>MAC Address0 [31:0]<br>This field contains the lower 32 bits of the 6-byte first MAC<br>address. This is used by the MAC for filtering for received frames<br>and for inserting the MAC address in the Transmit Flow Control<br>(PAUSE) Frames |

# MAC AN CTRL

Address: Operational Base + offset (0x00c0)

| Bit   | Attr   | <b>Reset Value</b> | Description                                                         |
|-------|--------|--------------------|---------------------------------------------------------------------|
| 31:13 | RO     | 0x0                | reserved                                                            |
|       |        |                    | ANE                                                                 |
|       |        |                    | Auto-Negotiation Enable                                             |
| 12    | RW     | 0x0                | When set, will enable the MAC to perform auto-negotiation with      |
|       |        |                    | the link partner.                                                   |
|       |        |                    | Clearing this bit will disable auto-negotiation                     |
| 11:10 | RO     | 0x0                | reserved                                                            |
|       |        | R/W<br>SC 0x0      | RAN                                                                 |
|       | D /\\/ |                    | Restart Auto-Negotiation                                            |
| 9     |        |                    | When set, will cause auto-negotiation to restart if the ANE is set. |
|       | SC     |                    | This bit is self-clearing after auto-negotiation starts. This bit   |
|       |        |                    | should be cleared for normal operation                              |
| 8:0   | RO     | 0x0                | reserved                                                            |

## MAC AN STATUS

Address: Operational Base + offset (0x00c4)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                  |
|------|------|--------------------|------------------------------------------------------------------------------|
| 31:6 | RO   | 0x0                | reserved                                                                     |
|      |      |                    | ANC                                                                          |
|      |      |                    | Auto-Negotiation Complete                                                    |
| 5    | RO   | 0×0                | When set, this bit indicates that the auto-negotiation process is completed. |
|      |      |                    | This bit is cleared when auto-negotiation is reinitiated                     |
| 4    | RO   | 0x0                | reserved                                                                     |
|      |      | 0 0x1              | ANA                                                                          |
| 3    | RO   |                    | Auto-Negotiation Ability                                                     |
| 2    | ĸŬ   |                    | This bit is always high, because the MAC supports auto-                      |
|      |      |                    | negotiation                                                                  |
|      |      | 0x0                | LS                                                                           |
| 2    | R/W  |                    | Link Status                                                                  |
| Z    | SC   |                    | When set, this bit indicates that the link is up. When cleared, this         |
|      |      |                    | bit indicates that the link is down                                          |
| 1:0  | RO   | 0x0                | reserved                                                                     |

# MAC AN ADV

Address: Operational Base + offset (0x00c8)

| Bit   | Attr    | <b>Reset Value</b> | Description                                                        |
|-------|---------|--------------------|--------------------------------------------------------------------|
| 31:16 | RO      | 0x0                | reserved                                                           |
|       |         |                    | NP                                                                 |
| 15    | RO      | 0x0                | Next Page Support                                                  |
| 15    | ĸŪ      | UXU                | This bit is tied to low, because the MAC does not support the next |
|       |         |                    | page                                                               |
| 14    | RO      | 0x0                | reserved                                                           |
|       |         |                    | RFE                                                                |
| 13:12 | DW/     | 0x0                | Remote Fault Encoding                                              |
| 13.12 | RVV     | 0.00               | These 2 bits provide a remote fault encoding, indicating to a link |
|       |         |                    | partner that a fault or error condition has occurred               |
| 11:9  | RO      | 0x0                | reserved                                                           |
|       |         | 0x3                | PSE                                                                |
|       |         |                    | Pause Encoding                                                     |
| 8:7   | RW      |                    | These 2 bits provide an encoding for the PAUSE bits, indicating    |
|       |         |                    | that the MAC is capable of configuring the PAUSE function as       |
|       |         |                    | defined in IEEE 802.3x                                             |
|       |         |                    | HD                                                                 |
|       |         |                    | Half-Duplex                                                        |
| 6     | RW      | 0x1                | This bit, when set high, indicates that the MAC supports Half-     |
|       |         |                    | Duplex. This bit is tied to low (and RO) when the MAC is           |
|       |         |                    | configured for Full-Duplex-only operation                          |
|       |         |                    | FD                                                                 |
| 5     | RW      | W 0×1              | Full-Duplex                                                        |
| 5     | 1 \ V V |                    | This bit, when set high, indicates that the MAC supports Full-     |
|       |         |                    | Duplex                                                             |
| 4:0   | RO      | 0x0                | reserved                                                           |

# MAC AN LINK PART AB

Address: Operational Base + offset (0x00cc)

| Bit   | Attr | <b>Reset Value</b> | Description                                                        |
|-------|------|--------------------|--------------------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                           |
|       |      |                    | NP                                                                 |
|       |      |                    | Next Page Support                                                  |
| 15    | RO   | 0×0                | When set, this bit indicates that more next page information is    |
| 13    | κυ   | 0.00               | available.                                                         |
|       |      |                    | When cleared, this bit indicates that next page exchange is not    |
|       |      |                    | desired                                                            |
|       |      | 0×0                | АСК                                                                |
|       |      |                    | Acknowledge                                                        |
| 14    | RO   |                    | When set, this bit is used by the auto-negotiation function to     |
| 14    | κυ   |                    | indicate that the link partner has successfully received the MAC's |
|       |      |                    | base page. When cleared, it indicates that a successful receipt of |
|       |      |                    | the base page has not been achieved                                |

| Bit   | Attr | Reset Value | Description                                                           |
|-------|------|-------------|-----------------------------------------------------------------------|
|       |      |             | RFE                                                                   |
| 13:12 | PO   | 0x0         | Remote Fault Encoding                                                 |
| 13.12 | ĸo   | 0.0         | These 2 bits provide a remote fault encoding, indicating a fault or   |
|       |      |             | error condition of the link partner                                   |
| 11:9  | RO   | 0x0         | reserved                                                              |
|       |      |             | PSE                                                                   |
|       |      |             | Pause Encoding                                                        |
| 8:7   | RO   | 0x0         | These 2 bits provide an encoding for the PAUSE bits, indicating       |
|       |      |             | that the link partner's capability of configuring the PAUSE           |
|       |      |             | function as defined in IEEE 802.3x                                    |
|       |      |             | HD                                                                    |
|       |      |             | Half-Duplex                                                           |
| 6     | RO   | 0x0         | When set, this bit indicates that the link partner has the ability to |
|       |      |             | operate in Half-Duplex mode. When cleared, the link partner does      |
|       |      |             | not have the ability to operate in Half-Duplex mode                   |
|       |      |             | FD                                                                    |
|       |      |             | Full-Duplex                                                           |
| 5     | RO   | 0x0         | When set, this bit indicates that the link partner has the ability to |
|       |      |             | operate in Full-Duplex mode. When cleared, the link partner does      |
|       |      |             | not have the ability to operate in Full-Duplex mode                   |
| 4:0   | RO   | 0x0         | reserved                                                              |

## MAC\_AN\_EXP

Address: Operational Base + offset (0x00d0)

| Bit      | Attr | <b>Reset Value</b> | Description                                                       |
|----------|------|--------------------|-------------------------------------------------------------------|
| 31:3     | RO   | 0x0                | reserved                                                          |
|          |      |                    | NPA                                                               |
| 2        |      | 0.40               | Next Page Ability                                                 |
| 2        | RO   | 0×0                | This bit is tied to low, because the MAC does not support next    |
|          |      |                    | page function                                                     |
|          |      | 0×0                | NPR                                                               |
| 1        |      |                    | New Page Received                                                 |
| <b>1</b> | RO   |                    | When set, this bit indicates that a new page has been received by |
|          |      |                    | the MAC. This bit will be cleared when read                       |
| 0        | RO   | 0x0                | reserved                                                          |

# MAC\_INTF\_MODE\_STA

Address: Operational Base + offset (0x00d8)

| Bit  | Attr | <b>Reset Value</b> | Description                                            |
|------|------|--------------------|--------------------------------------------------------|
| 31:4 | RO   | 0x0                | reserved                                               |
|      |      |                    | LST                                                    |
| 3    | RO   | 0x0                | Link Status                                            |
|      |      |                    | Indicates whether the link is up (1'b1) or down (1'b0) |

| Bit | Attr | <b>Reset Value</b> | Description                                          |
|-----|------|--------------------|------------------------------------------------------|
|     |      |                    | LSD                                                  |
|     |      |                    | Link Speed                                           |
| 2.1 |      | 0.40               | Indicates the current speed of the link:             |
| 2:1 | RO   | 0×0                | 2'b00: 2.5 MHz                                       |
|     |      |                    | 2'b01: 25 MHz                                        |
|     |      |                    | 2'b10: 125 MHz                                       |
|     |      |                    | LM                                                   |
|     |      |                    | Link Mode                                            |
| 0   | RW   |                    | Indicates the current mode of operation of the link: |
|     |      |                    | 1'b0: Half-Duplex mode                               |
|     |      |                    | 1'b1: Full-Duplex mode                               |

# MAC MMC CTRL

Address: Operational Base + offset (0x0100)

| Bit  | Attr      | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|-----------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | RO        | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5    | RW        | 0×0                | FHP<br>Full-Half preset<br>When low and bit4 is set, all MMC counters get preset to almost-<br>half value. All octet counters get preset to 0x7FFF_F800 (half -<br>2K Bytes) and all frame-counters gets preset to 0x7FFF_FF0<br>(half - 16)<br>When high and bit4 is set, all MMC counters get preset to almost-<br>full value. All octet counters get preset to 0xFFFF_F800 (full - 2K<br>Bytes) and all frame-counters gets preset to 0xFFFF_FF0 (full -<br>16) |
| 4    | R/W<br>SC | 0×0                | CP<br>Counters Preset<br>When set, all counters will be initialized or preset to almost full or<br>almost half as per Bit5 above. This bit will be cleared<br>automatically after 1 clock cycle. This bit along with bit5 is useful<br>for debugging and testing the assertion of interrupts due to MMC<br>counter becoming half-full or full                                                                                                                      |
| 3    | RW        | 0x0                | MCF<br>MMC Counter Freeze<br>When set, this bit freezes all the MMC counters to their current<br>value. (None of the MMC counters are updated due to any<br>transmitted or received frame until this bit is reset to 0. If any<br>MMC counter is read with the Reset on Read bit set, then that<br>counter is also cleared in this mode.)                                                                                                                          |
| 2    | RW        | 0×0                | ROR<br>Reset on Read<br>When set, the MMC counters will be reset to zero after Read (self-<br>clearing after reset). The counters are cleared when the least<br>significant byte lane (bits[7:0]) is read                                                                                                                                                                                                                                                          |

| Bit | Attr | Reset Value | Description                                                    |
|-----|------|-------------|----------------------------------------------------------------|
|     |      |             | CSR                                                            |
| 1   | RW   | 0x0         | Counter Stop Rollover                                          |
| 1   | r vv | 0.00        | When set, counter after reaching maximum value will not roll   |
|     |      |             | over to zero                                                   |
|     |      | /W<br>C 0x0 | CR                                                             |
|     | R/W  |             | Counters Reset                                                 |
| 0   | SC   |             | When set, all counters will be reset. This bit will be cleared |
|     |      |             | automatically after 1 clock cycle                              |

# MAC MMC RX INTR

Address: Operational Base + offset (0x0104)

| Bit   | Attr | <b>Reset Value</b> | Description                                                      |
|-------|------|--------------------|------------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                         |
|       |      |                    | INT21                                                            |
| 21    | RW   | 0x0                | The bit is set when the rxfifooverflow counter reaches half the  |
|       |      |                    | maximum value, and also when it reaches the maximum value        |
| 20:19 | RO   | 0x0                | reserved                                                         |
|       |      |                    | INT18                                                            |
| 18    | RC   | 0x0                | The bit is set when the rxlengtherror counter reaches half the   |
|       |      |                    | maximum value, and also when it reaches the maximum value        |
| 17:6  | RO   | 0x0                | reserved                                                         |
|       |      |                    | INT5                                                             |
| 5     | RW   | 0x0                | The bit is set when the rxcrcerror counter reaches half the      |
|       |      |                    | maximum value, and also when it reaches the maximum value        |
|       |      |                    | INT4                                                             |
| 4     | RC   | 0x0                | The bit is set when the rxmulticastframes_g counter reaches half |
| 4     | κc   | 0.00               | the maximum value, and also when it reaches the maximum          |
|       |      |                    | value                                                            |
| 3     | RO   | 0x0                | reserved                                                         |
|       |      |                    | INT2                                                             |
| 2     | RC   | 0x0                | The bit is set when the rxoctetcount_g counter reaches half the  |
|       |      |                    | maximum value, and also when it reaches the maximum value        |
|       |      |                    | INT1                                                             |
| 1     | RC   | 0x0                | The bit is set when the rxoctetcount_gb counter reaches half the |
|       |      |                    | maximum value, and also when it reaches the maximum value        |
|       |      |                    | INTO                                                             |
| 0     | RC   | 0x0                | The bit is set when the rxframecount_gb counter reaches half the |
|       |      |                    | maximum value, and also when it reaches the maximum value        |

MAC MMC TX INTR Address: Operational Base + offset (0x0108)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                          |
|       |      |                    | INT21                                                             |
| 21    | RC   | 0x0                | The bit is set when the txframecount_g counter reaches half the   |
|       |      |                    | maximum value, and also when it reaches the maximum value         |
|       |      |                    | INT20                                                             |
| 20    | RC   | 0x0                | The bit is set when the txoctetcount_g counter reaches half the   |
|       |      |                    | maximum value, and also when it reaches the maximum value         |
|       |      |                    | INT19                                                             |
| 19    | RC   | 0x0                | The bit is set when the txcarriererror counter reaches half the   |
|       |      |                    | maximum value, and also when it reaches the maximum value         |
| 18:14 | RO   | 0x0                | reserved                                                          |
|       |      |                    | INT13                                                             |
| 13    | RC   | 0x0                | The bit is set when the txunderflowerror counter reaches half the |
|       |      |                    | maximum value, and also when it reaches the maximum value         |
| 12:2  | RO   | 0x0                | reserved                                                          |
|       |      |                    | INT1                                                              |
| 1     | RC   | 0x0                | The bit is set when the txframecount_gb counter reaches half the  |
|       |      |                    | maximum value, and also when it reaches the maximum value         |
|       |      |                    | INTO                                                              |
| 0     | RC   | 0x0                | The bit is set when the txoctetcount_gb counter reaches half the  |
|       |      |                    | maximum value, and also when it reaches the maximum value         |

# MAC\_MMC\_RX\_INT\_MSK

Address: Operational Base + offset (0x010c)

| Bit   |      | Reset Value | Description                                                      |
|-------|------|-------------|------------------------------------------------------------------|
| 31:22 | RO   | 0x0         | reserved                                                         |
|       |      |             | INT21                                                            |
| 21    | RW   | 0x0         | Setting this bit masks the interrupt when the rxfifooverflow     |
| 21    | K VV | UXU         | counter reaches half the maximum value, and also when it         |
|       |      |             | reaches the maximum value                                        |
| 20:19 | RO   | 0x0         | reserved                                                         |
|       |      |             | INT18                                                            |
| 18    | RW   | 0×0         | Setting this bit masks the interrupt when the rxlengtherror      |
| 10    |      |             | counter reaches half the maximum value, and also when it         |
|       |      |             | reaches the maximum value                                        |
| 17:6  | RO   | 0x0         | reserved                                                         |
|       |      | N 0×0       | INT5                                                             |
| 5     | RW   |             | Setting this bit masks the interrupt when the rxcrcerror counter |
| 5     |      |             | reaches half the maximum value, and also when it reaches the     |
|       |      |             | maximum value                                                    |
|       |      |             | INT4                                                             |
| 4     | RW   | 0×0         | Setting this bit masks the interrupt when the                    |
| -     |      | / 0x0       | rxmulticastframes_g counter reaches half the maximum value,      |
|       |      |             | and also when it reaches the maximum value                       |

| Bit | Attr | Reset Value | Description                                                                                                                                                    |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RO   | 0x0         | reserved                                                                                                                                                       |
|     |      |             | INT2                                                                                                                                                           |
| 2   | RW   | 0×0         | Setting this bit masks the interrupt when the rxoctetcount_g counter reaches half the maximum value, and also when it reaches the maximum value                |
| 1   | RW   | 0×0         | INT1<br>Setting this bit masks the interrupt when the rxoctetcount_gb<br>counter reaches half the maximum value, and also when it<br>reaches the maximum value |
| 0   | RW   | 0x0         | INT0<br>Setting this bit masks the interrupt when the rxframecount_gb<br>counter reaches half the maximum value, and also when it<br>reaches the maximum value |

# MAC MMC TX INT MSK

Address: Operational Base + offset (0x0110)

| Bit   | Attr | <b>Reset Value</b> | Description                                                    |
|-------|------|--------------------|----------------------------------------------------------------|
| 31:22 | RO   | 0x0                | reserved                                                       |
|       |      |                    | INT21                                                          |
| 21    | RW   | 0x0                | Setting this bit masks the interrupt when the txframecount_g   |
|       |      | 0,10               | counter reaches half the maximum value, and also when it       |
|       |      |                    | reaches the maximum value                                      |
|       |      |                    | INT20                                                          |
| 20    | RW   | 0x0                | Setting this bit masks the interrupt when the txoctetcount_g   |
| 20    |      | 0.00               | counter reaches half the maximum value, and also when it       |
|       |      |                    | reaches the maximum value                                      |
|       |      |                    | INT19                                                          |
| 10    |      | 0.40               | Setting this bit masks the interrupt when the txcarriererror   |
| 19    | RW   | 0x0                | counter reaches half the maximum value, and also when it       |
|       |      |                    | reaches the maximum value                                      |
| 18:14 | RO   | 0x0                | reserved                                                       |
|       |      |                    | INT13                                                          |
| 13    | RW   | V 0x0              | Setting this bit masks the interrupt when the txunderflowerror |
| 13    |      |                    | counter reaches half the maximum value, and also when it       |
|       |      |                    | reaches the maximum value                                      |
| 12:2  | RO   | 0x0                | reserved                                                       |
|       |      |                    | INT1                                                           |
| 4     |      | 00                 | Setting this bit masks the interrupt when the txframecount_gb  |
| 1     | RW   | 0x0                | counter reaches half the maximum value, and also when it       |
|       |      |                    | reaches the maximum value                                      |
|       |      |                    | INTO                                                           |
| 0     |      | 0.40               | Setting this bit masks the interrupt when the txoctetcount_gb  |
| 0     | RW   | 0x0                | counter reaches half the maximum value, and also when it       |
|       |      |                    | reaches the maximum value                                      |

#### MAC MMC TXOCTETCNT GB

Address: Operational Base + offset (0x0114)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
|      |      |                    | txoctetcount_gb                                                |
| 31:0 | RW   | 0x00000000         | Number of bytes transmitted, exclusive of preamble and retried |
|      |      |                    | bytes, in good and bad frames                                  |

#### MAC\_MMC\_TXFRMCNT\_GB

Address: Operational Base + offset (0x0118)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                  |
|------|------|--------------------|----------------------------------------------------------------------------------------------|
| 31:0 | RW   |                    | txframecount_gb<br>Number of good and bad frames transmitted, exclusive of retried<br>frames |

## MAC MMC TXUNDFLWERR

Address: Operational Base + offset (0x0148)

| Bit  | Attr | <b>Reset Value</b> | Description                                           |
|------|------|--------------------|-------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | txunderflowerror                                      |
| 31:0 |      |                    | Number of frames aborted due to frame underflow error |

## MAC MMC TXCARERR

Address: Operational Base + offset (0x0160)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                              |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | txcarriererror<br>Number of frames aborted due to carrier sense error (no carrier<br>or loss of carrier) |

MAC MMC TXOCTETCNT G Address: Operational Base + offset (0x0164)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                  |
|------|------|--------------------|----------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | txoctetcount_g<br>Number of bytes transmitted, exclusive of preamble, in good<br>frames only |

#### MAC MMC TXFRMCNT G

Address: Operational Base + offset (0x0168)

| Bit  | Attr | <b>Reset Value</b>                      | Description                       |
|------|------|-----------------------------------------|-----------------------------------|
| 31:0 |      | 0x00000000                              | txframecount_g                    |
| 51.0 | R VV | 0.0000000000000000000000000000000000000 | Number of good frames transmitted |

## MAC MMC RXFRMCNT GB

#### Address: Operational Base + offset (0x0180)

| Bit /  | Attr | <b>Reset Value</b> | Description                                               |
|--------|------|--------------------|-----------------------------------------------------------|
| 31:0 F | RW   | 0200000000         | rxframecount_gb<br>Number of good and bad frames received |

#### MAC MMC RXOCTETCNT GB

Address: Operational Base + offset (0x0184)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                   |
|------|------|--------------------|-----------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | rxoctetcount_gb<br>Number of bytes received, exclusive of preamble, in good and<br>bad frames |

#### MAC MMC RXOCTETCNT G

Address: Operational Base + offset (0x0188)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                               |
|------|------|--------------------|-------------------------------------------------------------------------------------------|
| 31:0 | RW   |                    | rxoctetcount_g<br>Number of bytes received, exclusive of preamble, only in good<br>frames |

### MAC MMC RXMCFRMCNT G

Address: Operational Base + offset (0x0190)

| Bit     | Attr | <b>Reset Value</b> | Description                              |
|---------|------|--------------------|------------------------------------------|
| 21.0 DW | RW   | 0x00000000         | rxmulticastframes_g                      |
| 51.0    | 1    | 0,00000000         | Number of good multicast frames received |

#### MAC MMC RXCRCERR

Address: Operational Base + offset (0x0194)

| Bit  | Attr | <b>Reset Value</b>                      | Description                              |
|------|------|-----------------------------------------|------------------------------------------|
| 31:0 | RW   | 0x00000000                              | rxcrcerror                               |
| 51.0 |      | 0.0000000000000000000000000000000000000 | Number of frames received with CRC error |

### MAC\_MMC\_RXLENERR

Address: Operational Base + offset (0x01c8)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                     |
|------|------|--------------------|---------------------------------------------------------------------------------|
| 31:0 | RW   |                    | rxlengtherror<br>Number of frames received with length error (Length type field |
|      |      |                    | $\neq$ frame size), for all frames with valid length field                      |

### MAC MMC RXFIFOOVRFLW

Address: Operational Base + offset (0x01d4)

| Bit  | Attr | <b>Reset Value</b> | Description                                           |
|------|------|--------------------|-------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | rxfifooverflow                                        |
| 51.0 | r vv | 0x00000000         | Number of missed received frames due to FIFO overflow |

#### MAC MMC IPC INT MSK

Address: Operational Base + offset (0x0200)

| Bit   | Attr | <b>Reset Value</b> | Description |
|-------|------|--------------------|-------------|
| 31:30 | RO   | 0x0                | reserved    |

| Bit   | Attr         | Reset Value | Description                                                      |
|-------|--------------|-------------|------------------------------------------------------------------|
|       |              |             | INT29                                                            |
| 20    | DIA          |             | Setting this bit masks the interrupt when the rxicmp_err_octets  |
| 29    | RW           | 0x0         | counter reaches half the maximum value, and also when it         |
|       |              |             | reaches the maximum value                                        |
| 28    | RO           | 0x0         | reserved                                                         |
|       |              |             | INT27                                                            |
|       |              |             | Setting this bit masks the interrupt when the rxtcp_err_octets   |
| 27    | RW           | 0x0         | counter reaches half the maximum value, and also when it         |
|       |              |             | reaches the maximum value                                        |
| 26    | RO           | 0x0         | reserved                                                         |
|       |              |             | INT25                                                            |
|       |              |             | Setting this bit masks the interrupt when the rxudp_err_octets   |
| 25    | RW           | 0x0         | counter reaches half the maximum value, and also when it         |
|       |              |             | reaches the maximum value                                        |
| 24:23 | RO           | 0x0         | reserved                                                         |
|       |              |             | INT22                                                            |
|       |              |             | Setting this bit masks the interrupt when the                    |
| 22    | RW           | 0x0         | rxipv6_hdrerr_octets counter reaches half the maximum value,     |
|       |              |             | and also when it reaches the maximum value                       |
| 21:18 | RO           | 0x0         | reserved                                                         |
|       |              | 0×0         | INT17                                                            |
|       |              |             | Setting this bit masks the interrupt when the                    |
| 17    | RW           |             | rxipv4_hdrerr_octets counter reaches half the maximum value,     |
|       |              |             | and also when it reaches the maximum value                       |
| 16:14 | RO           | 0x0         | reserved                                                         |
|       |              |             | INT13                                                            |
|       | D).4/        | 0×0         | Setting this bit masks the interrupt when the rxicmp_err_frms    |
| 13    | RW           |             | counter reaches half the maximum value, and also when it         |
|       |              |             | reaches the maximum value                                        |
| 12    | RO           | 0x0         | reserved                                                         |
|       |              |             | INT11                                                            |
|       | <b>D</b> 144 |             | Setting this bit masks the interrupt when the rxtcp_err_frms     |
| 11    | RW           | 0x0         | counter reaches half the maximum value, and also when it         |
|       |              |             | reaches the maximum value                                        |
| 10    | RO           | 0x0         | reserved                                                         |
|       |              |             | INT9                                                             |
|       | <b>D</b> 11/ |             | Setting this bit masks the interrupt when the rxudp_err_frms     |
| 9     | RW           | 0×0         | counter reaches half the maximum value, and also when it         |
|       |              |             | reaches the maximum value                                        |
| 8:7   | RO           | 0x0         | reserved                                                         |
|       |              |             | INT6                                                             |
| C     |              |             | Setting this bit masks the interrupt when the rxipv6_hdrerr_frms |
| 6     | RW           | 0x0         | counter reaches half the maximum value, and also when it         |
|       |              |             | reaches the maximum value                                        |

| Bit | Attr | Reset Value | Description                                                                                                                                                       |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0×0         | INT5<br>Setting this bit masks the interrupt when the rxipv6_gd_frms<br>counter reaches half the maximum value, and also when it<br>reaches the maximum value     |
| 4:2 | RO   | 0x0         | reserved                                                                                                                                                          |
| 1   | RW   | 0×0         | INT1<br>Setting this bit masks the interrupt when the rxipv4_hdrerr_frms<br>counter reaches half the maximum value, and also when it<br>reaches the maximum value |
| 0   | RW   | 0x0         | INT0<br>Setting this bit masks the interrupt when the rxipv4_gd_frms<br>counter reaches half the maximum value, and also when it<br>reaches the maximum value     |

# MAC MMC IPC INTR

Address: Operational Base + offset (0x0208)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
| 31:30 | RO   | 0x0                | reserved                                                          |
|       |      |                    | INT29                                                             |
| 29    | RC   | 0x0                | The bit is set when the rxicmp_err_octets counter reaches half    |
| 29    | RC   | UXU                | the maximum value, and also when it reaches the maximum           |
|       |      |                    | value                                                             |
| 28    | RO   | 0x0                | reserved                                                          |
|       |      |                    | INT27                                                             |
| 27    | RC   | 0x0                | The bit is set when the rxtcp_err_octets counter reaches half the |
|       |      |                    | maximum value, and also when it reaches the maximum value         |
| 26    | RO   | 0x0                | reserved                                                          |
|       |      |                    | INT25                                                             |
| 25    | RC   | 0x0                | The bit is set when the rxudp_err_octets counter reaches half the |
|       |      |                    | maximum value, and also when it reaches the maximum value         |
| 24:23 | RO   | 0x0                | reserved                                                          |
|       |      |                    | INT22                                                             |
| 22    | RC   | 0x0                | The bit is set when the rxipv6_hdrerr_octets counter reaches half |
| 22    | RC   |                    | the maximum value, and also when it reaches the maximum           |
|       |      |                    | value                                                             |
| 21:18 | RO   | 0x0                | reserved                                                          |
|       |      |                    | INT17                                                             |
| 17    | RC   | 0.40               | The bit is set when the rxipv4_hdrerr_octets counter reaches half |
| 17    | RC   | 0x0                | the maximum value, and also when it reaches the maximum           |
|       |      |                    | value                                                             |
| 16:14 | RO   | 0x0                | reserved                                                          |
|       |      |                    | INT13                                                             |
| 13    | RC   | 0x0                | The bit is set when the rxicmp_err_frms counter reaches half the  |
|       |      |                    | maximum value, and also when it reaches the maximum value         |

| Bit | Attr | Reset Value | Description                                                     |
|-----|------|-------------|-----------------------------------------------------------------|
| 12  | RO   | 0x0         | reserved                                                        |
|     |      |             | INT11                                                           |
| 11  | RC   | 0x0         | The bit is set when the rxtcp_err_frms counter reaches half the |
|     |      |             | maximum value, and also when it reaches the maximum value       |
| 10  | RO   | 0x0         | reserved                                                        |
|     |      |             | INT9                                                            |
| 9   | RC   | 0x0         | The bit is set when the rxudp_err_frms counter reaches half the |
|     |      |             | maximum value, and also when it reaches the maximum value       |
| 8:7 | RO   | 0x0         | reserved                                                        |
|     |      |             | INT6                                                            |
| 6   | RC   | 0×0         | The bit is set when the rxipv6_hdrerr_frms counter reaches half |
| 0   | INC. |             | the maximum value, and also when it reaches the maximum         |
|     |      |             | value                                                           |
|     |      |             | INT5                                                            |
| 5   | RC   | 0x0         | The bit is set when the rxipv6_gd_frms counter reaches half the |
|     |      |             | maximum value, and also when it reaches the maximum value       |
| 4:2 | RO   | 0x0         | reserved                                                        |
|     |      |             | INT1                                                            |
| 1   | RC   | 0x0         | The bit is set when the rxipv4_hdrerr_frms counter reaches half |
| 1   | RC.  |             | the maximum value, and also when it reaches the maximum         |
|     |      |             | value                                                           |
|     |      |             | INTO                                                            |
| 0   | RC   | 0x0         | The bit is set when the rxipv4_gd_frms counter reaches half the |
|     |      |             | maximum value, and also when it reaches the maximum value       |

# MAC MMC RXIPV4GFRM

Address: Operational Base + offset (0x0210)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                    |
|------|------|--------------------|------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | rxipv4_gd_frms<br>Number of good IPv4 datagrams received with the TCP, UDP, or<br>ICMP payload |

# MAC MMC RXIPV4HDERRFRM

Address: Operational Base + offset (0x0214)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                           |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | rxipv4_hdrerr_frms<br>Number of IPv4 datagrams received with header (checksum,<br>length, or version mismatch) errors |

## MAC MMC RXIPV6GFRM

Address: Operational Base + offset (0x0224)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                 |
|------|------|--------------------|---------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | rxipv6_gd_frms<br>Number of good IPv6 datagrams received with TCP, UDP, or ICMP<br>payloads |

# MAC MMC RXIPV6HDERRFRM

Address: Operational Base + offset (0x0228)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                |
|------|------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | rxipv6_hdrerr_frms<br>Number of IPv6 datagrams received with header errors (length or<br>version mismatch) |

## MAC MMC RXUDPERRFRM

Address: Operational Base + offset (0x0234)

| Bit  | Attr | <b>Reset Value</b> | Description                                                           |
|------|------|--------------------|-----------------------------------------------------------------------|
| 31:0 | RW   |                    | rxudp_err_frms<br>Number of good IP datagrams whose UDP payload has a |
|      |      |                    | checksum error                                                        |

## MAC MMC RXTCPERRFRM

Address: Operational Base + offset (0x023c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                             |
|------|------|--------------------|-----------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | rxtcp_err_frms<br>Number of good IP datagrams whose TCP payload has a<br>checksum error |

### MAC\_MMC\_RXICMPERRFRM

Address: Operational Base + offset (0x0244)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                               |
|------|------|--------------------|-------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | rxicmp_err_frms<br>Number of good IP datagrams whose ICMP payload has a<br>checksum error |

## MAC MMC RXIPV4HDERROCT

Address: Operational Base + offset (0x0254)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
|      | RW   | 0x00000000         | rxipv4_hdrerr_octets                                          |
| 31:0 |      |                    | Number of bytes received in IPv4 datagrams with header errors |
| 51.0 |      |                    | (checksum, length, version mismatch). The value in the Length |
|      |      |                    | field of IPv4 header is used to update this counter           |

## MAC\_MMC\_RXIPV6HDERROCT

Address: Operational Base + offset (0x0268)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
|      |      | 0×00000000         | rxipv6_hdrerr_octets                                          |
| 31:0 | RW   |                    | Number of bytes received in IPv6 datagrams with header errors |
| 51.0 |      |                    | (length, version mismatch). The value in the IPv6 header's    |
|      |      |                    | Length field is used to update this counter                   |

## MAC MMC RXUDPERROCT

Address: Operational Base + offset (0x0274)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                               |
|------|------|--------------------|-------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | rxudp_err_octets<br>Number of bytes received in a UDP segment that had checksum<br>errors |

## MAC MMC RXTCPERROCT

Address: Operational Base + offset (0x027c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
| 21.0 |      | 0x00000000         | rxtcp_err_octets                                               |
| 51.0 | r vv | 0x00000000         | Number of bytes received in a TCP segment with checksum errors |

# MAC MMC RXICMPERROCT

Address: Operational Base + offset (0x0284)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                              |
|------|------|--------------------|------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000         | rxicmp_err_octets<br>Number of bytes received in an ICMP segment with checksum<br>errors |

# MAC\_BUS\_MODE

Address: Operational Base + offset (0x1000)

| Bit   | Attr | <b>Reset Value</b> | Description                                                          |
|-------|------|--------------------|----------------------------------------------------------------------|
| 31:26 | RO   | 0x0                | reserved                                                             |
|       |      |                    | AAL                                                                  |
|       |      |                    | Address-Aligned Beats                                                |
|       |      |                    | When this bit is set high and the FB bit equals 1, the AXI           |
| 25    | RW   |                    | interface generates all bursts aligned to the start address LS bits. |
|       |      |                    | If the FB bit equals 0, the first burst (accessing the data buffer's |
|       |      |                    | start address) is not aligned, but subsequent bursts are aligned     |
|       |      |                    | to the address                                                       |
|       |      | / 0×0              | PBL_Mode                                                             |
|       |      |                    | 8xPBL Mode                                                           |
| 24    | RW   |                    | When set high, this bit multiplies the PBL value programmed (bits    |
| 27    | 1    |                    | [22:17] and bits [13:8]) eight times. Thus the DMA will transfer     |
|       |      |                    | data in to a maximum of 8, 16, 32, 64, 128, and 256 beats            |
|       |      |                    | depending on the PBL value                                           |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23    | RW   | 0×0         | USP<br>Use Separate PBL<br>When set high, it configures the RxDMA to use the value<br>configured in bits [22:17] as PBL while the PBL value in bits<br>[13:8] is applicable to TxDMA operations only. When reset to low,<br>the PBL value in bits [13:8] is applicable for both DMA engines                                                                                                                                                                                                                                  |
| 22:17 | RW   | 0×01        | RPBL<br>RxDMA PBL<br>These bits indicate the maximum number of beats to be<br>transferred in one RxDMA transaction. This will be the maximum<br>value that is used in a single block Read/Write. The RxDMA will<br>always attempt to burst as specified in RPBL each time it starts a<br>Burst transfer on the host bus. RPBL can be programmed with<br>permissible values of 1, 2, 4, 8, 16, and 32. Any other value will<br>result in undefined behavior. These bits are valid and applicable<br>only when USP is set high |
| 16    | RW   | 0x0         | FB<br>Fixed Burst<br>This bit controls whether the AXI Master interface performs fixed<br>burst transfers or not. When set, the AHB will use only SINGLE,<br>INCR4, INCR8 or INCR16 during start of normal burst transfers.<br>When reset, the AXI will use SINGLE and INCR burst transfer<br>operations                                                                                                                                                                                                                     |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Bit   | Attr      | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ыт    | RW        | 0x01               | PBL<br>Programmable Burst Length<br>These bits indicate the maximum number of beats to be<br>transferred in one DMA transaction. This will be the maximum<br>value that is used in a single block Read/Write.<br>The DMA will always attempt to burst as specified in PBL each<br>time it starts a Burst transfer on the host bus. PBL can be<br>programmed with permissible values of 1, 2, 4, 8, 16, and 32.<br>Any other value will result in undefined behavior. When USP is<br>set high, this PBL value is applicable for TxDMA transactions only.<br>The PBL values have the following limitations.<br>The maximum number of beats (PBL) possible is limited by the<br>size of the Tx FIFO and Rx FIFO in the MTL layer and the data bus<br>width on the DMA. The FIFO has a constraint that the maximum<br>beat supported is half the depth of the FIFO, except when<br>specified (as given below). For different data bus widths and FIFO<br>sizes, the valid PBL range (including x8 mode) is provided in the<br>following table. If the PBL is common for both transmit and<br>receive DMA, the minimum Rx FIFO and Tx FIFO depths must be<br>considered. Do not program out-of-range PBL values, because<br>the system may not behave properly.<br>For TxFIFO, valid PBL range in full duplex mode and duplex mode<br>is 128 or less.<br>For RxFIFO, valid PBL range in full duplex mode is all |
| 7 6:2 | RO        | 0x0<br>0x00        | reserved<br>DSL<br>Descriptor Skip Length<br>This bit specifies the number of dword to skip between two<br>unchained descriptors. The address skipping starts from the end<br>of current descriptor to the start of next descriptor. When DSL<br>value equals zero, then the descriptor table is taken as<br>contiguous by the DMA, in Ring mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1     | RO        | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0     | R/W<br>SC | 0x1                | SWR<br>Software Reset<br>When this bit is set, the MAC DMA Controller resets all MAC<br>Subsystem internal registers and logic. It is cleared automatically<br>after the reset operation has completed in all of the core clock<br>domains. Read a 0 value in this bit before re-programming any<br>register of the core.<br>Note: The reset operation is completed only when all the resets in<br>all the active clock domains are de-asserted. Hence it is essential<br>that all the PHY inputs clocks (applicable for the selected PHY<br>interface) are present for software reset completion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# MAC TX POLL DEMAND

Address: Operational Base + offset (0x1004)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 02000000000        | TPD<br>Transmit Poll Demand<br>When these bits are written with any value, the DMA reads the<br>current descriptor pointed to by Register<br>MAC_CUR_HOST_TX_DESC. If that descriptor is not available<br>(owned by Host), transmission returns to the Suspend state and<br>DMA Register MAC_STATUS[2] is asserted. If the descriptor is<br>available, transmission resumes |

### MAC RX POLL DEMAND

Address: Operational Base + offset (0x1008)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x000000000        | RPD<br>Receive Poll Demand<br>When these bits are written with any value, the DMA reads the<br>current descriptor pointed to by Register<br>MAC_CUR_HOST_RX_DESC. If that descriptor is not available<br>(owned by Host), reception returns to the Suspended state and<br>Register MAC_STATUS[7] is not asserted. If the descriptor is<br>available, the Receive DMA returns to active state |

## MAC RX DESC LIST ADDR

Address: Operational Base + offset (0x100c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                         |
|------|------|--------------------|---------------------------------------------------------------------|
|      | RW   | 0x00000000         | SRL                                                                 |
|      |      |                    | Start of Receive List                                               |
| 31:0 |      |                    | This field contains the base address of the First Descriptor in the |
| 51.0 |      |                    | Receive Descriptor list. The LSB bits [1/2/3:0] for 32/64/128-bit   |
|      |      |                    | bus width) will be ignored and taken as all-zero by the DMA         |
|      |      |                    | internally. Hence these LSB bits are Read Only                      |

## MAC TX DESC LIST ADDR

Address: Operational Base + offset (0x1010)

| Bit  | Attr | <b>Reset Value</b> | Description                                                         |
|------|------|--------------------|---------------------------------------------------------------------|
|      | RW   | 0×00000000         | STL                                                                 |
|      |      |                    | Start of Transmit List                                              |
| 31:0 |      |                    | This field contains the base address of the First Descriptor in the |
| 51.0 |      |                    | Transmit Descriptor list. The LSB bits [1/2/3:0] for 32/64/128-bit  |
|      |      |                    | bus width) will be ignored and taken as all-zero by the DMA         |
|      |      |                    | internally. Hence these LSB bits are Read Only                      |

### MAC\_STATUS

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 28    | RO   | 0x0                | GPI<br>MAC PMT Interrupt<br>This bit indicates an interrupt event in the MAC core's PMT<br>module. The software must read the corresponding registers in<br>the MAC core to get the exact cause of interrupt and clear its<br>source to reset this bit to 1'b0. The interrupt signal from the MAC<br>subsystem (sbd_intr_o) is high when this bit is high                                                                                                                                                                   |
| 27    | RO   | 0x0                | GMI<br>MAC MMC Interrupt<br>This bit reflects an interrupt event in the MMC module of the MAC<br>core. The software must read the corresponding registers in the<br>MAC core to get the exact cause of interrupt and clear the source<br>of interrupt to make this bit as 1'b0. The interrupt signal from the<br>MAC subsystem (sbd_intr_o) is high when this bit is high                                                                                                                                                   |
| 26    | RO   | 0x0                | GLI<br>MAC Line interface Interrupt<br>This bit reflects an interrupt event in the MAC Core's PCS or<br>RGMII interface block. The software must read the corresponding<br>registers in the MAC core to get the exact cause of interrupt and<br>clear the source of interrupt to make this bit as 1'b0. The<br>interrupt signal from the MAC subsystem (sbd_intr_o) is high<br>when this bit is high                                                                                                                        |
| 25:23 | RO   | 0×0                | EB<br>Error Bits<br>These bits indicate the type of error that caused a Bus Error<br>(e.g., error response on the AXI interface). Valid only with Fatal<br>Bus Error bit (Register MAC_STATUS[13]) set. This field does not<br>generate an interrupt.<br>Bit 23: 1'b1 Error during data transfer by TxDMA<br>1'b0 Error during data transfer by RxDMA<br>Bit 24: 1'b1 Error during read transfer<br>1'b0 Error during write transfer<br>Bit 25: 1'b1 Error during descriptor access<br>1'b0 Error during data buffer access |

Address: Operational Base + offset (0x1014)

| Bit   | Attr    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22:20 | RO      | 0×0         | TS<br>Transmit Process State<br>These bits indicate the Transmit DMA FSM state. This field does<br>not generate an interrupt.<br>3'b000: Stopped; Reset or Stop Transmit Command issued.<br>3'b001: Running; Fetching Transmit Transfer Descriptor.<br>3'b010: Running; Waiting for status.<br>3'b010: Running; Reading Data from host memory buffer and<br>queuing it to transmit buffer (Tx FIFO).<br>3'b100: TIME_STAMP write state.<br>3'b101: Reserved for future use.<br>3'b101: Suspended; Transmit Descriptor Unavailable or Transmit<br>Buffer Underflow.<br>3'b111: Running; Closing Transmit Descriptor |
| 19:17 | RO      | 0×0         | RS<br>Receive Process State<br>These bits indicate the Receive DMA FSM state. This field does<br>not generate an interrupt.<br>3'b000: Stopped: Reset or Stop Receive Command issued.<br>3'b001: Running: Fetching Receive Transfer Descriptor.<br>3'b010: Reserved for future use.<br>3'b010: Reserved for future use.<br>3'b011: Running: Waiting for receive packet.<br>3'b100: Suspended: Receive Descriptor Unavailable.<br>3'b101: Running: Closing Receive Descriptor.<br>3'b110: TIME_STAMP write state.<br>3'b111: Running: Transferring the receive packet data from<br>receive buffer to host memory    |
| 16    | W1<br>C | 0×0         | NIS<br>Normal Interrupt Summary<br>Normal Interrupt Summary bit value is the logical OR of the<br>following when the corresponding interrupt bits are enabled in<br>Register OP_MODE:<br>Register MAC_STATUS[0]: Transmit Interrupt<br>Register MAC_STATUS[2]: Transmit Buffer Unavailable<br>Register MAC_STATUS[6]: Receive Interrupt<br>Register MAC_STATUS[6]: Receive Interrupt<br>Only unmasked bits affect the Normal Interrupt Summary bit.<br>This is a sticky bit and must be cleared (by writing a 1 to this bit)<br>each time a<br>corresponding bit that causes NIS to be set is cleared              |

| Bit   | Attr    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | W1<br>C | 0×0         | AIS<br>Abnormal Interrupt Summary<br>Abnormal Interrupt Summary bit value is the logical OR of the<br>following when the corresponding interrupt bits are enabled in<br>Register OP_MODE:<br>Register MAC_STATUS[1]: Transmit Process Stopped<br>Register MAC_STATUS[3]: Transmit Jabber Timeout<br>Register MAC_STATUS[3]: Transmit Jabber Timeout<br>Register MAC_STATUS[4]: Receive FIFO Overflow<br>Register MAC_STATUS[5]: Transmit Underflow<br>Register MAC_STATUS[5]: Transmit Underflow<br>Register MAC_STATUS[7]: Receive Buffer Unavailable<br>Register MAC_STATUS[8]: Receive Process Stopped<br>Register MAC_STATUS[9]: Receive Watchdog Timeout<br>Register MAC_STATUS[10]: Early Transmit Interrupt<br>Register MAC_STATUS[13]: Fatal Bus Error<br>Only unmasked bits affect the Abnormal Interrupt Summary bit.<br>This is a sticky bit and must be cleared each time a<br>corresponding bit that causes AIS to be set is cleared |
| 14    | W1<br>C | 0×0         | ERI<br>Early Receive Interrupt<br>This bit indicates that the DMA had filled the first data buffer of<br>the packet. Receive Interrupt Register MAC_STATUS[6]<br>automatically clears this bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13    | W1<br>C | 0×0         | FBI<br>Fatal Bus Error Interrupt<br>This bit indicates that a bus error occurred, as detailed in<br>[25:23]. When this bit is set, the corresponding DMA engine<br>disables all its bus accesses                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 12:11 | RO      | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 10    | W1<br>C | 0×0         | ETI<br>Early Transmit Interrupt<br>This bit indicates that the frame to be transmitted was fully<br>transferred to the MTL<br>Transmit FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9     | W1<br>C | 0x0         | RWT<br>Receive Watchdog Timeout<br>This bit is asserted when a frame with a length greater than<br>2,048 bytes is received                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8     | W1<br>C | 0×0         | RPS<br>Receive Process Stopped<br>This bit is asserted when the Receive Process enters the Stopped<br>state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Bit | Attr    | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|---------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | W1<br>C | 0×0                | RU<br>Receive Buffer Unavailable<br>This bit indicates that the Next Descriptor in the Receive List is<br>owned by the host and cannot be acquired by the DMA. Receive<br>Process is suspended. To resume processing Receive descriptors,<br>the host should change the ownership of the descriptor and issue<br>a Receive Poll Demand command. If no Receive Poll Demand is<br>issued, Receive Process resumes when the next recognized<br>incoming frame is received. Register MAC_STATUS[7] is set only<br>when the previous Receive Descriptor was owned by the DMA |
| 6   | W1<br>C | 0×0                | RI<br>Receive Interrupt<br>This bit indicates the completion of frame reception. Specific<br>frame status information has been posted in the descriptor.<br>Reception remains in the Running state                                                                                                                                                                                                                                                                                                                                                                      |
| 5   | W1<br>C | 0×0                | UNF<br>Transmit Underflow<br>This bit indicates that the Transmit Buffer had an Underflow<br>during frame transmission. Transmission is suspended and an<br>Underflow Error TDES0[1] is set                                                                                                                                                                                                                                                                                                                                                                             |
| 4   | W1<br>C | 0×0                | OVF<br>Receive Overflow<br>This bit indicates that the Receive Buffer had an Overflow during<br>frame reception. If the partial frame is transferred to application,<br>the overflow status is set in RDES0[11]                                                                                                                                                                                                                                                                                                                                                         |
| 3   | W1<br>C | 0×0                | TJT<br>Transmit Jabber Timeout<br>This bit indicates that the Transmit Jabber Timer expired,<br>meaning that the transmitter had been excessively active. The<br>transmission process is aborted and placed in the Stopped state.<br>This causes the Transmit Jabber Timeout TDES0[14] flag to<br>assert                                                                                                                                                                                                                                                                |
| 2   | W1<br>C | 0×0                | TU<br>Transmit Buffer Unavailable<br>This bit indicates that the Next Descriptor in the Transmit List is<br>owned by the host and cannot be acquired by the DMA.<br>Transmission is suspended. Bits[22:20] explain the Transmit<br>Process state transitions. To resume processing transmit<br>descriptors, the host should change the ownership of the bit of<br>the descriptor and then issue a Transmit Poll Demand command                                                                                                                                          |
| 1   | W1<br>C | 0×0                | TPS<br>Transmit Process Stopped<br>This bit is set when the transmission is stopped                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Bit | Attr    | <b>Reset Value</b> | Description                                                |
|-----|---------|--------------------|------------------------------------------------------------|
|     | W1<br>C | 0×0                | ТІ                                                         |
| 0   |         |                    | Transmit Interrupt                                         |
| 0   |         |                    | This bit indicates that frame transmission is finished and |
|     |         |                    | TDES1[31] is set in the First Descriptor                   |

# MAC\_OP\_MODE

Address: Operational Base + offset (0x1018)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 26    | RW   | 0×0                | DT<br>Disable Dropping of TCP/IP Checksum Error Frames<br>When this bit is set, the core does not drop frames that only have<br>errors detected by the Receive Checksum Offload engine. Such<br>frames do not have any errors (including FCS error) in the<br>Ethernet frame received by the MAC but have errors in the<br>encapsulated payload only. When this bit is reset, all error frames<br>are dropped if the FEF bit is reset |
| 25    | RW   | 0×0                | RSF<br>Receive Store and Forward<br>When this bit is set, the MTL only reads a frame from the Rx FIFO<br>after the complete frame has been written to it, ignoring RTC<br>bits. When this bit is reset, the Rx FIFO operates in Cut-Through<br>mode, subject to the threshold specified by the RTC bits                                                                                                                               |
| 24    | RW   | 0×0                | DFF<br>Disable Flushing of Received Frames<br>When this bit is set, the RxDMA does not flush any frames due to<br>the unavailability of receive descriptors/buffers as it does<br>normally when this bit is reset                                                                                                                                                                                                                     |
| 23:22 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 21    | RW   | 0×0                | TSF<br>Transmit Store and Forward<br>When this bit is set, transmission starts when a full frame resides<br>in the MTL Transmit FIFO. When this bit is set, the TTC values<br>specified in Register MAC_OP_MODE[16:14] are ignored. This bit<br>should be changed only when transmission is stopped                                                                                                                                   |

| Bit   | Attr    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20    | W1<br>C | 0×0         | FTF<br>Flush Transmit FIFO<br>When this bit is set, the transmit FIFO controller logic is reset to<br>its default values and thus all data in the Tx FIFO is lost/flushed.<br>This bit is cleared internally when the flushing operation is<br>completed fully. The Operation Mode register should not be<br>written to until this bit is cleared. The data which is already<br>accepted by the MAC transmitter will not be flushed. It will be<br>scheduled for transmission and will result in underflow and runt<br>frame transmission.<br>Note: The flush operation completes only after emptying the<br>TxFIFO of its contents and all the pending Transmit Status of the<br>transmitted frames are accepted by the host. In order to<br>complete this flush operation, the PHY transmit clock (clk_tx_i) is<br>required to be active |
| 19:17 | RO      | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 16:14 | RW      | 0×0         | TTC<br>Transmit Threshold Control<br>These three bits control the threshold level of the MTL Transmit<br>FIFO. Transmission starts when the frame size within the MTL<br>Transmit FIFO is larger than the threshold. In addition, full<br>frames with a length less than the threshold are also transmitted.<br>These bits are used only when the TSF bit (Bit 21) is reset.<br>3'b000: 64<br>3'b001: 128<br>3'b010: 192<br>3'b011: 256<br>3'b100: 40<br>3'b101: 32<br>3'b110: 24<br>3'b111: 16                                                                                                                                                                                                                                                                                                                                            |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13    | RW   | 0x0         | ST<br>Start/Stop Transmission Command<br>When this bit is set, transmission is placed in the Running state,<br>and the DMA checks the Transmit List at the current position for a<br>frame to be transmitted. Descriptor acquisition is attempted<br>either from the current position in the list, which is the Transmit<br>List Base Address set by Register MAC_TX_DESC_LIST_ADDR, or<br>from the position retained when transmission was stopped<br>previously. If the current descriptor is not owned by the DMA,<br>transmission enters the Suspended state and Transmit Buffer<br>Unavailable (Register MAC_STATUS[2]) is set. The Start<br>Transmission command is effective only when transmission is<br>stopped. If the command is issued before setting DMA Register<br>TX_DESC_LIST_ADDR, then the DMA behavior is unpredictable.<br>When this bit is reset, the transmission process is placed in the<br>Stopped state after completing the transmission of the current<br>frame. The Next Descriptor position in the Transmit List is saved,<br>and becomes the current position when transmission is restarted.<br>The stop transmission command is effective only the transmission<br>of the current frame is complete or when the transmission is in<br>the Suspended state |
| 12:11 | RW   | 0×0         | RFD<br>Threshold for deactivating flow control (in both HD and FD)<br>These bits control the threshold (Fill-level of Rx FIFO) at which<br>the flow-control is de-asserted after activation.<br>2'b00: Full minus 1 KB<br>2'b01: Full minus 2 KB<br>2'b11: Full minus 3 KB<br>2'b11: Full minus 4 KB<br>Note that the de-assertion is effective only after flow control is<br>asserted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10:9  | RW   | 0×0         | RFA<br>Threshold for activating flow control (in both HD and FD)<br>These bits control the threshold (Fill level of Rx FIFO) at which<br>flow control is activated.<br>2'b00: Full minus 1 KB<br>2'b01: Full minus 2 KB<br>2'b11: Full minus 3 KB<br>2'b11: Full minus 4 KB<br>Note that the above only applies to Rx FIFOs of 4 KB or more<br>when the EFC bit is set high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | RW   | 0×0         | EFC<br>Enable HW flow control<br>When this bit is set, the flow control signal operation based on<br>fill-level of Rx FIFO is enabled. When reset, the flow control<br>operation is disabled                                                                                                                                                                                                                                                                                                                                                                                              |
| 7   | RW   | 0×0         | FEF<br>Forward Error Frames<br>When this bit is reset, the Rx FIFO drops frames with error status<br>(CRC error, collision error, GMII_ER, giant frame, watchdog<br>timeout, overflow). However, if the frame's start byte (write)<br>pointer is already transferred to the read controller side (in<br>Threshold mode), then the frames are not dropped.<br>When FEF is set, all frames except runt error frames are<br>forwarded to the DMA. But when RxFIFO overflows when a partial<br>frame is written, then such frames are dropped even when FEF is<br>set                         |
| 6   | RW   | 0×0         | FUF<br>Forward Undersized Good Frames<br>When set, the Rx FIFO will forward Undersized frames (frames<br>with no Error and length less than 64 bytes) including pad-bytes<br>and CRC).<br>When reset, the Rx FIFO will drop all frames of less than 64<br>bytes, unless it is already transferred due to lower value of<br>Receive Threshold (e.g., RTC = 01)                                                                                                                                                                                                                             |
| 5   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4:3 | RW   | 0×0         | RTC<br>Receive Threshold Control<br>These two bits control the threshold level of the MTL Receive<br>FIFO. Transfer (request) to DMA starts when the frame size<br>within the MTL Receive FIFO is larger than the threshold. In<br>addition, full frames with a length less than the threshold are<br>transferred automatically. Note that value of 11 is not applicable<br>if the configured Receive FIFO size is 128 bytes. These bits are<br>valid only when the RSF bit is zero, and are ignored when the<br>RSF bit is set to 1.<br>2'b00: 64<br>2'b1: 32<br>2'b10: 96<br>2'b11: 128 |
| 2   | RW   | 0×0         | OSF<br>Operate on Second Frame<br>When this bit is set, this bit instructs the DMA to process a<br>second frame of Transmit data even before status for first frame<br>is obtained                                                                                                                                                                                                                                                                                                                                                                                                        |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | RW   | 0×0                | SR<br>Start/Stop Receive<br>When this bit is set, the Receive process is placed in the Running<br>state. The DMA attempts to acquire the descriptor from the<br>Receive list and processes incoming frames. Descriptor<br>acquisition is attempted from the current position in the list,<br>which is the address set by register MAC_RX_DESC_LIST_ADDR<br>or the position retained when the Receive process was previously<br>stopped. If no descriptor is owned by the DMA, reception is<br>suspended and Receive Buffer Unavailable (Register<br>MAC_STATUS[7]) is set. The Start Receive command is effective<br>only when reception has stopped. If the command was issued<br>before setting register MAC_RX_DESC_LIST_ADDR, DMA<br>behavior is unpredictable.<br>When this bit is cleared, RxDMA operation is stopped after the<br>transfer of the current frame. The next descriptor position in the<br>Receive list is saved and becomes the current position after the<br>transfer of the current frame. The Stop Receive command is<br>effective only when the Receive process is in either the Running<br>(waiting for receive packet) or in the Suspended state |
| 0   | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### MAC\_INT\_ENA

Address: Operational Base + offset (0x101c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                        |
|-------|------|--------------------|--------------------------------------------------------------------|
| 31:17 | RO   | 0x0                | reserved                                                           |
|       |      |                    | NIE                                                                |
|       |      |                    | Normal Interrupt Summary Enable                                    |
|       |      |                    | When this bit is set, a normal interrupt is enabled. When this bit |
|       |      |                    | is reset, a normal interrupt is disabled. This bit enables the     |
| 16    | RW   | 0x0                | following bits:                                                    |
|       |      |                    | Register MAC_STATUS[0]: Transmit Interrupt                         |
|       |      |                    | Register MAC_STATUS[2]: Transmit Buffer Unavailable                |
|       |      |                    | Register MAC_STATUS[6]: Receive Interrupt                          |
|       |      |                    | Register MAC_STATUS[14]: Early Receive Interrupt                   |

| Bit   | Attr | <b>Reset Value</b> | Description                                                          |
|-------|------|--------------------|----------------------------------------------------------------------|
|       |      |                    | AIE                                                                  |
|       |      |                    | Abnormal Interrupt Summary Enable                                    |
|       |      |                    | When this bit is set, an Abnormal Interrupt is enabled. When this    |
|       |      |                    | bit is reset, an Abnormal Interrupt is disabled. This bit enables    |
|       |      |                    | the following bits                                                   |
|       |      |                    | Register MAC_STATUS[1]: Transmit Process Stopped                     |
| . –   |      |                    | Register MAC_STATUS[3]: Transmit Jabber Timeout                      |
| 15    | RW   | 0x0                | Register MAC_STATUS[4]: Receive Overflow                             |
|       |      |                    | Register MAC_STATUS[5]: Transmit Underflow                           |
|       |      |                    | Register MAC_STATUS[7]: Receive Buffer Unavailable                   |
|       |      |                    | Register MAC_STATUS[8]: Receive Process Stopped                      |
|       |      |                    | Register MAC_STATUS[9]: Receive Watchdog Timeout                     |
|       |      |                    | Register MAC_STATUS[10]: Early Transmit Interrupt                    |
|       |      |                    | Register MAC_STATUS[13]: Fatal Bus Error                             |
|       |      |                    | ERE                                                                  |
|       |      |                    | Early Receive Interrupt Enable                                       |
| 14    | RW   | 0x0                | When this bit is set with Normal Interrupt Summary Enable (BIT       |
|       |      |                    | 16), Early Receive Interrupt is enabled. When this bit is reset,     |
|       |      |                    | Early Receive Interrupt is disabled                                  |
|       |      | 0x0                | FBE                                                                  |
|       |      |                    | Fatal Bus Error Enable                                               |
| 13    | RW   |                    | When this bit is set with Abnormal Interrupt Summary Enable          |
|       |      |                    | (BIT 15), the Fatal Bus Error Interrupt is enabled. When this bit is |
|       |      |                    | reset, Fatal Bus Error Enable Interrupt is disabled                  |
| 12:11 | RO   | 0x0                | reserved                                                             |
|       |      |                    | ETE                                                                  |
|       |      |                    | Early Transmit Interrupt Enable                                      |
| 10    | RW   | W 0x0              | When this bit is set with an Abnormal Interrupt Summary Enable       |
|       |      |                    | (BIT 15), Early Transmit Interrupt is enabled. When this bit is      |
|       |      |                    | reset, Early Transmit Interrupt is disabled                          |
|       |      |                    | RWE                                                                  |
|       |      |                    | Receive Watchdog Timeout Enable                                      |
| 9     | RW   | 0x0                | When this bit is set with Abnormal Interrupt Summary Enable          |
| 5     | 1    | 0,0                | (BIT 15), the Receive Watchdog Timeout Interrupt is enabled.         |
|       |      |                    | When this bit is reset, Receive                                      |
|       |      |                    | Watchdog Timeout Interrupt is disabled                               |
|       |      |                    | RSE                                                                  |
|       | RW   |                    | Receive Stopped Enable                                               |
| 8     |      | 0x0                | When this bit is set with Abnormal Interrupt Summary Enable          |
|       |      |                    | (BIT 15), Receive Stopped Interrupt is enabled. When this bit is     |
|       |      |                    | reset, Receive Stopped Interrupt is disabled                         |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                              |
|-----|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RW   | 0×0                | RUE<br>Receive Buffer Unavailable Enable<br>When this bit is set with Abnormal Interrupt Summary Enable<br>(BIT 15), Receive Buffer Unavailable Interrupt is enabled. When<br>this bit is reset, the Receive Buffer Unavailable Interrupt is<br>disabled |
| 6   | RW   | 0×0                | RIE<br>Receive Interrupt Enable<br>When this bit is set with Normal Interrupt Summary Enable (BIT<br>16), Receive Interrupt is enabled. When this bit is reset, Receive<br>Interrupt is disabled                                                         |
| 5   | RW   | 0×0                | UNE<br>Underflow Interrupt Enable<br>When this bit is set with Abnormal Interrupt Summary Enable<br>(BIT 15), Transmit Underflow Interrupt is enabled. When this bit<br>is reset, Underflow Interrupt is disabled                                        |
| 4   | RW   | 0x0                | OVE<br>Overflow Interrupt Enable<br>When this bit is set with Abnormal Interrupt Summary Enable<br>(BIT 15), Receive Overflow Interrupt is enabled. When this bit is<br>reset, Overflow Interrupt is disabled                                            |
| 3   | RW   | 0×0                | TJE<br>Transmit Jabber Timeout Enable<br>When this bit is set with Abnormal Interrupt Summary Enable<br>(BIT 15), Transmit Jabber Timeout Interrupt is enabled. When<br>this bit is reset, Transmit Jabber Timeout Interrupt is disabled                 |
| 2   | RW   | 0×0                | TUE<br>Transmit Buffer Unavailable Enable<br>When this bit is set with Normal Interrupt Summary Enable (BIT<br>16), Transmit Buffer Unavailable Interrupt is enabled. When this<br>bit is reset, Transmit Buffer Unavailable Interrupt is disabled       |
| 1   | RW   | 0×0                | TSE<br>Transmit Stopped Enable<br>When this bit is set with Abnormal Interrupt Summary Enable<br>(BIT 15), Transmission Stopped Interrupt is enabled. When this<br>bit is reset, Transmission Stopped Interrupt is disabled                              |
| 0   | RW   | 0×0                | TIE<br>Transmit Interrupt Enable<br>When this bit is set with Normal Interrupt Summary Enable (BIT<br>16), Transmit Interrupt is enabled. When this bit is reset,<br>Transmit Interrupt is disabled                                                      |

#### MAC OVERFLOW CNT

Address: Operational Base + offset (0x1020)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
| 31:29 | RO   | 0x0                | reserved                                                          |
| 28    | RC   | 0x0                | FIFO_overflow_bit                                                 |
| 20    | RC   | 0.00               | Overflow bit for FIFO Overflow Counter                            |
|       |      |                    | Frame_miss_number                                                 |
|       |      |                    | Indicates the number of frames missed by the application          |
| 27:17 | RC   | 0×000              | This counter is incremented each time the MTL asserts the         |
|       |      |                    | sideband signal mtl_rxoverflow_o. The counter is cleared when     |
|       |      |                    | this register is read with mci_be_i[2] at 1'b1                    |
| 16    | RC   | .C 0x0             | Miss_frame_overflow_bit                                           |
| 10    |      |                    | Overflow bit for Missed Frame Counter                             |
|       |      | RC 0x0000          | Frame_miss_number_2                                               |
|       |      |                    | Indicates the number of frames missed by the controller due to    |
| 15:0  | RC   |                    | the Host Receive Buffer being unavailable. This counter is        |
| 15.0  |      |                    | incremented each time the DMA discards an incoming frame. The     |
|       |      |                    | counter is cleared when this register is read with mci_be_i[0] at |
|       |      |                    | 1'b1                                                              |

#### MAC REC INT WDT TIMER

Address: Operational Base + offset (0x1024)

| Bit  | Attr | <b>Reset Value</b> | Description                                                        |
|------|------|--------------------|--------------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                           |
|      |      |                    | RIWT                                                               |
|      |      |                    | RI Watchdog Timer count                                            |
|      |      |                    | Indicates the number of system clock cycles multiplied by 256 for  |
|      |      |                    | which the watchdog timer is set. The watchdog timer gets           |
|      |      |                    | triggered with the programmed value after the RxDMA completes      |
| 7:0  | RW   | 0x00               | the transfer of a frame for which the RI status bit is not set due |
|      |      |                    | to the setting in the corresponding descriptor RDES1[31]. When     |
|      |      |                    | the watch-dog timer runs out, the RI bit is set and the timer is   |
|      |      |                    | stopped. The watchdog timer is reset when RI bit is set high due   |
|      |      |                    | to automatic setting of RI as per RDES1[31] of any received        |
|      |      |                    | frame                                                              |

#### MAC AXI BUS MODE

Address: Operational Base + offset (0x1028)

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                            |
|-----|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | RW   | 0×0                | EN_LPI<br>Enable LPI (Low Power Interface)<br>When set to 1, enable the LPI (Low Power Interface) supported<br>by the MAC and accepts the LPI request from the AXI System<br>Clock controller.<br>When set to 0, disables the Low Power Mode and always denies<br>the LPI request from the AXI System Clock controller |

| Bit   | Attr | <b>Reset Value</b> | Description                                                         |
|-------|------|--------------------|---------------------------------------------------------------------|
|       |      |                    | UNLCK_ON_MGK_RWK                                                    |
|       |      |                    | Unlock on Magic Packet or Remote Wake Up                            |
|       |      |                    | When set to 1, enables it to request coming out of Low Power        |
| 30    | RW   | 0x0                | mode only when Magic Packet or Remote Wake Up Packet is             |
|       |      |                    | received.                                                           |
|       |      |                    | When set to 0, enables it requests to come out of Low Power         |
|       |      |                    | mode when any frame is received                                     |
| 29:22 | RO   | 0x0                | reserved                                                            |
|       |      |                    | WR_OSR_LMT                                                          |
|       |      |                    | AXI Maximum Write Out Standing Request Limit                        |
| 21:20 | RW   | 0x1                | This value limits the maximum outstanding request on the AXI        |
|       |      |                    | write interface.                                                    |
|       |      |                    | Maximum outstanding requests = WR_OSR_LMT+1                         |
| 19:18 | RO   | 0x0                | reserved                                                            |
|       |      |                    | RD_OSR_LMT                                                          |
|       |      |                    | AXI Maximum Read Out Standing Request Limit                         |
| 17:16 | RW   | 0x1                | This value limits the maximum outstanding request on the AXI        |
|       |      |                    | read interface.                                                     |
|       |      |                    | Maximum outstanding requests = RD_OSR_LMT+1                         |
| 15:13 | RO   | 0x0                | reserved                                                            |
|       |      |                    | AXI_AAL                                                             |
|       |      |                    | Address-Aligned Beats                                               |
| 10    | RO   | 0×0                | This bit is read-only bit and reflects the AAL bit Register0        |
| 12    | RU   |                    | (register MAC_BUS_MODE[25]).                                        |
|       |      |                    | When this bit set to 1, it performs address-aligned burst transfers |
|       |      |                    | on both read and write channels                                     |
| 11:4  | RO   | 0x0                | reserved                                                            |
|       |      |                    | BLEN16                                                              |
| 2     |      | 0.40               | AXI Burst Length 16                                                 |
| 3     | RW   | 0x0                | When this bit is set to 1, or when UNDEF is set to 1, it is allowed |
|       |      |                    | to select a burst length of 16                                      |
|       |      |                    | BLEN8                                                               |
| 2     |      | 0.40               | AXI Burst Length 8                                                  |
| 2     | RW   | 0x0                | When this bit is set to 1, or when UNDEF is set to 1, it is allowed |
|       |      |                    | to select a burst length of 8                                       |
|       |      |                    | BLEN4                                                               |
| 1     |      |                    | AXI Burst Length 4                                                  |
| 1     | RW   | N 0×0              | When this bit is set to 1, or when UNDEF is set to 1, it is allowed |
|       |      |                    | to select a burst length of 4                                       |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RO   | 0x1                | UNDEF<br>AXI Undefined Burst Length<br>This bit is read-only bit and indicates the complement (invert)<br>value of FB bit in register MAC_BUS_MODE[16].<br>When this bit is set to 1, it is allowed to perform any burst length<br>equal to or below the maximum allowed burst length as<br>programmed in bits[7:1];<br>When this bit is set to 0, it is allowed to perform only fixed burst<br>lengths as indicated by BLEN256/128/64/32/16/8/4, or a burst<br>length of 1 |

#### MAC\_AXI\_STATUS

Address: Operational Base + offset (0x102c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                             |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x0                | reserved                                                                                                |
| 1    | RO   | 0x0                | RD_CH_STA<br>When high, it indicates that AXI Master's read channel is active<br>and transferring data  |
| 0    | RO   | 0x0                | WR_CH_STA<br>When high, it indicates that AXI Master's write channel is active<br>and transferring data |

#### MAC CUR HOST TX DESC

Address: Operational Base + offset (0x1048)

| Bit  | Attr | <b>Reset Value</b> | Description                                               |  |  |  |
|------|------|--------------------|-----------------------------------------------------------|--|--|--|
|      |      |                    | HTDAP                                                     |  |  |  |
| 31:0 | RO   | 0x00000000         | Host Transmit Descriptor Address Pointer                  |  |  |  |
|      |      |                    | Cleared on Reset. Pointer updated by DMA during operation |  |  |  |

#### MAC CUR HOST RX DESC

Address: Operational Base + offset (0x104c)

| Bit  | Attr | <b>Reset Value</b> | Description                                               |
|------|------|--------------------|-----------------------------------------------------------|
|      |      |                    | HRDAP                                                     |
| 31:0 | RO   | 0x00000000         | Host Receive Descriptor Address Pointer                   |
|      |      |                    | Cleared on Reset. Pointer updated by DMA during operation |

#### MAC CUR HOST TX BUF ADDR

Address: Operational Base + offset (0x1050)

| Bit  | Attr | <b>Reset Value</b> | Description                                               |
|------|------|--------------------|-----------------------------------------------------------|
|      |      |                    | НТВАР                                                     |
| 31:0 | RO   | 0x00000000         | Host Transmit Buffer Address Pointer                      |
|      |      |                    | Cleared on Reset. Pointer updated by DMA during operation |

#### MAC CUR HOST RX BUF ADDR

Address: Operational Base + offset (0x1054)

| Bit  | Attr | <b>Reset Value</b> | Description                                               |  |  |  |
|------|------|--------------------|-----------------------------------------------------------|--|--|--|
|      |      |                    | HRBAP                                                     |  |  |  |
| 31:0 | RO   | 0x00000000         | Host Receive Buffer Address Pointer                       |  |  |  |
|      |      |                    | Cleared on Reset. Pointer updated by DMA during operation |  |  |  |

# 23.5 Interface Description

| Module pin                                                                     | Direction            | Pad name                                                                 | IOMUX setting                        |  |  |  |
|--------------------------------------------------------------------------------|----------------------|--------------------------------------------------------------------------|--------------------------------------|--|--|--|
|                                                                                | RMII interface       |                                                                          |                                      |  |  |  |
| mac_clk                                                                        | I/O                  | GPIO1_B4/LCDC_D8/I2S1_8CH_MCLK_M<br>1/MAC_CLK                            | GRF_GPIO1B_IOMUX_L[9:8]=2'b<br>11    |  |  |  |
| mac_txen                                                                       | 0                    | GPIO1_C1/LCDC_D13/I2S1_8CH_SDO0_<br>M1/MAC_TXEN                          | GRF_GPIO1C_IOMUX_L[3:2]=2'b<br>11    |  |  |  |
| mac_txd1                                                                       | 0                    | GPIO1_C3/LCDC_D15/I2S1_8CH_SDO2_<br>SDI2_M1/PDM_8CH_SDI2_M1/MAC_TXD<br>1 | GRF_GPIO1C_IOMUX_L[6:4]=3'b<br>011   |  |  |  |
| mac_txd0                                                                       | 0                    | GPIO1_C2/LCDC_D14/I2S1_8CH_SDO1_<br>SDI3_M1/PDM_8CH_SDI3_M1/MAC_TXD<br>0 | GRF_GPIO1C_IOMUX_L[10:8]=3'<br>b011  |  |  |  |
| mac_rxdv                                                                       | I                    | GPIO1_C0/LCDC_D12/I2S1_8CH_LRCK_<br>RX_M1/MAC_RXDV                       | GRF_GPIO1C_IOMUX_L[1:0]=2'b<br>11    |  |  |  |
| mac_rxer                                                                       | I                    | GPIO1_B7/LCDC_D11/I2S1_8CH_LRCK_<br>TX_M1/MAC_RXER                       | GRF_GPIO1B_IOMUX_H[2:0]=3'b<br>011   |  |  |  |
| mac_rxd1                                                                       | I                    | GPIO1_C5/LCDC_D17/I2S1_8CH_SDI0_<br>M1/PDM_8CH_SDI0_M1/MAC_RXD1          | GRF_GPIO1C_IOMUX_H[2:0]=3'b<br>011   |  |  |  |
| mac_rxd0                                                                       | I                    | GPIO1_C4/LCDC_D16/I2S1_8CH_SDO3_<br>SDI1_M1/PDM_8CH_SDI1_M1/MAC_RXD<br>0 | GRF_GPIO1C_IOMUX_L[14:12]=3<br>/b011 |  |  |  |
|                                                                                | Management interface |                                                                          |                                      |  |  |  |
| mac_mdio                                                                       | I/O                  | GPIO1_B6/LCDC_D10/I2S1_8CH_SCLK_<br>RX_M1/PDM_8CH_CLK_M1/MAC_MDIO        | GRF_GPIO1B_IOMUX_L[14:12]=3<br>'b011 |  |  |  |
| mac_mdc O GPIO1_B5/LCDC_D9/I2S1_8CH_SCLK_T GRF_GPIO1B_IOM<br>X_M1/MAC_MDC ′b11 |                      | GRF_GPIO1B_IOMUX_L[11:10]=2<br>'b11                                      |                                      |  |  |  |

*Notes: I*=*input, O*=*output, I*/*O*=*input/output, bidirectional* 

# **23.6 Application Notes**

# 23.6.1 Descriptors

The DMA in MAC can communicate with Host driver through descriptor lists and data buffers. The DMA transfers data frames received by the core to the Receive Buffer in the Host memory, and Transmit data frames from the Transmit Buffer in the Host memory. Descriptors that reside in the Host memory act as pointers to these buffers.

There are two descriptor lists; one for reception, and one for transmission. The base address of each list is written into DMA Registers RX\_DESC\_LIST\_ADDR and TX\_DESC\_LIST\_ADDR, respectively. A descriptor list is forward linked (either implicitly or explicitly). The last descriptor may point back to the first entry to create a ring structure. Explicit chaining of descriptors is accomplished by setting the second address chained in both Receive and Transmit descriptors (RDES1[24] and TDES1[24]). The descriptor lists resides in the Host physical memory address space. Each descriptor can point to a maximum of two buffers. This enables two buffers to be used, physically addressed, rather than contiguous buffers in memory.

A data buffer resides in the Host physical memory space, and consists of an entire frame or

part of a frame, but cannot exceed a single frame. Buffers contain only data, buffer status is maintained in the descriptor. Data chaining refers to frames that span multiple data buffers. However, a single descriptor cannot span multiple frames. The DMA will skip to the next frame buffer when end-of-frame is detected. Data chaining can be enabled or disabled The descriptor ring and chain structure is shown in following figure.



Fig. 23-11 Descriptor Ring and Chain Structure

Each descriptor contains two buffers, two byte-count buffers, and two address pointers, which enable the adapter port to be compatible with various types of memory management schemes. The descriptor addresses must be aligned to the bus width used (Word/Dword/Lword for 32/64/128-bit buses).

|           | 63 55                 | 47                                      | 39                          | 31          | 23   | 15             | 7   | 0 |
|-----------|-----------------------|-----------------------------------------|-----------------------------|-------------|------|----------------|-----|---|
| DES1-DES0 | Control Bits<br>[9:0] | Byte Count<br>Buffer2 [10:0]            | Byte Count<br>Buffer1[10:0] | O<br>W<br>N |      | Status [30:0]  |     |   |
| DES3-DES2 |                       | Iffer2 Address [31<br>Descriptor Addres |                             |             | Buff | er1 Address[31 | :0] |   |

Fig. 23-12 Rx/Tx Descriptors definition

## 23.6.2 Receive Descriptor

The MAC Subsystem requires at least two descriptors when receiving a frame. The Receive state machine of the DMAalways attempts to acquire an extra descriptor in anticipation of an incoming frame. (The size of the incoming frame is unknown). Before the RxDMA closes a descriptor, it will attempt to acquire the next descriptor even if no frames are received. In a single descriptor (receive) system, the subsystem will generate a descriptor error if the receive buffer is unable to accommodate the incoming frame and the next descriptor is not owned by the DMA. Thus, the Host is forced to increase either its descriptor pool or the buffer size. Otherwise, the subsystem starts dropping all incoming frames.

#### **Receive Descriptor 0 (RDES0)**

RDES0 contains the received frame status, the frame length, and the descriptor ownership information.

| Table 23-2 Receive Descript | or 0 | ) |
|-----------------------------|------|---|
|-----------------------------|------|---|

| Bit | Description  |
|-----|--------------|
| 31  | OWN: Own Bit |

| Bit   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30    | When set, this bit indicates that the descriptor is owned by the DMA of the MAC<br>Subsystem. When this bit is reset, this bit indicates that the descriptor is owned<br>by the Host. The DMA clears this bit either when it completes the frame reception<br>or when the buffers that are associated with this descriptor are full.<br>AFM: Destination Address Filter Fail                                                                                                                                                                                                                                                                                                                                        |
|       | When set, this bit indicates a frame that failed in the DA Filter in the MAC Core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 29:16 | FL: Frame Length<br>These bits indicate the byte length of the received frame that was transferred to<br>host memory (including CRC). This field is valid when Last Descriptor (RDES0[8])<br>is set and either the Descriptor Error (RDES0[14]) or Overflow Error bits are reset.<br>The frame length also includes the two bytes appended to the Ethernet frame<br>when IP checksum calculation (Type 1) is enabled and the received frame is not a<br>MAC control frame.<br>This field is valid when Last Descriptor (RDES0[8]) is set. When the Last<br>Descriptor and Error Summary bits are not set, this field indicates the<br>accumulated number of bytes that have been transferred for the current frame. |
| 15    | ES: Error Summary<br>Indicates the logical OR of the following bits:<br>• RDES0[0]: Payload Checksum Error<br>• RDES0[1]: CRC Error<br>• RDES0[3]: Receive Error<br>• RDES0[4]: Watchdog Timeout<br>• RDES0[6]: Late Collision<br>• RDES0[6]: Late Collision<br>• RDES0[7]: IPC Checksum<br>• RDES0[11]: Overflow Error<br>• RDES0[14]: Descriptor Error<br>This field is valid only when the Last Descriptor (RDES0[8]) is set.                                                                                                                                                                                                                                                                                    |
| 14    | DE: Descriptor Error<br>When set, this bit indicates a frame truncation caused by a frame that does not fit<br>within the current descriptor buffers, and that the DMA does not own the Next<br>Descriptor. The frame is truncated. This field is valid only when the Last Descriptor<br>(RDES0[8]) is set                                                                                                                                                                                                                                                                                                                                                                                                          |
| 13    | SAF: Source Address Filter Fail<br>When set, this bit indicates that the SA field of frame failed the SA Filter in the<br>MAC Core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12    | LE: Length Error<br>When set, this bit indicates that the actual length of the frame received and that<br>the Length/ Type field does not match. This bit is valid only when the Frame Type<br>(RDES0[5]) bit is reset. Length error status is not valid when CRC error is present.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11    | OE: Overflow Error<br>When set, this bit indicates that the received frame was damaged due to buffer<br>overflow.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 10    | VLAN: VLAN Tag<br>When set, this bit indicates that the frame pointed to by this descriptor is a VLAN<br>frame tagged by the MAC Core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 9     | FS: First Descriptor<br>When set, this bit indicates that this descriptor contains the first buffer of the<br>frame. If the size of the first buffer is 0, the second buffer contains the beginning<br>of the frame. If the size of the second buffer is also 0, the next Descriptor contains<br>the beginning of the frame.                                                                                                                                                                                                                                                                                                                                                                                        |
| 8     | LS: Last Descriptor<br>When set, this bit indicates that the buffers pointed to by this descriptor are the<br>last buffers of the frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7     | IPC Checksum Error/Giant Frame                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | When IP Checksum Engine is enabled, this bit, when set, indicates that the 16-bit IPv4 Header checksum calculated by the core did not match the received checksum bytes. The Error Summary bit[15] is NOT set when this bit is set in this mode.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6   | LC: Late Collision<br>When set, this bit indicates that a late collision has occurred while receiving the<br>frame in Half-Duplex mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 5   | FT: Frame Type<br>When set, this bit indicates that the Receive Frame is an Ethernet-type frame (the<br>LT field is greater than or equal to 16'h0600). When this bit is reset, it indicates<br>that the received frame is an IEEE802.3 frame. This bit is not valid for Runt<br>frames less than 14 bytes.                                                                                                                                                                                                                                                                                                                                                                                   |
| 4   | RWT: Receive Watchdog Timeout<br>When set, this bit indicates that the Receive Watchdog Timer has expired while<br>receiving the current frame and the current frame is truncated after the Watchdog<br>Timeout.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3   | RE: Receive Error<br>When set, this bit indicates that the gmii_rxer_i signal is asserted while<br>gmii_rxdv_i is asserted during frame reception. This error also includes carrier<br>extension error in GMII and Half-duplex mode. Error can be of less/no extension,<br>or error (rxd $\neq$ 0f) during extension.                                                                                                                                                                                                                                                                                                                                                                         |
| 2   | DE: Dribble Bit Error<br>When set, this bit indicates that the received frame has a non-integer multiple of<br>bytes (odd nibbles). This bit is valid only in MII Mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1   | CE: CRC Error<br>When set, this bit indicates that a Cyclic Redundancy Check (CRC) Error occurred<br>on the received frame. This field is valid only when the Last Descriptor (RDES0[8])<br>is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0   | Rx MAC Address/Payload Checksum Error<br>When set, this bit indicates that the Rx MAC Address registers value (1 to 15)<br>matched the frame's DA field. When reset, this bit indicates that the Rx MAC<br>Address Register 0 value matched the DA field.<br>If Full Checksum Offload Engine is enabled, this bit, when set, indicates the TCP,<br>UDP, or ICMP checksum the core calculated does not match the received<br>encapsulated TCP, UDP, or ICMP segment's Checksum field. This bit is also set<br>when the received number of payload bytes does not match the value indicated in<br>the Length field of the encapsulated IPv4 or IPv6 datagram in the received<br>Ethernet frame. |

Receive Descriptor 1 (RDES1) RDES1 contains the buffer sizes and other bits that control the descriptor chain/ring. Table 23-3 Receive Descriptor 1

| Bit   | Description                                                                                                                                                                                                                                                                                                           |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Disable Interrupt on Completion<br>When set, this bit will prevent the setting of the RI (CSR5[6]) bit of the<br>MAC_STATUS Register for the received frame that ends in the buffer pointed to by<br>this descriptor. This, in turn, will disable the assertion of the interrupt to Host due<br>to RI for that frame. |
| 30:26 | Reserved.                                                                                                                                                                                                                                                                                                             |
| 25    | RER: Receive End of Ring<br>When set, this bit indicates that the descriptor list reached its final descriptor. The<br>DMA returns to the base address of the list, creating a Descriptor Ring.                                                                                                                       |
| 24    | RCH: Second Address Chained<br>When set, this bit indicates that the second address in the descriptor is the Next                                                                                                                                                                                                     |

| Bit   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Descriptor address rather than the second buffer address. When RDES1[24] is set, RBS2 (RDES1[21-11]) is a "don't care" value.                                                                                                                                                                                                                                                                                                                                          |
|       | RDES1[25] takes precedence over RDES1[24].                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 23:22 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 21:11 | These bits indicate the second data buffer size in bytes. The buffer size must be a multiple of 8 depending upon the bus widths (64), even if the value of RDES3 (buffer2 address pointer) is not aligned to bus width. In the case where the buffer size is not a multiple of 8, the resulting behavior is undefined. This field is not valid if RDES1[24] is set.                                                                                                    |
| 10:0  | RBS1: Receive Buffer 1 Size<br>Indicates the first data buffer size in bytes. The buffer size must be a multiple of 8<br>depending upon the bus widths (64), even if the value of RDES2 (buffer1 address<br>pointer) is not aligned. In the case where the buffer size is not a multiple of 8, the<br>resulting behavior is undefined. If this field is 0, the DMA ignores this buffer and<br>uses Buffer 2 or next descriptor depending on the value of RCH (Bit 24). |

#### **Receive Descriptor 2 (RDES2)**

RDES2 contains the address pointer to the first data buffer in the descriptor. Table 23-4 Receive Descriptor 2

| Bit  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Buffer 1 Address Pointer<br>These bits indicate the physical address of Buffer 1. There are no limitations on the<br>buffer address alignment except for the following condition: The DMA uses the<br>configured value for its address generation when the RDES2 value is used to store<br>the start of frame. Note that the DMA performs a write operation with the<br>RDES2[2:0] bits as 0 during the transfer of the start of frame but the frame data is<br>shifted as per the actual Buffer address pointer. The DMA ignores RDES2[2:0]<br>(corresponding to bus width of 64) if the address pointer is to a buffer where the<br>middle or last part of the frame is stored. |

#### **Receive Descriptor 3 (RDES3)**

RDES3 contains the address pointer either to the second data buffer in the descriptor or to the next descriptor.

| -    | Table 23-5 Receive Descriptor 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| 31:0 | Buffer 2 Address Pointer (Next Descriptor Address)<br>These bits indicate the physical address of Buffer 2 when a descriptor ring structure<br>is used. If the Second Address Chained (RDES1[24]) bit is set, this address<br>contains the pointer to the physical memory where the<br>Next Descriptor is present.<br>If RDES1[24] is set, the buffer (Next Descriptor) address pointer must be bus<br>width-aligned (RDES3[2:0] = 0, corresponding to a bus width of 64. LSBs are<br>ignored internally.) However, when<br>RDES1[24] is reset, there are no limitations on the RDES3 value, except for the<br>following condition: The DMA uses the configured value for its buffer address<br>generation when the RDES3 value is used to store the start of frame. The DMA<br>ignores RDES3[2:0] (corresponding to a bus width of 64) if the address pointer is<br>to a buffer where the middle or last part of the frame is stored. |  |  |  |  |  |

#### 23.6.3 Transmit Descriptor

The descriptor addresses must be aligned to the bus width used (64). Each descriptor is

provided with two buffers, two byte-count buffers, and two address pointers, which enable the adapter port to be compatible with various types of memory-management schemes.

#### Transmit Descriptor 0 (TDES0)

TDES0 contains the transmitted frame status and the descriptor ownership information. Table 23-6 Transmit Descriptor 0

| Bit   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | OWN: Own Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | When set, this bit indicates that the descriptor is owned by the DMA. When this bit<br>is reset, this bit indicates that the descriptor is owned by the Host. The DMA clears<br>this bit either when it completes the frame transmission or when the buffers<br>allocated in the descriptor are empty. The ownership bit of the First Descriptor of<br>the frame should be set after all subsequent descriptors belonging to the same<br>frame have been set. This avoids a possible race condition between fetching a<br>descriptor and the driver setting an ownership bit.                                                                                            |
| 30:17 | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 16    | IHE: IP Header Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       | When set, this bit indicates that the Checksum Offload engine detected an IP header error and consequently did not modify the transmitted frame for any checksum insertion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15    | ES: Error Summary<br>Indicates the logical OR of the following bits:<br>• TDES0[14]: Jabber Timeout<br>• TDES0[13]: Frame Flush                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|       | TDES0[11]: Loss of Carrier                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | TDES0[10]: No Carrier                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       | TDES0[9]: Late Collision                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | TDES0[8]: Excessive Collision     TDES0[2]: Excessive Deformation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | <ul> <li>TDES0[2]: Excessive Deferral</li> <li>TDES0[1]: Underflow Error</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 14    | JT: Jabber Timeout                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 14    | When set, this bit indicates the MAC transmitter has experienced a jabber time-<br>out.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13    | FF: Frame Flushed<br>When set, this bit indicates that the DMA/MTL flushed the frame due to a SW flush<br>command given by the CPU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 12    | PCE: Payload Checksum Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       | This bit, when set, indicates that the Checksum Offload engine had a failure and did not insert any checksum into the encapsulated TCP, UDP, or ICMP payload. This failure can be either due to insufficient bytes, as indicated by the IP Header's Payload Length field, or the MTL starting to forward the frame to the MAC transmitter in Store-and-Forward mode without the checksum having been calculated yet. This second error condition only occurs when the Transmit FIFO depth is less than the length of the Ethernet frame being transmitted: to avoid deadlock, the MTL starts forwarding the frame when the FIFO is full, even in Store-and-Forward mode. |
| 11    | LC: Loss of Carrier                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10    | When set, this bit indicates that Loss of Carrier occurred during frame<br>transmission. This is valid only for the frames transmitted without collision and<br>when the MAC operates in Half-Duplex Mode.<br>NC: No Carrier                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | When set, this bit indicates that the carrier sense signal form the PHY was not asserted during transmission.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 9     | LC: Late Collision<br>When set, this bit indicates that frame transmission was aborted due to a collision<br>occurring after the collision window (64 byte times including Preamble in RMII                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bit | Description                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | Mode and 512 byte times including Preamble and Carrier Extension in RGMII Mode). Not valid if Underflow Error is set.                                                                                                                                                                                                                                                                                                    |
| 8   | EC: Excessive Collision<br>When set, this bit indicates that the transmission was aborted after 16 successive<br>collisions while attempting to transmit the current frame. If the DR (Disable Retry)<br>bit in the MAC Configuration Register is set, this bit is set after the first collision<br>and the transmission of the frame is aborted.                                                                        |
| 7   | VF: VLAN Frame<br>When set, this bit indicates that the transmitted frame was a VLAN-type frame.                                                                                                                                                                                                                                                                                                                         |
| 6:3 | CC: Collision Count<br>This 4-bit counter value indicates the number of collisions occurring before the<br>frame was transmitted. The count is not valid when the Excessive Collisions bit<br>(TDES0[8]) is set.                                                                                                                                                                                                         |
| 2   | ED: Excessive Deferral<br>When set, this bit indicates that the transmission has ended because of excessive<br>deferral of over 24,288 bit times (155,680 bits times in 1000-Mbps mode) if the<br>Deferral Check (DC) bit is set high in the MAC Control Register.                                                                                                                                                       |
| 1   | UF: Underflow Error<br>When set, this bit indicates that the MAC aborted the frame because data arrived<br>late from the Host memory. Underflow Error indicates that the DMA encountered<br>an empty Transmit Buffer while transmitting the frame. The transmission process<br>enters the suspended state and sets both Transmit Underflow (Register<br>MAC_STATUS[5]) and Transmit Interrupt (Register MAC_STATUS [0]). |
| 0   | DB: Deferred Bit<br>When set, this bit indicates that the MAC defers before transmission because of<br>the presence of carrier. This bit is valid only in Half-Duplex mode.                                                                                                                                                                                                                                              |

#### Transmit Descriptor 1 (TDES1)

TDES1 contains the buffer sizes and other bits which control the descriptor chain/ring and the frame being transferred.

| Bit   | Description                                                                                  |
|-------|----------------------------------------------------------------------------------------------|
| 31    | IC: Interrupt on Completion                                                                  |
|       | When set, this bit sets Transmit Interrupt (Register 5[0]) after the present frame           |
|       | has been transmitted.                                                                        |
| 30    | LS: Last Segment                                                                             |
|       | When set, this bit indicates that the buffer contains the last segment of the frame.         |
| 29    | FS: First Segment                                                                            |
|       | When set, this bit indicates that the buffer contains the first segment of a frame.          |
| 28:27 | CIC: Checksum Insertion Control                                                              |
|       | These bits control the insertion of checksums in Ethernet frames that encapsulate            |
|       | TCP, UDP, or ICMP over IPv4 or IPv6 as described below.                                      |
|       | <ul> <li>2'b00: Do nothing. Checksum Engine is bypassed</li> </ul>                           |
|       | <ul> <li>2'b01: Insert IPv4 header checksum. Use this value to insert IPv4 header</li> </ul> |
|       | checksum when the frame encapsulates an IPv4 datagram.                                       |
|       | • 2'b10: Insert TCP/UDP/ICMP checksum. The checksum is calculated over the                   |
|       | TCP, UDP, or ICMP segment only and the TCP, UDP, or ICMP pseudo-header                       |
|       | checksum is assumed to be present in the corresponding input frame's Checksum                |
|       | field. An IPv4 header checksum is also inserted if the encapsulated datagram                 |
|       | conforms to IPv4.                                                                            |
|       | • 2'b11: Insert a TCP/UDP/ICMP checksum that is fully calculated in this engine.             |
|       | In other words, the TCP, UDP, or ICMP pseudo-header is included in the checksum              |
|       | calculation, and the input frame's corresponding Checksum field has an all-zero              |
|       | value. An IPv4 Header checksum is also inserted if the encapsulated datagram                 |

Table 23-7 Transmit Descriptor 1

| Bit         | Description                                                                                                                                                                                                                                                                                                                                                      |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | conforms to IPv4.<br>The Checksum engine detects whether the TCP, UDP, or ICMP segment is<br>encapsulated in IPv4 or IPv6 and processes its data accordingly.                                                                                                                                                                                                    |
| 26          | DC: Disable CRC<br>When set, the MAC does not append the Cyclic Redundancy Check (CRC) to the<br>end of the transmitted frame. This is valid only when the first segment<br>(TDES1[29]).                                                                                                                                                                         |
| 25          | TER: Transmit End of Ring<br>When set, this bit indicates that the descriptor list reached its final descriptor. The<br>returns to the base address of the list, creating a descriptor ring.                                                                                                                                                                     |
| 24          | TCH: Second Address Chained<br>When set, this bit indicates that the second address in the descriptor is the Next<br>Descriptor address rather than the second buffer address. When TDES1[24] is set,<br>TBS2 (TDES1[21–11]) are "don't care" values.<br>TDES1[25] takes precedence over TDES1[24].                                                              |
| 23          | DP: Disable Padding<br>When set, the MAC does not automatically add padding to a frame shorter than 64<br>bytes. When this bit is reset, the DMA automatically adds padding and CRC to a<br>frame shorter than 64 bytes and the CRC field is added despite the state of the DC<br>(TDES1[26]) bit. This is valid only when the first segment (TDES1[29]) is set. |
| 22<br>21:11 | Reserved.<br>TBS2: Transmit Buffer 2 Size<br>These bits indicate the Second Data Buffer in bytes. This field is not valid if<br>TDES1[24] is set.                                                                                                                                                                                                                |
| 10:0        | TBS1: Transmit Buffer 1 Size<br>These bits indicate the First Data Buffer byte size. If this field is 0, the DMA<br>ignores this buffer and uses Buffer 2 or next descriptor depending on the value of<br>TCH (Bit 24).                                                                                                                                          |

#### Transmit Descriptor 2 (TDES2)

TDES2 contains the address pointer to the first buffer of the descriptor.

Table 23-8 Transmit Descriptor 2

| Bit  | Description                                                                                                                                  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Buffer 1 Address Pointer<br>These bits indicate the physical address of Buffer 1. There is no limitation on the<br>buffer address alignment. |

#### Transmit Descriptor 3 (TDES3)

TDES3 contains the address pointer either to the second buffer of the descriptor or the next descriptor.

| Bit  | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:0 | Buffer 2 Address Pointer (Next Descriptor Address)<br>Indicates the physical address of Buffer 2 when a descriptor ring structure is used.<br>If the Second Address Chained (TDES1[24]) bit is set, this address contains the<br>pointer to the physical memory where the Next<br>Descriptor is present. The buffer address pointer must be aligned to the bus width<br>only when TDES1[24] is set. (LSBs are ignored internally.) |  |  |  |  |

## 23.6.4 Programming Guide

## **DMA Initialization – Descriptors**

The following operations must be performed to initialize the DMA.

1. Provide a software reset. This will reset all of the MAC internal registers and logic. (MAC\_OP\_MODE[0]).

2. Wait for the completion of the reset process (poll MAC\_OP\_MODE[0], which is only cleared after the reset operation is completed).

3. Program the following fields to initialize the Bus Mode Register by setting values in register MAC\_BUS\_MODE

a. Mixed Burst and AAL

b. Fixed burst or undefined burst

c. Burst length values and burst mode values.

d. Descriptor Length (only valid if Ring Mode is used)

e. Tx and Rx DMA Arbitration scheme

4. Program the AXI Interface options in the register MAC\_BUS\_MODE

a. If fixed burst-length is enabled, then select the maximum burst-length possible on the AXI bus (Bits[7:1])

5. A proper descriptor chain for transmit and receive must be created. It should also ensure that the receive descriptors are owned by DMA (bit 31 of descriptor should be set). When OSF mode is used, at least two descriptors are required.

6. Software should create three or more different transmit or receive descriptors in the chain before reusing any of the descriptors.

7. Initialize receive and transmit descriptor list address with the base address of transmit and receive descriptor (register MAC\_RX\_DESC\_LIST\_ADDR and

MAC\_TX\_DESC\_LIST\_ADDR).

8. Program the following fields to initialize the mode of operation by setting values in register MAC\_OP\_MODE

a. Receive and Transmit Store And Forward

b. Receive and Transmit Threshold Control (RTC and TTC)

c. Hardware Flow Control enable

d. Flow Control Activation and De-activation thresholds for MTL Receive and Transmit FIFO (RFA and RFD)

e. Error Frame and undersized good frame forwarding enable

f. OSF Mode

9. Clear the interrupt requests, by writing to those bits of the status register (interrupt bits only) which are set. For example, by writing 1 into bit 16 - normal interrupt summary will clear this bit (register MAC\_STATUS).

10. Enable the interrupts by programming the interrupt enable register MAC\_INT\_ENA. 11. Start the Receive and Transmit DMA by setting SR (bit 1) and ST (bit 13) of the control register MAC\_OP\_MODE.

#### **MAC Initialization**

The following MAC Initialization operations can be performed after the DMA initialization sequence. If the MAC Initialization is done before the DMA is set-up, then enable the MAC receiver (last step below) only after the DMA is active. Otherwise, received frames will fill the RxFIFO and overflow.

1. Program the register MAC\_GMII\_ADDR for controlling the management cycles for external PHY, for example, Physical Layer Address PA (bits 15-11). Also set bit 0 (GMII Busy) for writing into PHY and reading from PHY.

2. Read the 16-bit data of (MAC\_GMII\_DATA) from the PHY for link up, speed of operation, and mode of operation, by specifying the appropriate address value in register MAC\_GMII\_ADDR (bits 15-11).

Provide the MAC address registers (MAC\_MAC\_ADDR0\_HI and MAC\_MAC\_ADDR0\_LO).
 If Hash filtering is enabled in your configuration, program the Hash filter register

(MAC\_HASH\_TAB\_HI and MAC\_HASH\_TAB\_LO).

5. Program the following fields to set the appropriate filters for the incoming frames in register MAC\_MAC\_FRM\_FILT

a. Receive All

- b. Promiscuous mode
- c. Hash or Perfect Filter

- d. Unicast, Multicast, broad cast and control frames filter settings etc.
- 6. Program the following fields for proper flow control in register MAC\_FLOW\_CTRL.
  - a. Pause time and other pause frame control bits
  - b. Receive and Transmit Flow control bits
  - c. Flow Control Busy/Backpressure Activate

7. Program the Interrupt Mask register bits, as required, and if applicable, for your configuration.

8. Program the appropriate fields in register MAC\_MAC\_CONF for example, Inter-frame gap while transmission, jabber disable, etc. Based on the Auto-negotiation you can set the Duplex mode (bit 11), port select (bit 15), etc.

9. Set the bits Transmit enable (TE bit-3) and Receive Enable (RE bit-2) in register MAC\_MAC\_CONF.

#### Normal Receive and Transmit Operation

For normal operation, the following steps can be followed.

- For normal transmit and receive interrupts, read the interrupt status. Then poll the descriptors, reading the status of the descriptor owned by the Host (either transmit or receive).
- On completion of the above step, set appropriate values for the descriptors, ensuring that transmit and receive descriptors are owned by the DMA to resume the transmission and reception of data.
- If the descriptors were not owned by the DMA (or no descriptor is available), the DMA will go into SUSPEND state. The transmission or reception can be resumed by freeing the descriptors and issuing a poll demand by writing 0 into the Tx/Rx poll demand register (MAC\_TX\_POLL\_DEMAND and MAC\_RX\_POLL\_DEMAND).
- The values of the current host transmitter or receiver descriptor address pointer can be read for the debug process (MAC\_CUR\_HOST\_TX\_DESC and MAC\_CUR\_HOST\_RX\_DESC).
- The values of the current host transmit buffer address pointer and receive buffer address pointer can be read for the debug process (MAC\_CUR\_HOST\_TX\_Buf\_ADDR and MAC\_CUR\_HOST\_RX\_BUF\_ADDR).

#### Stop and Start Operation

When the transmission is required to be paused for some time then the following steps can be followed.

1. Disable the Transmit DMA (if applicable), by clearing ST (bit 13) of the control register MAC\_OP\_MODE.

2. Wait for any previous frame transmissions to complete. This can be checked by reading the appropriate bits of MAC Debug register.

3. Disable the MAC transmitter and MAC receiver by clearing the bits Transmit enable (TE bit-3) and Receive Enable (RE bit-2) in register MAC\_MAC\_CONF.

4. Disable the Receive DMA (if applicable), after making sure the data in the RX FIFO is transferred to the system memory (by reading the register MAC\_DEBUG).

5. Make sure both the TX FIFO and RX FIFO are empty.

6. To re-start the operation, start the DMAs first, before enabling the MAC Transmitter and Receiver.

# 23.6.5 Clock Architecture

In RMII mode, reference clock and TX/RX clock can be from CRU or external OSC as following figure.

The mux select is CRU\_CLKSEL\_CON43[14].



Fig. 23-13 RMII clock architecture when clock source from CRU



Fig. 23-14 RMII clock architecture when clock source from external OSC

# 23.6.6 Remote Wake-Up Frame Filter Register

The register wkupfmfilter\_reg, address (028H), loads the Wake-up Frame Filter register. To load values in a Wake-up Frame Filter register, the entire register (wkupfmfilter\_reg) must be written. The wkupfmfilter\_reg register is loaded by sequentially loading the eight register values in address (028) for wkupfmfilter\_reg0, wkupfmfilter\_reg1, ..., wkupfmfilter\_reg7, respectively. Wkupfmfilter\_reg is read in the same way.

The internal counter to access the appropriate wkupfmfilter\_reg is incremented when lane3 (or lane 0 in big-endian) is accessed by the CPU. This should be kept in mind if you are accessing these registers in byte or half-word mode.

| wkupfmfilter_reg0 |                                     | Filter 0 Byte Mask  |                 |                     |                   |                     |                 |                     |
|-------------------|-------------------------------------|---------------------|-----------------|---------------------|-------------------|---------------------|-----------------|---------------------|
| wkupfmfilter_reg1 |                                     | Filter 1 Byte Mask  |                 |                     |                   |                     |                 |                     |
| wkupfmfilter_reg2 | Filter 2 Byte Mask                  |                     |                 |                     |                   |                     |                 |                     |
| wkupfmfilter_reg3 | Filter 3 Byte Mask                  |                     |                 |                     |                   |                     |                 |                     |
| wkupfmfilter_reg4 | RSVD                                | Filter 3<br>Command | RSVD            | Filter 2<br>Command | RSVD              | Filter 1<br>Command | RSVD            | Filter 0<br>Command |
| wkupfmfilter_reg5 | kupfmfilter_reg5 Filter 3 Offset    |                     | Filter 2 Offset |                     | Filter 1 Offset   |                     | Filter 0 Offset |                     |
| wkupfmfilter_reg6 | Filter 1 CRC - 16 Filter 0 CRC - 16 |                     |                 |                     |                   |                     |                 |                     |
| wkupfmfilter_reg7 | Filter 3 CRC - 16                   |                     |                 |                     | Filter 2 CRC - 16 |                     |                 |                     |

Fig. 23-1 Wake-Up Frame Filter Register

#### Filter i Byte Mask

This register defines which bytes of the frame are examined by filter i (0, 1, 2, and 3) in order to determine whether or not the frame is a wake-up frame. The MSB (thirty-first bit) must be zero. Bit j [30:0] is the Byte Mask. If bit j (byte number) of the Byte Mask is set, then Filter i Offset + j of the incoming frame is processed by the CRC block; otherwise Filter i Offset + j is ignored.

#### Filter i Command

This 4-bit command controls the filter i operation. Bit 3 specifies the address type, defining the pattern's destination address type. When the bit is set, the pattern applies to only multicast frames; when the bit is reset, the pattern applies only to unicast frame. Bit 2 and Bit 1 are reserved. Bit 0 is the enable for filter i; if Bit 0 is not set, filter i is disabled. *Filter i Offset* 

# This register defines the offset (within the frame) from which the frames are examined by filter i. This 8-bit pattern-offset is the offset for the filter i first byte to examined. The minimum allowed is 12, which refers to the 13th byte of the frame (offset value 0 refers to the first byte of the frame).

#### Filter i CRC-16

This register contains the CRC\_16 value calculated from the pattern, as well as the byte mask programmed to the wake-up filter register block.

#### 23.6.7 System Consideration During Power-Down

MAC neither gates nor stops clocks when Power-Down mode is enabled. Power saving by clock gating must be done outside the core by the CRU. The receive data path must be clocked with clk\_rx\_i during Power-Down mode, because it is involved in magic packet/wake-on-LAN frame detection. However, the transmit path and the APB path clocks can be gated off during Power-Down mode.

The PMT interrupt is asserted when a valid wake-up frame is received. This interrupt is generated in the clk\_rx domain.

The recommended power-down and wake-up sequence is as follows.

1. Disable the Transmit DMA (if applicable) and wait for any previous frame transmissions to complete. These transmissions can be detected when Transmit Interrupt (TI - Register MAC\_STATUS[0]) is received.

2. Disable the MAC transmitter and MAC receiver by clearing the appropriate bits in the MAC Configuration register.

3. Wait until the Receive DMA empties all the frames from the Rx FIFO (a software timer may be required).

4. Enable Power-Down mode by appropriately configuring the PMT registers.

5. Enable the MAC Receiver and enter Power-Down mode.

6. Gate the APB and transmit clock inputs to the core (and other relevant clocks in the system) to reduce power and enter Sleep mode.

7. On receiving a valid wake-up frame, the MAC asserts the PMT interrupt signal and exits Power-Down mode.

8. On receiving the interrupt, the system must enable the APB and transmit clock inputs to

the core.

9. Read the register MAC\_PMT\_CTRL\_STA to clear the interrupt, then enable the other modules in the system and resume normal operation.

# 23.6.8 GRF Register Summary

| MAC2IO               |                                                                                                                                                                                                                                  |  |  |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| GRF Register         | Register Description                                                                                                                                                                                                             |  |  |  |
| GRF_MAC_CON0[0]      | MACspeed<br>1'b1: 100-Mbps<br>1'b0: 10-Mbps                                                                                                                                                                                      |  |  |  |
| GRF_MAC_CON0[1]      | MAC transmit flow control<br>When set high, instructs the MAC to transmit PAUSE Control<br>frames in Full-duplex mode. In Half-duplex mode, the MAC<br>enables the Back-pressure function until this signal is made<br>low again |  |  |  |
| GRF_MAC_CON0[4:2]    | PHY interface select<br>3'b001: RGMII(useless)<br>3'b100: RMII<br>All others: Reserved                                                                                                                                           |  |  |  |
| CRU_CLKSEL_CON43[14] | rmii_extclk_sel<br>1'b1:from CRU<br>1'b0:from IO                                                                                                                                                                                 |  |  |  |
| CRU_CLKSEL_CON43[15] | rmii_clk_sel<br>1'b1:100M<br>1'b0:10M                                                                                                                                                                                            |  |  |  |

# Chapter 24 WatchDog

# 24.1 Overview

Watchdog Timer (WDT) is an APB slave peripheral that can be used to prevent system lockup that may be caused by conflicting parts or programs .The WDT would generate interrupt or reset signal when it's counter reaches zero, then a reset controller would reset the system. there are a Non-secure WDT(WDT\_NS) and a Secure WDT(WDT\_S); WDT supports the following features:

- 32 bits APB bus width
- WDT counter's clock is pclk
- 32 bits WDT counter width
- Counter counts down from a preset value to 0 to indicate the occurrence of a timeout
- WDT can perform two types of operations when timeout occurs:
  - Generate a system reset
  - First generate an interrupt and if this is not cleared by the service routine by the time a second timeout occurs then generate a system reset
- Programmable reset pulse length
- Total 16 defined-ranges of main timeout period
- Support two WTD, one is used for non-secure application, the other is used for secure application

# 24.2 Block Diagram



Fig. 24-1 WDT block diagram

#### **Block Descriptions:**

• APB Interface

The APB Interface implements the APB slave operation. Its data bus width is 32 bits.Register Block

- A register block that read coherence for the current count register.
- Interrupt & system reset control

An interrupt/system reset generation block is comprised of a decrementing counter and control logic.

# 24.3 Function Description

#### 24.3.1 Operation

#### Counter

The WDT counts from a preset (timeout) value in descending order to zero. When the counter reaches zero, depending on the output response mode selected, either a system reset or an interrupt occurs. When the counter reaches zero, it wraps to the selected timeout value and continues decrementing. The user can restart the counter to its initial value. This is programmed by writing to the restart register at any time. The process of restarting the watchdog counter is sometimes referred as kicking the dog. As a safety feature to prevent accidental restarts, the value 0x76 must be written to the Current

Counter Value Register (WDT\_CRR).

#### Interrupts

The WDT can be programmed to generate an interrupt (and then a system reset) when a timeout occurs. When a 1 is written to the response mode field (RMOD, bit 1) of the Watchdog Timer Control Register (WDT\_CR), the WDT generates an interrupt. If it is not cleared by the time a second timeout occurs, then it generates a system reset. If a restart occurs at the same time the watchdog counter reaches zero, an interrupt is not generated.

#### **System Resets**

When a 0 is written to the output response mode field (RMOD, bit 1) of the Watchdog Timer Control Register (WDT\_CR), the WDT generates a system reset when a timeout occurs.

#### Reset Pulse Length

The reset pulse length is the number of pclk cycles for which a system reset is asserted. When a system reset is generated, it remains asserted for the number of cycles specified by the reset pulse length or until the system is reset. A counter restart has no effect on the system reset once it has been asserted.

# 24.4 Register Description

This section describes the control/status registers of the design.

| Offset | Size                                                     | Reset<br>Value                                                       | Description                                                                                                                                                                                                                                                         |
|--------|----------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0000 | W                                                        | 0x0000000a                                                           | Control Register                                                                                                                                                                                                                                                    |
| 0x0004 | W                                                        | 0x00000000                                                           | Timeout range Register                                                                                                                                                                                                                                              |
| 0x0008 | W                                                        | 0x0000ffff                                                           | Current counter value Register                                                                                                                                                                                                                                      |
| 0x000c | W                                                        | 0x00000000                                                           | Counter restart Register                                                                                                                                                                                                                                            |
| 0x0010 | W                                                        | 0x00000000                                                           | Interrupt status Register                                                                                                                                                                                                                                           |
| 0x0014 | W                                                        | 0x00000000                                                           | Interrupt clear Register                                                                                                                                                                                                                                            |
|        | 0x0000<br>0x0004<br>0x0008<br>0x000c<br>0x0010<br>0x0014 | 0x0000 W<br>0x0004 W<br>0x0008 W<br>0x000c W<br>0x0010 W<br>0x0014 W | Offset         Size         Value           0x0000         W         0x000000a           0x0004         W         0x0000000           0x0008         W         0x0000ffff           0x000c         W         0x0000000           0x0010         W         0x0000000 |

#### 24.4.1 Registers Summary

Notes: Size: B- Byte (8 bits) access, HW- Half WORD (16 bits) access, W-WORD (32 bits) access

#### 24.4.2 Detail Register Description

#### WDT\_CR

Address: Operational Base + offset (0x0000)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31:5 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
| 4:2  | RW   | 0x2                | rst_pluse_lenth<br>Reset pulse length. This is used to select the number of pclk<br>cycles<br>for which the system reset stays asserted.<br>000: 2 pclk cycles<br>001: 4 pclk cycles<br>010: 8 pclk cycles<br>011: 16 pclk cycles<br>100: 32 pclk cycles<br>101: 64 pclk cycles<br>110: 128 pclk cycles<br>111: 256 pclk cycles |  |  |  |  |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                              |  |  |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1   | RW   | 0×1                | <ul><li>resp_mode</li><li>Response mode. Selects the output response generated to a timeout.</li><li>0: Generate a system reset.</li><li>1: First generate an interrupt and if it is not cleared by the time a</li></ul> |  |  |
| 0   | RW   | 0×0                | second timeout occurs then generate a system reset<br>wdt_en<br>WDT enable:<br>0: WDT disabled;<br>1: WDT enabled                                                                                                        |  |  |

#### WDT\_TORR

Address: Operational Base + offset (0x0004)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      |      | 0x0                | reserved<br>timeout_period<br>Timeout period. This field is used to select the timeout period<br>from<br>which the watchdog counter restarts. A change of the timeout<br>period takes effect only after the next counter restart (kick).<br>The range of values available for a 32-bit watchdog counter are:<br>0000: 0x0000ffff<br>0001: 0x0001ffff<br>0010: 0x0003ffff<br>0010: 0x0003ffff<br>0101: 0x0007ffff<br>0100: 0x000fffff<br>0111: 0x007fffff<br>1010: 0x003fffff<br>1001: 0x03ffffff<br>1001: 0x03ffffff<br>1011: 0x07fffff<br>1011: 0x07ffffff<br>1101: 0x07ffffff<br>1101: 0x1fffffff<br>1101: 0x1fffffff |

WDT\_CCVR Address: Operational Base + offset (0x0008)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                        |  |  |
|------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:0 | RO   | 0×00000000         | cur_cnt<br>Current counter value.<br>This register, when read, is the current value of the internal<br>counter. This value is read coherently when ever it is read |  |  |

#### WDT\_CRR

Address: Operational Base + offset (0x000c)

| Bit  | Attr    | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                |  |  |
|------|---------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:8 | RO      | 0x0                | reserved                                                                                                                                                                                                                                                   |  |  |
| 7:0  | W1<br>C | 0x00               | cnt_restart<br>Counter restart. This register is used to restart the WDT counter.<br>As a safety feature to prevent accidental restarts, the value 0x76<br>must be written. A restart also clears the WDT interrupt. Reading<br>this register returns zero |  |  |

#### WDT\_STAT

Address: Operational Base + offset (0x0010)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |  |  |  |
|------|------|--------------------|------------------------------------------------------|--|--|--|
| 31:1 | RO   | 0x0                | reserved                                             |  |  |  |
|      |      | 0×0                | wdt_status                                           |  |  |  |
| 0    |      |                    | This register shows the interrupt status of the WDT. |  |  |  |
| 0    | RO   |                    | 1: Interrupt is active regardless of polarity;       |  |  |  |
|      |      |                    | 0: Interrupt is inactive                             |  |  |  |

#### WDT\_EOI

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                      |  |  |
|------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31:1 | RO   | 0x0                | reserved                                                                                                                         |  |  |
| 0    | RO   | 0x0                | wdt_int_clr<br>Clears the watchdog interrupt. This can be used to clear the<br>interrupt without restarting the watchdog counter |  |  |

# 24.5 Application Notes

#### 24.5.1 Programming sequence

The following figure show the operation flow chart (Response mode=1).



1. Select required timeout period.

2. Set reset pulse length, response mode, and enable WDT.

3. Write 0x76 to WDT\_CRR.

4. Starts back to selected timeout period.

5. Can clear by reading WDT\_EOI or restarting (kicking) the counter by writing 0x76 to WDT\_CRR.

Fig. 24-2 WDT Operation Flow

# **Chapter 25 SAR-ADC**

## 25.1 Overview

The ADC is a 6-channel signal-ended 10-bit Successive Approximation Register (SAR) A/D Converter. It uses the supply and ground as it reference which avoid use of any external reference. It converts the analog input signal into 10-bit binary digital codes at maximum conversion rate of 1MSPS with 13MHz A/D converter clock.

# 25.2 Block Diagram



Fig. 25-1 RK3308 SAR-ADC block diagram

#### Successive-Approximate Register and Control Logic Block

This block is exploited to realize binary search algorithm, storing the intermediate result and generate control signal for analog block.

#### **Comparator Block**

This block compares the analog input SARADC\_AIN[2:0] with the voltage generated from D/A Converter, and output the comparison result to SAR and Control Logic Block for binary search. Three level amplifiers are employed in this comparator to provide enough gain.

# **25.3 Function Description**

#### 25.3.1 APB Interface

In RK3308, SAR-ADC works at single-sample operation mode.

This mode is useful to sample an analog input when there is a gap between two samples to be converted. In this mode START is asserted only on the rising edge of CLKIN where conversion is needed. At the end of every conversion EOC signal is made high and valid output data is available at the rising edge of EOC. The detailed timing diagram will be shown in the following.

# **25.4 Register description**

#### 25.4.1 Registers Summary

| Name        | Offset | Size | Reset Value | Description                    |
|-------------|--------|------|-------------|--------------------------------|
| SARADC DATA | 0x0000 | W    | 0x00000000  | The data after A/D conversion. |
| SARADC STAS | 0x0004 | w    | 0x00000000  | The status register of A/D     |
| <u> </u>    | •      |      |             | converter.                     |

| Name              | Offset | Size | <b>Reset Value</b> | Description                               |
|-------------------|--------|------|--------------------|-------------------------------------------|
| SARADC_CTRL       | 0x0008 | w    | UXUUUUUUUUU        | The control register of A/D<br>Converter. |
| SARADC DLY PU SOC | 0x000c | w    | 0x000000000        | Delay between power up and start command. |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

#### 25.4.2 Detail Register Description

#### SARADC\_DATA

Address: Operational Base + offset (0x0000) This register contains the data after A/D conversion.

| Bit   | Attr | <b>Reset Value</b> | Description                                              |  |  |
|-------|------|--------------------|----------------------------------------------------------|--|--|
| 31:10 | RO   | 0x0                | reserved                                                 |  |  |
| 9:0   | RO   | 0x000              | adc_data<br>A/D value of the last conversion (DOUT[9:0]) |  |  |

#### SARADC\_STAS

Address: Operational Base + offset (0x0004)The status register of A/D converter.

| Bit  | Attr | <b>Reset Value</b> | Description                  |  |  |
|------|------|--------------------|------------------------------|--|--|
| 31:1 | RO   | 0x0                | reserved                     |  |  |
|      |      | 0x0                | adc_status                   |  |  |
| 0    | RO   |                    | ADC status                   |  |  |
| 0    | ĸŪ   |                    | 1'b0: ADC stop               |  |  |
|      |      |                    | 1'b1: Conversion in progress |  |  |

#### SARADC\_CTRL

Address: Operational Base + offset (0x0008)The control register of A/D converter.

| Bit  | Attr | Reset Value | Description                                                      |  |  |
|------|------|-------------|------------------------------------------------------------------|--|--|
| 31:7 | RO   | 0x0         | reserved                                                         |  |  |
|      |      |             | int_status                                                       |  |  |
| 6    | RW   | 0x0         | Interrupt status.                                                |  |  |
| 0    | ĸvv  | 0.00        | This bit will be set to 1 when end-of-conversion.                |  |  |
|      |      |             | Set 0 to clear the interrupt                                     |  |  |
|      |      |             | int_en                                                           |  |  |
| 5    | RW   | 0x0         | Interrupt enable.                                                |  |  |
| 5    | κw   |             | 1'b0: Disable                                                    |  |  |
|      |      |             | 1'b1: Enable                                                     |  |  |
| 4    | RO   | 0x0         | reserved                                                         |  |  |
|      |      |             | adc_power_ctrl                                                   |  |  |
|      |      |             | ADC power down control bit                                       |  |  |
| 3    | RW   | V 0x0       | 1'b0: ADC power down                                             |  |  |
| 5    | r vv |             | 1'b1: ADC power up and reset                                     |  |  |
|      |      |             | start signal will be asserted (DLY_PU_SOC + 2) sclk clock period |  |  |
|      |      |             | later after power up                                             |  |  |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                   |  |  |
|-----|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 2:0 | RW   | 0×0                | adc_input_src_sel<br>ADC input source selection(CH_SEL[2:0]).<br>3'b000: Input source 0 (SARADC_AIN[0])<br>3'b001: Input source 1 (SARADC_AIN[1])<br>3'b010: Input source 2 (SARADC_AIN[2])<br>3'b011: Input source 3 (SARADC_AIN[3])<br>3'b100: Input source 4 (SARADC_AIN[4])<br>3'b101: Input source 5 (SARADC_AIN[5])<br>Others: Reserved |  |  |

#### SARADC\_DLY\_PU\_SOC

Address: Operational Base + offset (0x000c) delay between power up and start command

| Bit          | Attr | Reset Value | Description                                                   |
|--------------|------|-------------|---------------------------------------------------------------|
| 31:6         | RO   | 0x0         | reserved                                                      |
|              |      |             | DLY_PU_SOC                                                    |
| <b>F</b> · O |      |             | delay between power up and start command                      |
| 5:0          | RVV  |             | The start signal will be asserted (DLY_PU_SOC + 2) sclk clock |
|              |      |             | period later after power up                                   |

# 25.5 Timing Diagram



Fig. 25-2 SAR-ADC timing diagram in single-sample conversion mode

The following table shows the detailed value for timing parameters in the above diagram.

| Table OF 1 DV2200 CAD ADC time a series | at awa liat |
|-----------------------------------------|-------------|
| Table 25-1 RK3308 SAR-ADC timing param  | eters list  |

| Parameter                 | Symbol    | Condition | Min  | Тур | Max  | Unit |
|---------------------------|-----------|-----------|------|-----|------|------|
| Operating                 | Condition |           |      |     |      |      |
| Analog Supply             | AVDD      |           | 1.62 | 1.8 | 1.98 | V    |
| Digital Supply            | VDD       |           | 0.81 | 0.9 | 0.99 | V    |
| Junction Temperature      | Tj        |           | -40  |     | 125  | °C   |
| Saradc Pe                 | rformance |           |      |     |      |      |
| Resolution                |           |           |      | 10  |      | bit  |
| Effective Number of Bit   | ENOB      |           |      | 9   |      | bit  |
| Differential Nonlinearity | DNL       |           | -1   |     | 1    | LSB  |
| Intergral Nonlinearity    | INL       |           | -2   |     | 2    | LSB  |
| Input Voltage Range       | Vin       |           | 0    |     | 1    | AVDD |

| Parameter                                        | Symbol            | Condition  | Min      | Тур | Max | Unit |
|--------------------------------------------------|-------------------|------------|----------|-----|-----|------|
| Input Capacitance                                | Cin               |            |          | 10  |     | pF   |
| Sampling Rate                                    | fs                |            |          |     | 1   | MS/s |
| Spurious Free Dynamic Range                      | SFDR              | fs=1MS/s   |          | 61  |     | dB   |
|                                                  |                   | fout =     |          |     |     |      |
|                                                  |                   | 1.17KHz    |          |     |     |      |
| Signal to Noise and Harmonic Ratio               | SNDR              |            |          | 56  |     | dB   |
| Timing Ch                                        | aracteristic      | :          | <b>F</b> | 1   |     |      |
| Clock Frequency                                  | fCLK              |            |          |     | 13  | MHz  |
| Clock Period                                     | tCLK              |            | 75       |     |     | ns   |
| Clock Duty Cycle                                 |                   |            | 45       |     | 55  | %    |
| Conversion Time                                  |                   |            | 13       |     |     | tCLK |
| Setup Time of soc signal                         | Ts                |            |          | 0.5 |     | tCLK |
| Hold Time of soc signal                          | Th                |            |          | 0.5 |     | tCLK |
| Time Interval between Transition of sel[2:0] and | Tsel1             |            | 1        |     |     | tCLK |
| Rising Edge of 1st clock                         |                   |            |          |     |     |      |
| Rising Edge of 1st clock and Time Interval       | Tsel2             |            | 2        |     |     | tCLK |
| between Transition of sel[2:0]                   |                   |            |          |     |     |      |
| High Level Time of eoc signal                    | Teoc              |            | 1        |     |     | tCLK |
| Power Co                                         | nsumption         |            |          |     | -   |      |
| Analog Supply Current                            | I <sub>AVDD</sub> | fs=1MS/s   |          | 450 |     | uA   |
|                                                  |                   | Power Down |          | 1   |     | uA   |
| Digital Supply Current                           | I <sub>VDD</sub>  | fs=1MS/s   |          | 50  |     | uA   |
|                                                  |                   | Power Down |          | 1   |     | uA   |

# **25.6 Application Notes**

Steps of adc conversion:

- Write SARADC\_CTRL[3] as 0 to power down adc converter.
- Write SARADC\_CTRL[2:0] as n to select adc channel(n).
- Write SARADC\_CTRL[5] as 1 to enable adc interrupt.
- Write SARADC\_CTRL[3] as 1 to power up adc converter.
- Wait for adc interrupt or poll SARADC\_STAS register to assert whether the conversion is completed
- Read the conversion result from SARADC\_DATA[9:0]
- Note: The A/D converter was designed to operate at maximum 1MHZ.

# Chapter 26 Temperature-Sensor ADC(TS-ADC)

# 26.1 Overview

TS-ADC Controller module supports user-defined mode and automatic mode. User-defined mode refers, TSADC all the control signals entirely by software writing to register for direct control. Automatic mode refers to the module automatically poll TSADC output, and the results were checked. If you find that the temperature over the defined high temperature value in a period of time, an interrupt is generated to the processor down-measures taken; if the temperature over the defined SHUT temperature value, the resulting TSHUT gave CRU module, let it reset the entire chip, or via GPIO give PMIC.

TS-ADC Controller supports the following features:

- Support User-Defined Mode and Automatic Mode
- In User-Defined Mode, start\_of\_conversion can be controlled completely by software, and also can be generated by hardware.
- In Automatic Mode, the temperature of alarm(high/low temperature) interrupt can be configurable
- In Automatic Mode, the temperature of system reset can be configurable
- Support to 2 channel TS-ADC, the temperature criteria of each channel can be configurable
- In Automatic Mode, the time interval of temperature detection can be configurable
- In Automatic Mode, when detecting a high temperature, the time interval of temperature detection can be configurable
- High temperature debounce can be configurable
- -40~125°C temperature range and 5°C temperature resolution
- 12-bit SARADC up to 50KS/s sampling rate

# 26.2 Block Diagram

TS-ADC controller comprises with:

- APB Interface
- TS-ADC control logic





# **26.3 Function Description**

## 26.3.1 APB Interface

There is an APB Slave interface in TS-ADC Controller, which is used to configure the TS-ADC Controller registers and look up the temperature from the temperature sensor.

#### 26.3.2 TS-ADC Controller

This block is exploited to realize binary search algorithm, storing the intermediate result and generate control signal for analog block. This block compares the analog input with the voltage generated from D/A Converter, and output the comparison result to SAR and Control Logic Block for binary search. Three level amplifiers are employed in this comparator to provide enough gain.

# 26.4 Register description

#### 26.4.1 Registers Summary

| Name                           | Offset | Size | Reset<br>Value | Description                                                    |
|--------------------------------|--------|------|----------------|----------------------------------------------------------------|
| TSADC_USER_CON                 | 0x0000 | w    | 0x00000200     | The control register of A/D converter.                         |
| TSADC_AUTO_CON                 | 0x0004 | W    | 0x00000000     | TSADC auto mode control register                               |
| TSADC_INT_EN                   | 0x0008 | W    | 0x00000000     | TSADC interrupts enable control                                |
| TSADC_INT_PD                   | 0x000c | W    | 0x00000000     | TSADC interrupts status                                        |
| TSADC_DATA0                    | 0x0020 | w    | 0x00000000     | This register contains the data from CH0 after A/D conversion. |
| TSADC_DATA1                    | 0x0024 | w    | 0x00000000     | This register contains the data from CH1 after A/D conversion. |
| TSADC_COMP0_INT                | 0x0030 | w    | 0x00000000     | TSADC high temperature level for source 0                      |
| TSADC_COMP1_INT                | 0x0034 | w    | 0x00000000     | TSADC high temperature level for source 1                      |
| TSADC_COMP0_SHUT               | 0x0040 | w    | 0x00000000     | TSADC shut temperature level for source 0                      |
| TSADC_COMP1_SHUT               | 0x0044 | w    | 0x00000000     | TSADC shut temperature level for source 1                      |
| TSADC_HIGHT_INT_DEBO<br>UNCE   | 0x0060 | w    | 0x00000003     | High temperature debounce                                      |
| TSADC_HIGHT_TSHUT_D<br>EBOUNCE | 0x0064 | w    | 0x0000003      | Shut temperature debounce                                      |
| TSADC_AUTO_PERIOD              | 0x0068 | W    | 0x00010000     | TSADC auto access period                                       |
| TSADC_AUTO_PERIOD_H<br>T       | 0x006c | W    | 0x00010000     | TSADC auto access period when temperature is high              |
| TSADC_COMP0_LOW_INT            | 0x0080 | W    | 0x00000000     | TSADC low temperature level for source 0                       |
| TSADC_COMP1_LOW_INT            | 0x0084 | W    | 0×00000000     | TSADC low temperature level for source 1                       |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

#### 26.4.2 Detail Register Description

#### TSADC\_USER\_CON

Address: Operational Base + offset (0x0000) The control register of A/D Converter.

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
| 31:13 | RO   | 0x0                | reserved                                                        |
|       |      |                    | adc_status                                                      |
| 1.2   | RO   | 0x0                | ADC status (EOC)                                                |
| 12    | кU   | UXU                | 1'b0: ADC stop                                                  |
|       |      |                    | 1'b1: Conversion in progress                                    |
| 11:6  | RW   | 0x08               | inter_pd_soc                                                    |
| 11.0  | r vv | 0x08               | interleave between power down and start of conversion           |
|       |      |                    | start                                                           |
|       |      |                    | When software write 1 to this bit , start_of_conversion will be |
| 5     | RW   | 0x0                | assert.                                                         |
|       |      |                    | This bit will be cleared after TSADC access finishing.          |
|       |      |                    | When TSADC_USER_CON[4] = 1'b1 take effect.                      |
|       |      |                    | start_mode                                                      |
|       |      |                    | start mode.                                                     |
| 4     | RW   | 0x0                | 1'b0: tsadc controller will asert start_of_conversion after     |
| •     |      |                    | "inter_pd_soc" cycles.                                          |
|       |      |                    | 1'b1: the start_of_conversion will be controlled by             |
|       |      |                    | TSADC_USER_CON[5].                                              |
|       |      |                    | adc_power_ctrl                                                  |
| 3     | RW   | 0x0                | ADC power down control bit                                      |
|       |      |                    | 1'b0: ADC power down                                            |
|       |      |                    | 1'b1: ADC power up and reset                                    |
|       |      |                    | adc_input_src_sel                                               |
|       |      |                    | ADC input source selection(CH_SEL[2:0]).                        |
| 2:0   | RW   | 0x0                | 3'b000: Input source 0 (SARADC_AIN[0])                          |
|       |      |                    | 3'b001: Input source 1 (SARADC_AIN[1])                          |
|       |      |                    | Others: Reserved                                                |

#### TSADC\_AUTO\_CON

Address: Operational Base + offset (0x0004) TSADC auto mode control register

| IJADC | auto | mode control       |                                                                 |
|-------|------|--------------------|-----------------------------------------------------------------|
| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
| 31:26 | RO   | 0x0                | reserved                                                        |
|       |      |                    | last_tshut_2cru                                                 |
|       |      |                    | last_tshut_2cru for cru first/second reset TSHUT status.        |
| 25    | RW   | 0x0                | This bit will set to 1 when tshut is valid, and only be cleared |
|       |      |                    | when application write 1 to it.                                 |
|       |      |                    | This bit will not be cleared by system reset.                   |
|       |      |                    | last_tshut_2gpio                                                |
|       |      |                    | last_tshut_2gpio for hardware reset TSHUT status.               |
| 24    | RW   | 0x0                | This bit will set to 1 when tshut is valid, and only be cleared |
|       |      |                    | when application write 1 to it.                                 |
|       |      |                    | This bit will not be cleared by system reset.                   |
| 23:18 | RO   | 0x0                | reserved                                                        |

| Bit   | Attr  | <b>Reset Value</b> | Description                                                     |
|-------|-------|--------------------|-----------------------------------------------------------------|
|       |       |                    | sample_dly_sel                                                  |
| 17    | RO    | 0x0                | 1'b0: AUTO_PERIOD is used                                       |
|       |       |                    | 1'b1: AUTO_PERIOD_HT is used                                    |
|       |       |                    | auto_status                                                     |
| 16    | RO    | 0x0                | 1'b0: auto mode stop                                            |
|       |       |                    | 1'b1: auto mode in progress                                     |
| 15:14 | RO    | 0x0                | reserved                                                        |
|       |       |                    | src1_lt_en                                                      |
| 13    | RW    | 0x0                | 1'b0: do not care low temperature of source 1                   |
|       |       |                    | 1'b1: enable the low temperature monitor of source 1            |
|       |       |                    | src0_lt_en                                                      |
| 12    | RW    | 0x0                | 1'b0: do not care low temperature of source 0                   |
|       |       |                    | 1'b1: enable the low temperature monitor of source 0            |
| 11:9  | RO    | 0x0                | reserved                                                        |
|       |       |                    | tshut_prolarity                                                 |
| 8     | RW    | 0x0                | 1'b0: low active                                                |
|       |       |                    | 1'b1: high active                                               |
| 7:6   | RO    | 0x0                | reserved                                                        |
|       |       |                    | src1_en                                                         |
| 5     | RW    | 0x0                | 1'b0: do not care the temperature of source 1                   |
| 5     | L A A | 0.00               | 1'b1: if the temperature of source 1 is too high, TSHUT will be |
|       |       |                    | valid                                                           |
|       |       |                    | src0_en                                                         |
| 4     | RW    | 0x0                | 1'b0: do not care the temperature of source 0                   |
| -     | 1     | 0.00               | 1'b1: if the temperature of source 0 is too high, TSHUT will be |
|       |       |                    | valid                                                           |
| 3:2   | RO    | 0x0                | reserved                                                        |
|       |       |                    | tsadc_q_sel                                                     |
| 1     | RW    | V 0×0              | temperature coefficient                                         |
| 1     | 1     | 0.00               | 1'b0:use tsadc_q as output                                      |
|       |       |                    | 1'b1:use(4096 - tsadc_q) as output                              |
|       |       |                    | auto_en                                                         |
| 0     | RW    | 0x0                | 1'b0: TSADC controller works at user-define mode                |
|       |       |                    | 1'b1: TSADC controller works at auto mode                       |

## TSADC\_INT\_EN

Address: Operational Base + offset (0x0008)

| Bit   | Attr | <b>Reset Value</b> | Description                               |  |
|-------|------|--------------------|-------------------------------------------|--|
| 31:17 | RO   | 0x0                | reserved                                  |  |
|       |      |                    | eoc_int_en                                |  |
|       |      |                    | eoc_Interrupt enable.                     |  |
| 16    | RW   | 0x0                | eoc_interrupt enable in user defined mode |  |
|       |      |                    | 1'b0: disable                             |  |
|       |      |                    | 1'b1: enable                              |  |

| Bit   | Attr | Reset Value | Description                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | RO   | 0x0         | reserved                                                                                                                     |
| 13    | RW   | 0×0         | It_inten_src1<br>low temperature interrupt enable for src1<br>1'b0: disable<br>1'b1: enable                                  |
| 12    | RW   | 0×0         | lt_inten_src0<br>low temperature interrupt enable for src0<br>1'b0: disable<br>1'b1: enable                                  |
| 11:10 | RO   | 0x0         | reserved                                                                                                                     |
| 9     | RW   | 0×0         | tshut_2cru_en_src1<br>1'b0: TSHUT output to cru disabled. TSHUT output will always<br>keep low<br>1'b1: TSHUT output works   |
| 8     | RW   | 0×0         | tshut_2cru_en_src0<br>1'b0: TSHUT output to cru disabled. TSHUT output will always<br>keep low<br>1'b1: TSHUT output works   |
| 7:6   | RO   | 0x0         | reserved                                                                                                                     |
| 5     | RW   | 0×0         | tshut_2gpio_en_src1<br>1'b0: TSHUT output to gpio disabled. TSHUT output will always<br>keep low<br>1'b1: TSHUT output works |
| 4     | RW   | 0x0         | tshut_2gpio_en_src0<br>1'b0: TSHUT output to gpio disabled. TSHUT output will always<br>keep low<br>1'b1: TSHUT output works |
| 3:2   | RO   | 0x0         | reserved                                                                                                                     |
| 1     | RW   | 0x0         | ht_inten_src1<br>high temperature interrupt enable for src1<br>1'b0: disable<br>1'b1: enable                                 |
| 0     | RW   | 0x0         | ht_inten_src0<br>high temperature interrupt enable for src0<br>1'b0: disable<br>1'b1: enable                                 |

#### TSADC\_INT\_PD

Address: Operational Base + offset (0x000c)

| Bit   | Attr | <b>Reset Value</b> | Description |
|-------|------|--------------------|-------------|
| 31:17 | RO   | 0x0                | reserved    |

| Bit   | Attr  | <b>Reset Value</b> | Description                                                   |
|-------|-------|--------------------|---------------------------------------------------------------|
|       |       |                    | eoc_int_pd                                                    |
| 10    |       | 0.40               | Interrupt status.                                             |
| 16    | RW    | 0x0                | This bit will be set to 1 when end-of-conversion.             |
|       |       |                    | Set 0 to clear the interrupt.                                 |
| 15:14 | RO    | 0x0                | reserved                                                      |
|       |       |                    | lt_irq_src1                                                   |
|       |       |                    | When TSADC output is lower than COMP_INT_LOW, this bit will   |
| 13    | RW    | 0x0                | be valid, which means temperature is low, and the application |
|       |       |                    | should in charge of this.                                     |
|       |       |                    | write 1 to it, this bit will be cleared.                      |
|       |       |                    | lt_irq_src0                                                   |
|       |       |                    | When TSADC output is lower than COMP_INT_LOW, this bit will   |
| 12    | l2 RW | 0x0                | be valid, which means temperature is low, and the application |
|       |       |                    | should in charge of this.                                     |
|       |       |                    | write 1 to it, this bit will be cleared.                      |
| 11:6  | RO    | 0x0                | reserved                                                      |
|       |       | W 0×0              | tshut_o_src1                                                  |
|       |       |                    | TSHUT output status                                           |
| 5     | RW    |                    | When TSADC output is bigger than COMP_SHUT, this bit will be  |
| -     |       |                    | valid, which means temperature is VERY high, and the          |
|       |       |                    | application should in charge of this.                         |
|       |       |                    | write 1 to it, this bit will be cleared.                      |
|       |       |                    | tshut_o_src0                                                  |
|       |       |                    | TSHUT output status                                           |
| 4     | RW    | 0x0                | When TSADC output is bigger than COMP_SHUT, this bit will be  |
| -     |       |                    | valid, which means temperature is VERY high, and the          |
|       |       |                    | application should in charge of this.                         |
|       |       |                    | write 1 to it, this bit will be cleared.                      |
| 3:2   | RO    | 0x0                | reserved                                                      |
|       |       |                    | ht_irq_src1                                                   |
|       |       |                    | When TSADC output is bigger than COMP_INT, this bit will be   |
| 1     | RW    | 0x0                | valid, which means temperature is high, and the application   |
|       |       |                    | should in charge of this.                                     |
|       |       |                    | write 1 to it, this bit will be cleared.                      |
|       |       |                    | ht_irq_src0                                                   |
|       |       |                    | When TSADC output is bigger than COMP_INT, this bit will be   |
| 0     | RW    | 0x0                | valid, which means temperature is high, and the application   |
|       |       |                    | should in charge of this.                                     |
|       |       |                    | write 1 to it, this bit will be cleared.                      |

## TSADC\_DATA0

Address: Operational Base + offset (0x0020) This register contains the data after A/D Conversion.

| Bit   | Attr | <b>Reset Value</b> | Description |
|-------|------|--------------------|-------------|
| 31:12 | RO   | 0x0                | reserved    |

| Bit  | Attr | <b>Reset Value</b> | Description                                                          |
|------|------|--------------------|----------------------------------------------------------------------|
| 11:0 | RO   | 0x000              | adc_data<br>A/D value of the channel 0 last conversion (DOUT[11:0]). |

### TSADC\_DATA1

Address: Operational Base + offset (0x0024)

This register contains the data after A/D Conversion.

| Bit   | Attr | <b>Reset Value</b> | Description                                                          |
|-------|------|--------------------|----------------------------------------------------------------------|
| 31:12 | RO   | 0x0                | reserved                                                             |
| 11:0  | RO   | 0x000              | adc_data<br>A/D value of the channel 1 last conversion (DOUT[11:0]). |

### TSADC\_COMP0\_INT

Address: Operational Base + offset (0x0030) TSADC high temperature level for source 0

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                               |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | RO   | 0x0                | reserved                                                                                                                                                  |
| 11:0  | RW   | 0×000              | tsadc_comp_src0<br>TSADC high temperature level.<br>TSADC output is bigger than tsadc_comp, means the<br>temperature is high.<br>TSADC_INT will be valid. |

#### TSADC\_COMP1\_INT

Address: Operational Base + offset (0x0034)TSADC high temperature level for source 1

| ISADC high temperature level for so |      |                    |                                                                                                                                                           |
|-------------------------------------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                 | Attr | <b>Reset Value</b> | Description                                                                                                                                               |
| 31:12                               | RO   | 0x0                | reserved                                                                                                                                                  |
| 11:0                                | RW   | 0×000              | tsadc_comp_src1<br>TSADC high temperature level.<br>TSADC output is bigger than tsadc_comp, means the<br>temperature is high.<br>TSADC_INT will be valid. |

#### TSADC\_COMP0\_SHUT

Address: Operational Base + offset (0x0040) TSADC high temperature level for source 0

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | RO   | 0x0         | reserved                                                                                                                          |
| 11:0  | RW   | 0x000       | tsadc_comp_src0<br>TSADC high temperature level.<br>TSADC output is bigger than tsadc_comp, means the<br>temperature is too high. |
|       |      |             | TSHUT will be valid.                                                                                                              |

#### TSADC\_COMP1\_SHUT

Address: Operational Base + offset (0x0044) TSADC high temperature level for source 1

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                               |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | RO   | 0x0                | reserved                                                                                                                                                  |
| 11:0  | RW   | 0×000              | tsadc_comp_src1<br>TSADC high temperature level.<br>TSADC output is bigger than tsadc_comp, means the<br>temperature is too high.<br>TSHUT will be valid. |

#### TSADC\_HIGHT\_INT\_DEBOUNCE

Address: Operational Base + offset (0x0060)

High temperature debounce

| Bit  | Attr | <b>Reset Value</b> | Description                                                 |
|------|------|--------------------|-------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                    |
|      |      |                    | debounce                                                    |
| 7:0  | RW   | 0x03               | TSADC controller will only generate interrupt or TSHUT when |
|      |      |                    | temperature is higher than COMP_INT for "debounce" times.   |

#### TSADC\_HIGHT\_TSHUT\_DEBOUNCE

Address: Operational Base + offset (0x0064) Shut temperature debounce

| Bit  | Attr | <b>Reset Value</b> | Description                                                 |
|------|------|--------------------|-------------------------------------------------------------|
| 31:8 | RO   | 0x0                | reserved                                                    |
|      |      |                    | debounce                                                    |
| 7:0  | RW   | 0x03               | TSADC controller will only generate interrupt or TSHUT when |
|      |      |                    | temperature is higher than COMP_SHUT for "debounce" times.  |

#### TSADC\_AUTO\_PERIOD

Address: Operational Base + offset (0x0068)

## TSADC auto access period

| Bit  | Attr | Reset Valu | e Description                                                    |
|------|------|------------|------------------------------------------------------------------|
|      |      |            | auto_period                                                      |
| 31:0 | RW   | 0x00010000 | When auto mode is enabled, this register controls the interleave |
|      |      |            | between every two accessing of TSADC.                            |

#### TSADC\_AUTO\_PERIOD\_HT

Address: Operational Base + offset (0x006c) TSADC auto access period when temperature is high

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                                                                 |
|------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00010000         | auto_period<br>This register controls the interleave between every two accessing<br>of TSADC after the temperature is higher than COMP_SHUT or<br>COMP_INT. |

#### TSADC\_COMP0\_LOW\_INT

Address: Operational Base + offset (0x0080) TSADC low temperature level for source 0

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                          |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:12 | RO   | 0x0                | reserved                                                                                             |
|       |      |                    | tsadc_comp_src0<br>TSADC low temperature level.                                                      |
| 11:0  | RW   | 0x000              | TSADC output is lower than tsadc_comp, means the temperature is low.<br>TSADC_LOW_INT will be valid. |

#### TSADC\_COMP1\_LOW\_INT

Address: Operational Base + offset (0x0084) TSADC low temperature level for source 1

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
| 31:12 | RO   | 0x0                | reserved                                                     |
|       |      |                    | tsadc_comp_src1                                              |
|       |      |                    | TSADC low temperature level.                                 |
| 11:0  | RW   | 0x000              | TSADC output is lower than tsadc_comp, means the temperature |
|       |      |                    | is low.                                                      |
|       |      |                    | TSADC_LOW_INT will be valid.                                 |

# **26.5 Application Notes**

#### 26.5.1 Channel Select

The system has two Temperature Sensors, channel 0 is for logic power domain and channel 1 is for core power domain.

## 26.5.2 Single-sample conversion



Fig. 26-2 the start flow to enable the sensor and adc

# 26.5.3 Temperature-to-code mapping

| Table 26-1 Temperature Code Mapping |               |               |  |  |  |  |
|-------------------------------------|---------------|---------------|--|--|--|--|
|                                     | Code          | Code          |  |  |  |  |
| temp(°C)                            | tsadc_q_sel=0 | tsadc_q_sel=1 |  |  |  |  |
| -40                                 | 3800          | 296           |  |  |  |  |
| -35                                 | 3792          | 304           |  |  |  |  |
| -30                                 | 3783          | 313           |  |  |  |  |
| -25                                 | 3774          | 322           |  |  |  |  |
| -20                                 | 3765          | 331           |  |  |  |  |
| -15                                 | 3756          | 340           |  |  |  |  |
| -10                                 | 3747          | 349           |  |  |  |  |
| -5                                  | 3737          | 359           |  |  |  |  |
| 0                                   | 3728          | 368           |  |  |  |  |
| 5                                   | 3718          | 378           |  |  |  |  |
| 10                                  | 3708          | 388           |  |  |  |  |
| 15                                  | 3698          | 398           |  |  |  |  |
| 20                                  | 3688          | 408           |  |  |  |  |
| 25                                  | 3678          | 418           |  |  |  |  |
| 30                                  | 3667          | 429           |  |  |  |  |
| 35                                  | 3656          | 440           |  |  |  |  |
| 40                                  | 3645          | 451           |  |  |  |  |
| 45                                  | 3634          | 462           |  |  |  |  |
| 50                                  | 3623          | 473           |  |  |  |  |
| 55                                  | 3611          | 485           |  |  |  |  |
| 60                                  | 3600          | 496           |  |  |  |  |
| 65                                  | 3588          | 508           |  |  |  |  |
| 70                                  | 3575          | 521           |  |  |  |  |
| 75                                  | 3563          | 533           |  |  |  |  |
| 80                                  | 3550          | 546           |  |  |  |  |
| 85                                  | 3537          | 559           |  |  |  |  |
| 90                                  | 3524          | 572           |  |  |  |  |
| 95                                  | 3510          | 586           |  |  |  |  |
| 100                                 | 3496          | 600           |  |  |  |  |
| 105                                 | 3482          | 614           |  |  |  |  |
| 110                                 | 3467          | 629           |  |  |  |  |
| 115                                 | 3452          | 644           |  |  |  |  |
| 120                                 | 3437          | 659           |  |  |  |  |
| 125                                 | 3421          | 675           |  |  |  |  |

Note:

Code to Temperature mapping of the Temperature sensor is a piece wise linear curve. Any temperature,

code faling between to 2 give temperatures can be linearly interpolated. Code to Temperature mapping should be updated based on sillcon results. **RK3308 tsadc\_q\_sel must be configured as 1'b1.** 

### 26.5.4 User-Define Mode

- In user-define mode, the PD\_DVDD and CHSEL\_DVDD are generate by setting register TSADC\_USER\_CON, bit[3] and bit[2:0]. In order to ensure timing between PD\_DVDD and CHSEL\_DVDD, the CHSEL\_DVDD must be set before the PD\_DVDD.
- In user-define mode, you can choose the method to control the START\_OF\_CONVERSION by setting bit[4] of TSADC\_USER\_CON. If set to 0, the start\_of\_conversion will be assert after "inter\_pd\_soc" cycles, which could be set by bit[11:6] of TSADC\_USER\_CON. And if start\_mode was set 1, the start\_of\_conversion will be controlled by bit[5] of TSADC\_USER\_CON.
- Software can get the two channel temperature from TSADC\_DATAn (n=0,1).

## 26.5.5 Automatic Mode

You can use the automatic mode with the following step:

- Set TSADC\_AUTO\_PERIOD, configure the interleave between every two accessing of TSADC in normal operation.
- Set TSADC\_AUTO\_PERIOD\_HT. configure the interval between every two accessing of TSADC after the temperature is higher than COMP\_SHUT or COMP\_INT.
- Set TSADC\_COMPn\_INT(n=0,1), configure the high temperature level, if TSADC output is larger than the value, means the temperature is high, tsadc\_int will be asserted.
- Set TSADC\_COMPn\_SHUT(n=0,1), configure the super high temperature level, if TSADC output is larger than the value, means the temperature is too high, TSHUT will be asserted.
- Set TSADC\_INT\_EN, you can enable the high temperature interrupt for all channel; and you can also set TSHUT output to GPIO to reset the whole chip; and you can set TSHUT output to CRU to reset the whole chip.
- Set TSADC\_HIGHT\_INT\_DEBOUNCE and TSADC\_HIGHT\_TSHUT\_DEBOUNCE, if the temperature is higher than COMP\_INT or COMP\_SHUT for "debounce" times, TSADC controller will generate interrupt or TSHUT.
- Set TSADC\_AUTO\_CON, enable the TSADC controller.

# Chapter 27 Timer

# 27.1 Overview

Timer is a programmable timer peripheral. This component is an APB slave device. There are 2 groups of timer (TIMER\_6CH\_0 & TIMER\_6CH\_1) and each has 6 counting up timers. The group of TIMER\_6CH\_1 is dedicated to secure mode, its clock and reset configuration registers are in SGRF unit.

Timer supports the following features:

- Two operation modes: free-running and user-defined count.
- TIMER\_6CH\_1's timer5 defined as A35 Generic Timer.

# 27.2 Block Diagram



Fig. 27-1 Timer Block Diagram

The above figure shows the architecture of the APB timers (include six programmable timer channels) that in the bus subsystem.

# **27.3 Function Description**

# 27.3.1 Timer clock

Timers are in the pd\_peri\_wrapper subsystem. The timer clock is 24MHz OSC.

## 27.3.2 Programming sequence

1. Initialize the timer by the TIMERn\_CONTROLREG ( $0 \le n \le 5$ ) register:

- Disable the timer by writing a "0" to the timer enable bit (bit 0). Accordingly, the timer\_en output signal is de-asserted.
- Program the timer mode—user-defined or free-running—by writing a "0" or "1" respectively, to the timer mode bit (bit 1).
- Set the interrupt mask as either masked or not masked by writing a "0" or "1" respectively, to the timer interrupt mask bit (bit 2).

2. Load the timer count value into the TIMERn\_LOAD\_COUNT1 ( $0 \le n \le 5$ ) and TIMERn\_LOAD\_COUNT0 ( $0 \le n \le 5$ ) register.

3. Enable the timer by writing a "1" to bit 0 of TIMERn\_CONTROLREG ( $0 \le n \le 5$ ).



Fig. 27-2 Timer Usage Flow

### 27.3.3 Loading a timer count value

The initial value for each timer is zero. The count register will count up to the value loaded in the register TIMERn\_LOAD\_COUNT1 and TIMERn\_ LOAD\_COUNT0. Two events can cause a timer to load zero:

- Timer is enabled after reset or disabled.
- Timer counts up to the value stored in TIMERn\_LOAD\_COUNT1 and TIMERn\_LOAD\_COUNT0, when timer is configured into free-running mode.

### 27.3.4 Timer mode selection

- User-defined count mode Timer loads zero (for incremental timers) as initial value. When the timer counts up to the value in TIMERn\_LOAD\_COUNT1 and TIMERn\_LOAD\_COUNT0, it will not automatically reload the counting register. User need to disable timer firstly and follow the programming sequence to make timer work again.
- Free-running mode Timer loads zero (for incremental timers) as initial value. Timer will automatically reload the counting register, when timer counts up to the value in TIMERn\_LOAD\_COUNT1 and TIMERn\_LOAD\_COUNT0.

# **27.4 Register Description**

## 27.4.1 Internal Address Mapping

The table below shows the base address for each timer internal.

| Name   | Timern Base Address Offset |
|--------|----------------------------|
| Timer0 | 0x00                       |
| Timer1 | 0x20                       |
| Timer2 | 0x40                       |
| Timer3 | 0x60                       |
| Timer4 | 0x80                       |
| Timer5 | 0xA0                       |

Table 27-1 Timer Internal Address Mapping Table

#### 27.4.2 Registers Summary

| Name                                       | Offset | Size | Reset<br>Value | Description                                                                       |
|--------------------------------------------|--------|------|----------------|-----------------------------------------------------------------------------------|
| <u>TIMER_TIMERn_LOAD_CO</u><br><u>UNT0</u> | 0x0000 | W    | 0×00000000     | Timern Load Count Register 0.<br>Low 32 bits Value to be loaded<br>into Timer n.  |
| <u>TIMER_TIMERn_LOAD_CO</u><br><u>UNT1</u> | 0x0004 | W    | 0×00000000     | Timern Load Count Register 1.<br>High 32 bits Value to be loaded<br>into Timer n. |

| Name                           | Offset | Size | Reset<br>Value | Description                                                                      |
|--------------------------------|--------|------|----------------|----------------------------------------------------------------------------------|
| TIMER TIMERn CURRENT<br>VALUE0 | 0x0008 | W    | 0×00000000     | Timern Current Value Register 0.<br>Low 32 bits of Current Value of<br>Timer n.  |
| TIMER TIMERn CURRENT<br>VALUE1 | 0x000c | W    | 0×00000000     | Timern Current Value Register 1.<br>High 32 bits of Current Value of<br>Timer n. |
| TIMER TIMERn CONTROL<br>REG    | 0x0010 | W    | 0x00000000     | Timern Control Register                                                          |
| TIMER_TIMERn_INTSTAT<br>US     | 0x0018 | W    | 0x00000000     | Timern Interrupt Status Register                                                 |

Notes: Size: B- Byte (8 bits) access, HW- Half WORD (16 bits) access, W-WORD (32 bits) access

# 27.4.3 Detail Register Description

# TIMER TIMERn LOAD COUNTO

Address: Operational Base + offset (0x0000)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |  |  |
|------|------|--------------------|----------------------------------------------------------------|--|--|
|      |      |                    | load_count_0                                                   |  |  |
| 31:0 | RW   | 0x00000000         | Low 32 bits Value to be loaded into Timer n. This is the value |  |  |
|      |      |                    | from which counting commences                                  |  |  |

### TIMER TIMERn LOAD COUNT1

Address: Operational Base + offset (0x0004)

| Bit  | Attr         | <b>Reset Value</b> | Description                                                                                    |  |  |
|------|--------------|--------------------|------------------------------------------------------------------------------------------------|--|--|
| 21.0 | <b>D</b> 14/ |                    | load_count_1                                                                                   |  |  |
| 31:0 | RW           |                    | High 32 bits Value to be loaded into Timer n. This is the value from which counting commences. |  |  |

## TIMER TIMERn CURRENT VALUE0

Address: Operational Base + offset (0x0008)

| Bit  | Attr | <b>Reset Value</b> | Description                              |  |  |  |
|------|------|--------------------|------------------------------------------|--|--|--|
| 31:0 | RO   | 0x00000000         | timern_current_value0                    |  |  |  |
| 51.0 | κυ   | 0.000000000        | Low 32 bits of Current Value of Timer n. |  |  |  |

#### TIMER TIMERn CURRENT VALUE1

Address: Operational Base + offset (0x000c)

| Bit  | Attr               | <b>Reset Value</b> | Description                               |  |  |
|------|--------------------|--------------------|-------------------------------------------|--|--|
| 31:0 |                    | 0x00000000         | timern_current_value1                     |  |  |
| 51.0 | 31:0 RO 0x00000000 |                    | High 32 bits of Current Value of Timer n. |  |  |

#### TIMER TIMERn CONTROLREG

| Addres | Address: Operational Base + offset (0x0010) |                    |             |  |  |  |
|--------|---------------------------------------------|--------------------|-------------|--|--|--|
| Bit    | Attr                                        | <b>Reset Value</b> | Description |  |  |  |
| 31:3   | RO                                          | 0x0                | reserved    |  |  |  |

| Bit | Attr | <b>Reset Value</b> | Description                   |
|-----|------|--------------------|-------------------------------|
|     |      |                    | timer_int_mask                |
| 2   | RW   | 0.40               | Timer interrupt mask          |
| 2   | RVV  | 0x0                | 1'b0: mask                    |
|     |      |                    | 1'b1: not mask                |
|     |      |                    | timer_mode                    |
| 1   | RW   | 0×0                | Timer mode                    |
| 1   | RVV  |                    | 1'b0: free-running mode       |
|     |      |                    | 1'b1: user-defined count mode |
|     |      |                    | timer_en                      |
| 0   |      | W 0×0              | Timer enable                  |
| 0   | RVV  |                    | 1'b0: disable                 |
|     |      |                    | 1'b1: enable                  |

#### TIMER TIMERN INTSTATUS

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                 |  |  |
|------|------|--------------------|-------------------------------------------------------------------------------------------------------------|--|--|
| 31:1 | RO   | 0x0                | reserved                                                                                                    |  |  |
|      |      |                    | timern_int                                                                                                  |  |  |
| 0    | RW   |                    | This register contains the interrupt status for Timer n. Write 1 to this register will clear the interrupt. |  |  |

# **27.5 Application Notes**

In the chip, the timer\_clk is from 24MHz OSC, asynchronous to the pclk. When user disables the timer enables bit (bit 0 of TIMERn\_CONTROLREG ( $0 \le n \le 5$ )), the timer en output signal is de-asserted, and timer\_clk will stop. When user enables the timer, the timer\_en signal is asserted and timer\_clk will start running.

The application is only allowed to re-config registers when timer\_en is low.



Fig. 27-3 Timing between timer\_en and timer\_clk Please refer to function description section for the timer usage flow.

# **Chapter 28 SPDIF Transmitter**

# 28.1 Overview

The SPDIF transmitter is a self-clocking, serial, unidirectional interface for the interconnection of digital audio equipment for consumer and professional applications, using linear PCM coded audio samples.

It provides the basic structure of the interface. Separate documents define items specific to particular applications.

When used in a professional application, the interface is primarily intended to carry monophonic or stereophonic programmes, at a 48 kHz sampling frequency and with a resolution of up to 24bits per sample; it may alternatively be used to carry signals sampled at 32 kHz or 44.1 kHz.

When used in a consumer application, the interface is primarily intended to carry stereophonic programmes, with a resolution of up to 20 bits per sample, an extension to 24 bits per sample being possible.

When used for other purposes, the interface is primarily intended to carry audio data coded other than as linear PCM coded audio samples. Provision is also made to allow the interface to carry data related to computer software or signals coded using non-linear PCM. The format specification for these applications is not part of this standard.

In all cases, the clock references and auxiliary information are transmitted along with the programme.

It supports following features:

- Support one internal 32-bit wide and 32-location deep sample data buffer
- Support two 16-bit audio data store together in one 32-bit wide location
- Support AHB bus interface
- Support biphase format stereo audio data output
- Support DMA handshake interface and configurable DMA water level
- Support sample data buffer empty and block terminate interrupt
- Support combine interrupt output
- Support 16 to 31 bit audio data left or right justified in 32-bit wide sample data buffer
- Support 48, 44.1, 32kHz sample rate
- Support 16, 20, 24 bits audio data transfer

# 28.2 Block Diagram



Fig. 28-1 SPDIF transmitter Block Diagram

# The SPDIF is composed by:

System Interface

The system interface implements the AHB slave operation. It contains not only control registers of transmitters and receiver inside but also interrupt and DMA handshaking interface.

#### **Clock Divider**

The clock divider implements clock generation function. It divides the the source clock MCLK to generate the working clock used for the digital audio data transformation and transmission.

#### **Parallel Audio Buffer**

The parallel audio buffer stores the audio data to be transmitted. The size of the FIFO is 32bits x 32.

#### **Serial Audio Converter**

The serial audio converter converts the parallel audio data from the parallel audio buffer to the serial audio data.

#### **Biphase Audio Generator**

The biphase audio generator reads serial audio data from the serial audio converter and generates biphase audio data based on IEC-60958 standard.

# 28.3 Function description

# 28.3.1 Frame Format

A frame is uniquely composed of two sub-frames. For linear coded audio applications, the rate of transmission of frames corresponds exactly to the source sampling frequency. In the 2-channel operation mode, the samples taken from both channels are transmitted by time multiplexing in consecutive sub-frames. The first sub-frame(left channel in stereophonic operation and primary channel in monophonic operation) normally use preamble M. However, the preamble is changed to preamble B once every 192 frame to identify the start of the block structure used to organize the channel status information. The second sub-frame (right in stereophonic operation and secondary channel in monophonic operation) always use preamble W.



#### Fig. 28-2 SPDIF Frame Format

In the single channel operation mode in a professional application, the frame format is the same as in the 2-channel mode. Data is carried only in the first sub-frame and may be duplicated in the second sub-frame. If the second sub-frame is not carrying duplicate data, then time slot 28 (validity flag) shall be set to logical '1' (not valid).

## 28.3.2 Sub-frame Format



#### Fig. 28-3 SPDIF Sub-frame Format

Each sub-frame is divided into 32 time slots, numbered from 0 to 31. Time slot 0 to 3 carries one of the three permitted preambles. Time slot 4 to 27 carry the audio sample word in linear 2's complement representation. The MSB is carried by time slot 27. When a 24-bit

coding range is used, the LSB is in time slot 4. When a 20-bit coding range is used, time slot 8 to 27 carry the audio sample word with the LSB in time slot 8.Time slot 4 to 7 may be used for other application. Under these circumstances, the bits in the time slot 4 to 7 are designated auxiliary sample bits.

If the source provides fewer bits than the interface allows (either 24 or 20),the unused LSBs are set to a logical '0'. For a non-linear PCM audio application or a data application the main data field may carry any other information. Time slot 28 carries the validity flag associated with the main data field. Time slot 29 carries 1 bit of the user data associated with the audio channel transmitted in the same sub-frame. Time slot 30 carries one bit of the channel status words associated with the main data field channel transmitted in the same sub-frame. Time slot 31 carries a parity bit such that time slots 4 to 31 inclusive carries an even number of ones and an even number of zeros.

## 28.3.3 Channel Coding



Fig. 28-4 SPDIF Channel Coding

To minimize the direct current component on the transmission line, to facilitate clock recovery from the data stream and to make the interface insensitive to the polarity of connections, time slots 4 to 31 are encoded in biphase-mark.

Each bit to be transmitted is represented by a symbol comprising two consecutive binary states. The first state of a symbol is always different from the second state of the previous symbol. The second state of the symbol is identical to the first if the bit to be transmitted is logical '0'. However, it is different from the first if the bit is logical '1'.

## 28.3.4 Preamble

Preambles are specific patterns providing synchronization and identification of the subframes and blocks.

To achieve synchronization within one sampling period and to make this process completely reliable, these patterns violate the biphase-mark code rules, thereby avoiding the possibility of data imitating the preambles.

A set of three preambles is used. These preambles are transmitted in the time allocated to four time slots (time slots 0 to 3) and are represented by eight successive states. The first state of the preamble is always different from the second state of the previous symbol.



Fig. 28-5 SPDIF Preamble

Like biphase code, these preambles are dc free and provide clock recovery. They differ in at least two states from any valid biphase sequence.

# **28.4 Register Description**

## 28.4.1 Registers Summary

| Name                | Offset | Size         | Reset<br>Value | Description                       |
|---------------------|--------|--------------|----------------|-----------------------------------|
| SPDIF CFGR          | 0x0000 | W            | 0x00000000     | Transfer Configuration Register   |
| SPDIF_SDBLR         | 0x0004 | W            | 0x00000000     | Sample Date Buffer Level Register |
| SPDIF DMACR         | 0x0008 | W            | 0x00000000     | DMA Control Register              |
| SPDIF_INTCR         | 0x000c | W            | 0x00000000     | Interrupt Control Register        |
| SPDIF_INTSR         | 0x0010 | W            | 0x00000000     | Interrupt Status Register         |
| SPDIF XFER          | 0x0018 | W            | 0x00000000     | Transfer Start Register           |
| SPDIF_SMPDR         | 0x0020 | W            | 0x00000000     | Sample Data Register              |
| SPDIF VLDFRn        | 0x0060 | W            | 0x00000000     | Validity Flag Register n          |
| SPDIF USRDRn        | 0x0090 | W            | 0x00000000     | User Data Register n              |
| SPDIF_CHNSRn        | 0x00c0 | W            | 0x00000000     | Channel Status Register n         |
| SPDIF BURTSINFO     | 0x00d0 | W            | 0x00000000     | Channel Burst Info Register       |
| SPDIF_REPETTION     | 0x0104 | W            | 0x00000000     | Channel Repetition Register       |
|                     | 0.0100 | 14/          | 0.00000000     | Shadow Channel Burst Info         |
| SPDIF BURTSINFO SHD | 0x0108 | W            | 0x00000000     | Register                          |
|                     | 0x010c | \ <b>\</b> / | 0,000,000,000  | Shadow Channel Repetition         |
| SPDIF_REPETTION_SHD |        | W            | 0x00000000     | Register                          |
| SPDIF_USRDR_SHDn    | 0x0190 | W            | 0x0000000      | Shadow User Data Register n       |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# 28.4.2 Detail Register Description

#### SPDIF\_CFGR

Address: Operational Base + offset (0x0000)

| Bit   | Attr | <b>Reset Value</b> | Description                                         |
|-------|------|--------------------|-----------------------------------------------------|
| 31:24 | RO   | 0x0                | reserved                                            |
|       |      | w oxoo             | MCD                                                 |
| 22.10 |      |                    | Fmclk/Fsdo                                          |
| 23:16 | RW   |                    | This parameter can be calculated by Fmclk/(Fs*128). |
|       |      |                    | Fs=the sample frequency be wanted                   |
| 15:9  | RO   | 0x0                | reserved                                            |

| Bit | Attr | <b>Reset Value</b> | Description                                                    |
|-----|------|--------------------|----------------------------------------------------------------|
|     |      |                    | РСМТҮРЕ                                                        |
| 8   | RW   | 0x0                | 1'b0: linear PCM                                               |
|     |      |                    | 1'b1: non-linear PCM                                           |
| 7   | wo   | 0x0                | CLR                                                            |
| /   | WU   | 0.00               | Write 1 to clear MCLK domain logic. Read return zero.          |
|     |      |                    | CSE                                                            |
|     |      |                    | 1'b0: disable                                                  |
| 6   | RW   | 0x0                | 1'b1: enable                                                   |
|     |      |                    | The bit should be set to 1 when the channel conveys non-linear |
|     |      |                    | PCM                                                            |
|     |      |                    | UDE                                                            |
| 5   | RW   | 0x0                | 1'b0: disable                                                  |
|     |      |                    | 1'b1: enable                                                   |
|     |      |                    | VFE                                                            |
| 4   | RW   | 0x0                | 1'b0: disable                                                  |
|     |      |                    | 1'b1: enable                                                   |
|     |      |                    | ADJ                                                            |
| 3   | RW   | 0x0                | 1'b0: Right justified                                          |
|     |      |                    | 1'b1: Left justified                                           |
|     |      |                    | НМТ                                                            |
| 2   | RW   | 0x0                | 1'b0: disable                                                  |
| 2   | r vv | UXU                | 1'b1: enable                                                   |
|     |      |                    | It is valid only when the valid data width is 16bit.           |
|     |      |                    | VDW                                                            |
|     |      |                    | 2'b00: 16bit                                                   |
| 1:0 | RW   | 0x0                | 2'b01: 20bit                                                   |
| 1.0 |      |                    | 2'b10: 24bit                                                   |
|     |      |                    | 2'b11: reserved                                                |
|     |      |                    | The valid data width is 16bit only for non-linear PCM          |

#### SPDIF\_SDBLR

Address: Operational Base + offset (0x0004)

| Bit  | Attr | <b>Reset Value</b> | Description                                                           |
|------|------|--------------------|-----------------------------------------------------------------------|
| 31:6 | RO   | 0x0                | reserved                                                              |
| 5:0  | RW   |                    | SDBLR<br>Contains the number of valid data entries in the sample data |
|      |      |                    | buffer.                                                               |

#### SPDIF\_DMACR

Address: Operational Base + offset (0x0008)

| Bit  | Attr | <b>Reset Value</b> |          | Description |  |
|------|------|--------------------|----------|-------------|--|
| 31:6 | RO   | 0x0                | reserved |             |  |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                      |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0×0                | TDE<br>1'b0: Transmit DMA disabled<br>1'b1: Transmit DMA enabled                                                                                                                                                                                                                                 |
| 4:0 | RW   | 0×00               | TDL<br>This bit field controls the level at which a DMA request is made by<br>the transmit logic. It is equal to the watermark level; that is, the<br>dma_tx_req signal is generated when the number of valid data<br>entries in the Sample Date Buffer is equal to or below this field<br>value |

#### SPDIF\_INTCR

Address: Operational Base + offset (0x000c)

| Bit   | Attr    | <b>Reset Value</b> | Description                                                                                                                                                                                                                                          |
|-------|---------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | RO      | 0x0                | reserved                                                                                                                                                                                                                                             |
| 17    | W1<br>C | 0x0                | UDTIC<br>Write '1' to clear the user data interrupt.                                                                                                                                                                                                 |
| 16    | W1<br>C | 0×0                | BTTIC<br>Write 1 to clear the interrupt.                                                                                                                                                                                                             |
| 15:10 | RO      | 0x0                | reserved                                                                                                                                                                                                                                             |
| 9:5   | RW      | 0x00               | SDBT<br>Sample Date Buffer Threshold for empty interrupt                                                                                                                                                                                             |
| 4     | RW      | 0×0                | SDBEIE<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                              |
| 3     | RW      | 0×0                | BTTIE<br>When enabled, an interrupt will be asserted when the block<br>transfer is finished if the channel conveys linear PCM or when the<br>repetition period is reached if the channel conveys non-linear<br>PCM.<br>1'b0: disable<br>1'b1: enable |
| 2     | RW      | 0×0                | UDTIE<br>1'b0: disable<br>1'b1: enable<br>If enabled, an interrupt will be asserted when the content of the<br>user data register is fed into the corresponding shadow register                                                                      |
| 1:0   | RO      | 0x0                | reserved                                                                                                                                                                                                                                             |

#### SPDIF\_INTSR

Address: Operational Base + offset (0x0010)

| Bit  | Attr | <b>Reset Value</b> | Description |
|------|------|--------------------|-------------|
| 31:5 | RO   | 0x0                | reserved    |

| Bit | Attr | Reset Value | Description    |
|-----|------|-------------|----------------|
|     |      |             | SDBEIS         |
| 4   | RW   | 0x0         | 1'b0: inactive |
|     |      |             | 1'b1: active   |
|     |      |             | BTTIS          |
| 3   | RW   | 0x0         | 1'b0: inactive |
|     |      |             | 1'b1: active   |
|     |      |             | UDTIS          |
| 2   | RW   | 0x0         | 1'b0: inactive |
|     |      |             | 1'b1: active   |
| 1:0 | RO   | 0x0         | reserved       |

#### SPDIF\_XFER

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description             |
|------|------|--------------------|-------------------------|
| 31:1 | RO   | 0x0                | reserved                |
| 0    |      | 00                 | XFER                    |
| U    | RW   | 0x0                | Transfer Start Register |

#### SPDIF\_SMPDR

Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description          |
|------|------|--------------------|----------------------|
| 31:0 | RW   | 0x00000000         | SMPDR                |
|      |      |                    | Sample Data Register |

### SPDIF\_VLDFRn

Address: Operational Base + offset (0x0060)

| Bit   | Attr | <b>Reset Value</b> | Description                  |
|-------|------|--------------------|------------------------------|
| 31:16 |      | 0x0000             | VLDFR_SUB_1                  |
| 51.10 | ĸvv  |                    | Validity Flag Register 0     |
| 15.0  |      | / 10x0000          | VLDFR_SUB_0                  |
| 15:0  | RW   |                    | Validity Flag For Subframe 0 |

### SPDIF\_USRDRn

Address: Operational Base + offset (0x0090)

| Bit   | Attr | <b>Reset Value</b> | Description                  |  |  |
|-------|------|--------------------|------------------------------|--|--|
| 31:16 |      | 0x0000             | USR_SUB_1                    |  |  |
| 51:10 | RW   | 0x0000             | User Data Bit for Subframe 1 |  |  |
| 15:0  |      | 0x0000             | USR_SUB_0                    |  |  |
| 15:0  | RW   |                    | User Data Bit for Subframe 0 |  |  |

#### SPDIF\_CHNSRn

Address: Operational Base + offset (0x00c0)

| Bit   | Attr | <b>Reset Value</b> | Description                       |  |
|-------|------|--------------------|-----------------------------------|--|
| 21.10 | DW   | 10x0000            | CHNSR_SUB_1                       |  |
| 51.10 | ĸvv  |                    | Channel Status Bit for Subframe 1 |  |
| 15.0  | RW   | V I0x0000          | CHNSR_SUB_0                       |  |
| 15:0  |      |                    | Channel Status Bit for Subframe 0 |  |

**<u>SPDIF</u>** BURTSINFO Address: Operational Base + offset (0x00d0)

| Bit   | Attr | <b>Reset Value</b> | Description                                                      |
|-------|------|--------------------|------------------------------------------------------------------|
|       |      |                    | PD                                                               |
| 31:16 | RW   | 0x0000             | Preamble Pd for non-linear pcm, indicating the length of burst   |
|       |      |                    | payload in unit of bytes or bits.                                |
|       |      |                    | BSNUM                                                            |
| 15:13 | RW   | 0x0                | This field indicates the bitstream number. Usually the bitstream |
|       |      |                    | number is 0.                                                     |
| 12:8  | RW   | W 0×00             | DATAINFO                                                         |
| 12.0  |      |                    | This field gives the data-type-dependent info                    |
|       |      |                    | ERRFLAG                                                          |
| 7     | RW   |                    | 1'b0: indicates a valid burst-payload                            |
|       |      |                    | 1'b1: indicates that the burst-payload may contain errors        |

| Bit | Attr | Reset Value | Description                                                      |  |  |  |
|-----|------|-------------|------------------------------------------------------------------|--|--|--|
|     |      |             | DATATYPE<br>7'b0000000: null data<br>7'b0000001: AC-3 data       |  |  |  |
| 6:0 | RW   | 0×00        | 7'b0000000: null data                                            |  |  |  |
|     |      |             | 7'b0010101: Enhanced AC-3<br>7'b0010110: MAT<br>others: reserved |  |  |  |

### SPDIF\_REPETTION

Address: Operational Base + offset (0x0104)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                |  |  |  |
|-------|------|--------------------|--------------------------------------------------------------------------------------------|--|--|--|
| 31:16 | RO   | 0x0                | reserved                                                                                   |  |  |  |
| 15:0  | RW   | 0x0000             | REPETTION<br>This define the repetition period when the channel conveys non-<br>linear PCM |  |  |  |

### SPDIF BURTSINFO SHD

Address: Operational Base + offset (0x0108)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                              |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------|
|       |      |                    | PD                                                                                                       |
| 31:16 | RO   | 0x0000             | Preamble Pd for non-linear pcm, indicating the length of burst                                           |
|       |      |                    | payload in unit of bytes or bits.                                                                        |
|       |      |                    | BSNUM                                                                                                    |
| 15:13 | RO   | 0x0                | This field indicates the bitstream number. Usually the bitstream                                         |
| 13.13 |      | 0,0                | number is 0.                                                                                             |
|       |      |                    | DATAINFO                                                                                                 |
| 12:8  | RO   | 0x00               | This field gives the data-type-dependent info                                                            |
|       |      |                    | ERRFLAG                                                                                                  |
| 7     | RO   | 0x0                | 1'b0: indicates a valid burst-payload                                                                    |
| /     | ŇŎ   | 0.0                | 1'b1: indicates that the burst-payload may contain errors                                                |
|       |      |                    |                                                                                                          |
|       |      |                    | 7'b0000000: null data                                                                                    |
|       |      |                    | 7'b0000001: AC-3 data                                                                                    |
|       |      |                    | 7'b0000011: Pause data                                                                                   |
|       |      |                    | 7'b0000100: MPEG-1 layer 1 data                                                                          |
|       |      |                    | 7'b0000101: MPEG-1 layer 2 or 3 data or MPEG-2 without                                                   |
|       |      |                    | extension                                                                                                |
|       |      |                    | 7'b0000110: MPEG-2 data with extension                                                                   |
|       |      |                    | 7'b0000111: MPEG-2 AAC                                                                                   |
|       |      |                    | 7'b0001111. MPEG-2, layer-1 low sampling frequency                                                       |
|       |      |                    | 7'b0001000: MPEG-2, layer-2 low sampling frequency                                                       |
|       |      |                    | 7'b0001001: MPEG-2, layer-2 low sampling frequency<br>7'b0001010: MPEG-2, layer-3 low sampling frequency |
|       |      |                    | 7'b0001010: DTS type I                                                                                   |
|       |      |                    | 7'b0001100: DTS type I                                                                                   |
|       |      |                    | 7'b0001101: DTS type II<br>7'b0001101: DTS type III                                                      |
|       |      |                    | 7'b0001110: ATRAC                                                                                        |
|       |      |                    | 7'b0001111: ATRAC 2/3                                                                                    |
| 6:0   | RO   | 0x00               | 7'b0010000: ATRAC-X                                                                                      |
|       |      |                    | 7'b0010001: DTS type IV                                                                                  |
|       |      |                    | 7'b0010010: WMA professional type I                                                                      |
|       |      |                    | 7'b0110010: WMA professional type II                                                                     |
|       |      |                    | 7'b1010010: WMA professional type III                                                                    |
|       |      |                    | 7'b1110010: WMA professional type IV                                                                     |
|       |      |                    | 7'b0010011: MPEG-2 AAC low sampling frequency                                                            |
|       |      |                    | 7'b0110011: MPEG-2 AAC low sampling frequency                                                            |
|       |      |                    | 7'b1010011: MPEG-2 AAC low sampling frequency                                                            |
|       |      |                    | 7'b1110011: MPEG-2 AAC low sampling frequency                                                            |
|       |      |                    | 7'b0010100: MPEG-4 AAC                                                                                   |
|       |      |                    | 7'b0110100: MPEG-4 AAC                                                                                   |
|       |      |                    | 7'b1010100: MPEG-4 AAC                                                                                   |
|       |      |                    | 7'b1110100: MPEG-4 AAC                                                                                   |
|       |      |                    | 7'b0010101: Enhanced AC-3                                                                                |
|       |      |                    | 7'b0010110: MAT                                                                                          |
|       |      |                    | others: reserved                                                                                         |
|       |      |                    |                                                                                                          |

#### SPDIF REPETTION SHD

Address: Operational Base + offset (0x010c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                        |  |
|-------|------|--------------------|--------------------------------------------------------------------|--|
| 31:16 | RO   | 0x0                | reserved                                                           |  |
|       |      | 0×0000             | REPETTION                                                          |  |
|       |      |                    | This register provides the repetition of the bitstream when        |  |
| 15:0  | RW   |                    | channel conveys non-linear PCM. In the design, it defines the      |  |
| 15.0  |      |                    | length between Pa of the two consecutive data-burst. For the       |  |
|       |      |                    | same audio format, the definition is different. Please convert the |  |
|       |      |                    | actual repetition in order to comply with the design.              |  |

## SPDIF USRDR SHDn

Address: Operational Base + offset (0x0190)

| Bit      | Attr | <b>Reset Value</b> | Description                  |  |  |  |
|----------|------|--------------------|------------------------------|--|--|--|
| 31:16 RC |      | 0x0000             | USR_SUB_1                    |  |  |  |
| 51.10    | ĸŪ   |                    | User Data Bit for Subframe 1 |  |  |  |
| 15.0     | RO   | ) 0x0000           | USR_SUB_0                    |  |  |  |
| 15:0     |      |                    | User Data Bit for Subframe 0 |  |  |  |

# **28.5 Interface Description**

| Table 28-1 spdif transmitter interfa | ice |
|--------------------------------------|-----|
|--------------------------------------|-----|

| Module Pin                                                | Dir | PIN Name          | IOMUX Setting               |  |  |
|-----------------------------------------------------------|-----|-------------------|-----------------------------|--|--|
| spdif_tx                                                  | 0   | GPIO0_C1/SPDIF_TX | GRF_GPIO0C_IOMUX[3:2]=2'b01 |  |  |
| Notes: I=input, O=output, I/O=input/output, bidirectional |     |                   |                             |  |  |

# **28.6 Application Notes**



Fig. 28-6 SPDIF transmitter operation flow chart

The above figure shows the operation flow of SPDIF operation. Note that the configuration register can be written only when the transfer is stopped.

# **Chapter 29 SPDIF Receiver**

# 29.1 Overview

The SPDIF receiver is a self-clocking, serial, unidirectional interface for the interconnection of digital audio equipment for consumer and professional applications, using linear PCM coded audio samples.

It provides the basic structure of the interface. Separate documents define items specific to particular applications.

When used in a professional application, the interface is primarily intended to receive monophonic or stereophonic programmes, at a 48 kHz sampling frequency and with a resolution of up to 24bits per sample; it may alternatively be used to receive signals sampled at 32 kHz or 44.1 kHz.

When used in a consumer application, the interface is primarily intended to receive stereophonic programmes, with a resolution of up to 24 bits per sample.

When used for other purposes, the interface is primarily intended to receive audio data coded other than as linear PCM coded audio samples. Provision is also made to allow the interface to receive data related to computer software or signals coded using non-linear PCM. The format specification for these applications is not part of this standard. It supports following features:

- Support AHB Bus Interface
- Support one internal 30-bit wide and 32-location deep FIFO for receiving audio data
- Support combined interrupt output
- Support DMA handshaking interface and configurable DMA water level
- Support liner PCM(IEC60958) and non-liner PCM(IEC61937)
- Support 16~24 bits audio sample length for liner PCM application
- Support 16 bits audio sample length for non-liner PCM application
- Support up to 192kHz sample rate with the corresponding reference clock equal to 192KHz\*64\*2\*10, that is 245.76MHz
- Support the frequency of reference clock is at least 10 times the frequency of the biphase encoding clock, but not more than 256 times
- Support recovering clock and audio data from input bitstream

# 29.2 Block Diagram



Fig. 29-1 SPDIF receiver Block Diagram



# SPDIF\_RX\_SYS

The module implements the AHB slave operation. It contains not only control registers of SPDIF receiver inside but also interrupt and DMA handshaking interface.

#### CDR

The CDR is short for clock and data recovery. Clock and data can be recovered from the input bitstream by using a high frequency reference clock.

#### DECODER

The clock recovered from the CDR is used as the working clock to decode the input bitstream such as extracting audio data, the corresponding preamble code, V/U/C/P flags and other audio information.

### **RX FIFO**

The RX FIFO stores the audio data extracted from input bitstream. The size of the FIFO is 30bitsx32.

# 29.3 Function description

## 29.3.1 Frame Format

SPDIF receiver follows the same protocol(IEC60958/IEC61937) as SPDIF transmitter. A frame is uniquely composed of two sub-frames. For linear coded audio applications, the rate of receiving of frames corresponds exactly to the source sampling frequency.

In the 2-channel operation mode, the samples received from both channels are arranged by time multiplexing in consecutive sub-frames. The first sub-frame(left channel in stereophonic operation and primary channel in monophonic operation) normally use preamble M. However, the preamble is changed to preamble B once every 192 frame to identify the start of the block structure used to organize the channel status information. The second sub-frame (right in stereophonic operation and secondary channel in monophonic operation) always use preamble W.



Fig. 29-2 SPDIF Frame Format

In the single channel operation mode in a professional application, the frame format is the same as in the 2-channel mode. Data is carried only in the first sub-frame and may be duplicated in the second sub-frame. If the second sub-frame is not carrying duplicate data, then time slot 28 (validity flag) shall be set to logical '1' (not valid).

## 29.3.2 Sub-frame Format



#### Fig. 29-3 SPDIF Sub-frame Format

Each sub-frame is divided into 32 time slots, numbered from 0 to 31. Time slot 0 to 3 carries one of the three permitted preambles. Time slot 4 to 27 carry the audio sample word in linear 2's complement representation. The MSB is carried by time slot 27. When a 24-bit coding range is used, the LSB is in time slot 4. When a 20-bit coding range is used, time slot 8 to 27 carry the audio sample word with the LSB in time slot 8. Time slot 4 to 7 may be used for other application. Under these circumstances, the bits in the time slot 4 to 7 are designated auxiliary sample bits.

If the source provides fewer bits than the interface allows (either 24 or 20), the unused LSBs are set to a logical '0'. For a non-linear PCM audio application or a data application the main data field may carry any other information. Time slot 28 carries the validity flag associated with the main data field. Time slot 29 carries 1 bit of the user data associated with the audio channel transmitted in the same sub-frame. Time slot 30 carries one bit of the channel status words associated with the main data field channel transmitted in the same sub-frame. Time slot 31 carries a parity bit such that time slots 4 to 31 inclusive carries an even number of ones and an even number of zeros.

### 29.3.3 Channel Coding



Fig. 29-4 SPDIF Channel Coding

To minimize the direct current component on the transmission/receiving line, to facilitate clock recovery from the data stream and to make the interface insensitive to the polarity of connections, time slots 4 to 31 are encoded in biphase-mark.

Each bit to be transmitted is represented by a symbol comprising two consecutive binary states. The first state of a symbol is always different from the second state of the previous symbol. The second state of the symbol is identical to the first if the bit to be transmitted is logical '0'. However, it is different from the first if the bit is logical '1'.

## 29.3.4 Preamble

Preambles are specific patterns providing synchronization and identification of the subframes and blocks.

To achieve synchronization within one sampling period and to make this process completely reliable, these patterns violate the biphase-mark code rules, thereby avoiding the possibility of data imitating the preambles.

A set of three preambles is used. These preambles are transmitted in the time allocated to four time slots (time slots 0 to 3) and are represented by eight successive states. The first state of the preamble is always different from the second state of the previous symbol.





Like biphase code, these preambles are dc free and provide clock recovery. They differ in at least two states from any valid biphase sequence.

# **29.4 Register Description**

## 29.4.1 Registers Summary

| Nomo                     | Offset | Size | Reset      | Description                      |
|--------------------------|--------|------|------------|----------------------------------|
| Name                     | Unset  | Size | Value      | Description                      |
| SPDIF_RX_VERSION         | 0x0000 | W    | 0x00000100 | Version Register                 |
| SPDIF RX CFGR            | 0x0004 | W    | 0x00000000 | Transfer Configuration Register  |
| SPDIF RX CLR             | 0x0008 | W    | 0x00000000 | Clear Register                   |
| SPDIF_RX_CDR             | 0x000c | W    | 0x000000a0 | Clock And Data Recovery Register |
|                          | 0x0010 | w    | 0x000000ff | Clock And Data Recovery Status   |
| <u>SPDIF_RX_CDRST</u>    | 0X0010 | vv   | 0x00000011 | Register                         |
| SPDIF RX DMACR           | 0x0014 | W    | 0x00000000 | DMA Control Register             |
| <u>SPDIF_RX_FIFOCTRL</u> | 0x0018 | W    | 0x00000000 | FIFO Control Register            |
| <u>SPDIF RX INTEN</u>    | 0x001c | W    | 0x00000000 | Interrupt Enable Register        |
| SPDIF RX INTMASK         | 0x0020 | W    | 0x00000000 | Interrupt Mask Register          |
| SPDIF RX INTSR           | 0x0024 | W    | 0x00000000 | Interrupt Status Register        |
| SPDIF_RX_INTCLR          | 0x0028 | W    | 0x00000000 | Interrupt Clear Register         |
| SPDIF RX SMPDR           | 0x002c | W    | 0x00000000 | Sample Data Register             |
| SPDIF RX USRDRn          | 0x0030 | W    | 0x00000000 | User Data Register n(0~11)       |
| <u>SPDIF_RX_CHNSRn</u>   | 0x0060 | W    | 0x00000000 | Channel Status Register n(0~11)  |
| SPDIF RX BURTSINFO       | 0x0100 | W    | 0x00000000 | Channel Burst Info Register      |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

### 29.4.2 Detail Register Description SPDIF RX VERSION

Address: Operational Base + offset (0x0000)

| Bit  | Attr | <b>Reset Value</b> | Description         |  |  |  |
|------|------|--------------------|---------------------|--|--|--|
| 31:0 | RW   | 0x00000100         | VERSION             |  |  |  |
| 51:0 | r vv |                    | Version Of SPDIF_RX |  |  |  |

#### SPDIF RX CFGR

Address: Operational Base + offset (0x0004)

| Bit  | Attr | <b>Reset Value</b> | Description                                                 |  |  |  |
|------|------|--------------------|-------------------------------------------------------------|--|--|--|
| 31:2 | RO   | 0x0                | reserved                                                    |  |  |  |
|      |      |                    | TWAD                                                        |  |  |  |
| 4    |      | 0×0                | 1'b0: Only audio data transmitted to FIFO.                  |  |  |  |
| T    | RW   |                    | 1'b1: Block start, channel number and VUCP transmitted with |  |  |  |
|      |      |                    | audio data to FIFO.                                         |  |  |  |
|      |      | W 0×0              | EN                                                          |  |  |  |
| 0    | RW   |                    | 1'b0: disable SPDIF_RX                                      |  |  |  |
|      |      |                    | 1'b1: enable SPDIF_RX                                       |  |  |  |

#### SPDIF\_RX\_CLR

Address: Operational Base + offset (0x0008)

| Bit  | Attr | <b>Reset Value</b> | Description                                                       |
|------|------|--------------------|-------------------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                          |
|      |      |                    | RXSC                                                              |
| 0    | RW   | 0x0                | This is a software self-cleared bit. Write 1 to clear all receive |
|      |      |                    | logic.                                                            |

#### SPDIF RX CDR

Address: Operational Base + offset (0x000c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                    |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | RO   | 0x0                | reserved                                                                                                                                                                                       |
| 10:9  | RW   | 0×0                | CS<br>2'b00: Idle state. CDR is idle and waits for rising edge of spdif<br>input bitstream<br>2'b01: Detect state.<br>2'b10: Measurement state.<br>2'b11: Synchronization state.               |
| 8:2   | RO   | 0x0                | reserved                                                                                                                                                                                       |
| 1     | RW   | 0×0                | AVGSEL<br>Select if the min or average number of cycles from the calculation<br>of spdif_in pulse width.<br>1'b0: min number of cycles<br>1'b1: average number of cycles, that is (max+min)/4. |
| 0     | RW   | 0x0                | BYPASS<br>Write 1 to enable CDR. Please ensure that this bit is set to 1<br>before starting receiving data.                                                                                    |

#### SPDIF RX CDRST

Address: Operational Base + offset (0x0010)

| Bit   | Attr | <b>Reset Value</b> | Description                                                     |
|-------|------|--------------------|-----------------------------------------------------------------|
|       |      |                    | NOSTRTHR                                                        |
| 31:16 |      | 0,0000             | The threshold counter determines the latency between input      |
| 51:10 | RVV  | 0x0000             | bitstream idle and exit synchronous status. Make sure that this |
|       |      |                    | value is large than 0x3ff.                                      |
|       |      |                    | MAXCNT                                                          |
| 15:8  | RO   | 0x00               | The value indicates the number of reference clock cycles to     |
|       |      |                    | oversample the maximum pulse width of bitstream.                |
|       |      |                    | MINCNT                                                          |
| 7:0   | RO   | 0xff               | The value indicates the number of reference clock cycles to     |
|       |      |                    | oversample the minimum pulse width of bitstream.                |

### SPDIF RX DMACR

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description                                                         |
|------|------|--------------------|---------------------------------------------------------------------|
| 31:6 | RO   | 0x0                | reserved                                                            |
|      |      |                    | RDE                                                                 |
| 5    | RW   | 0x0                | 1'b0: Receive DMA disabled                                          |
|      |      |                    | 1'b1: Receive DMA enabled                                           |
|      |      | N 0x00             | RDL                                                                 |
|      |      |                    | This bit field controls the level at which a DMA request is made by |
| 4:0  | RW   |                    | the receive logic. The watermark level = DMARDL+1; that is,         |
| 4.0  | ĸvv  |                    | dma_rx_req is generated when the number of valid data entries       |
|      |      |                    | in the Sample Date Buffer is equal to or above this field value +   |
|      |      |                    | 1.                                                                  |

#### SPDIF RX FIFOCTRL

Address: Operational Base + offset (0x0018)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                     |
|-------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14 | RO   | 0x0                | reserved                                                                                                                                        |
| 13:8  | RO   | 0x00               | RFL<br>Contains the number of valid data entries in the receive FIFO.                                                                           |
| 7:5   | RO   | 0x0                | reserved                                                                                                                                        |
| 4:0   | RW   | 0x00               | RFT<br>When the number of receive FIFO entries is more than or equal to<br>this threshold plus 1, the receive FIFO full interrupt is triggered. |

### SPDIF\_RX\_INTEN

Address: Operational Base + offset (0x001c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                       |
|-------|------|--------------------|-------------------------------------------------------------------|
| 31:11 | RO   | 0x0                | reserved                                                          |
|       |      |                    | UBCIE                                                             |
| 10    | RW   | 0x0                | 1'b0: disable                                                     |
|       |      |                    | 1'b1: enable                                                      |
|       |      |                    | ESYNCIE                                                           |
| 0     |      | 0×0                | 1'b0: disable                                                     |
| 9     | RW   |                    | 1'b1: enable                                                      |
|       |      |                    | Entering synchronous state will generate an interrupt if enabled. |
|       |      |                    | BTEIE                                                             |
|       |      |                    | 1'b0: disable                                                     |
|       |      |                    | 1'b1: enable                                                      |
| 8     | RW   |                    | When enabled, an interrupt will be asserted when the block        |
|       |      |                    | receive is finished if the channel conveys linear PCM or when the |
|       |      |                    | repetition period is reached if the channel conveys non-linear    |
|       |      |                    | PCM.                                                              |

| Bit | Attr | <b>Reset Value</b> | Description                                                      |
|-----|------|--------------------|------------------------------------------------------------------|
|     |      |                    | NSYNCIE                                                          |
|     |      |                    | 1'b0: disable                                                    |
| 7   | RW   | 0x0                | 1'b1: enable                                                     |
|     |      |                    | A state change from synchronization state to idle state will     |
|     |      |                    | generate an interrupt if enabled.                                |
|     |      |                    | BMDEIE                                                           |
|     |      |                    | 1'b0: disable                                                    |
| 6   | RW   | 0x0                | 1'b1: enable                                                     |
|     |      |                    | If enabled, an interrupt will be generated if a bi-phase mark    |
|     |      |                    | decoding error has occurred.                                     |
|     |      |                    | RXOIE                                                            |
| 5   | RW   | 0x0                | 1'b0: disable                                                    |
|     |      |                    | 1'b1: enable                                                     |
|     |      |                    | RXFIE                                                            |
| 4   | RW   | 0x0                | 1'b0: disable                                                    |
|     |      |                    | 1'b1: enable                                                     |
|     |      |                    | NPSPIE                                                           |
| 3   | RW   | 0x0                | 1'b0: disable                                                    |
|     |      |                    | 1'b1: enable                                                     |
|     |      |                    | NVLDIE                                                           |
| 2   | RW   | 0x0                | 1'b0: disable                                                    |
|     |      |                    | 1'b1: enable                                                     |
|     |      |                    | CSCIE                                                            |
| 1   | RW   | 0x0                | 1'b0: disable                                                    |
|     |      |                    | 1'b1: enable                                                     |
|     |      |                    | PEIE                                                             |
|     |      |                    | 1'b0: disable                                                    |
| 0   | RW   | 0x0                | 1'b1: enable                                                     |
|     |      |                    | If enabled, an interrupt will be generated if a parity error has |
|     |      |                    | occurred.                                                        |

**SPDIF RX INTMASK** Address: Operational Base + offset (0x0020)

| Bit   | Attr | Reset Value | Description      |
|-------|------|-------------|------------------|
| 31:11 | RO   | 0x0         | reserved         |
|       |      |             | UBCIMSK          |
| 10    | RW   | 0x0         | 1'b0: Don't mask |
|       |      |             | 1'b1: Mask       |
|       |      |             | ESYNCIMSK        |
| 9     | RW   | 0x0         | 1'b0: Don't mask |
|       |      |             | 1'b1: Mask       |
|       |      |             | BTEIMSK          |
| 8     | RW   | 0x0         | 1'b0: Don't mask |
|       |      |             | 1'b1: Mask       |

| Bit | Attr | <b>Reset Value</b> | Description      |
|-----|------|--------------------|------------------|
|     |      |                    | NSYNCIMSK        |
| 7   | RW   | 0x0                | 1'b0: Don't mask |
|     |      |                    | 1'b1: Mask       |
|     |      |                    | BMDEIMSK         |
| 6   | RW   | 0x0                | 1'b0: Don't mask |
|     |      |                    | 1'b1: Mask       |
|     |      |                    | RXOIMSK          |
| 5   | RW   | 0x0                | 1'b0: Don't mask |
|     |      |                    | 1'b1: Mask       |
|     |      |                    | RXFIMSK          |
| 4   | RW   | 0x0                | 1'b0: Don't mask |
|     |      |                    | 1'b1: Mask       |
|     |      |                    | NPSPIMSK         |
| 3   | RW   | 0x0                | 1'b0: Don't mask |
|     |      |                    | 1'b1: Mask       |
|     |      |                    | NVLDIMSK         |
| 2   | RW   | 0x0                | 1'b0: Don't mask |
|     |      |                    | 1'b1: Mask       |
|     |      |                    | CSCIMSK          |
| 1   | RW   | 0x0                | 1'b0: Don't mask |
|     |      |                    | 1'b1: Mask       |
|     |      |                    | PEIMSK           |
| 0   | RW   | 0x0                | 1'b0: Don't mask |
|     |      |                    | 1'b1: Mask       |

#### <u>SPDIF\_RX\_INTSR</u>

Address: Operational Base + offset (0x0024)

| Bit   | Attr | <b>Reset Value</b> | Description    |
|-------|------|--------------------|----------------|
| 31:11 | RO   | 0x0                | reserved       |
|       |      |                    | UBCISR         |
| 10    | RW   | 0x0                | 1'b0: inactive |
|       |      |                    | 1'b1: active   |
|       |      |                    | ESYNCISR       |
| 9     | RW   | 0x0                | 1'b0: inactive |
|       |      |                    | 1'b1: active   |
|       |      |                    | BTEISR         |
| 8     | RW   | 0x0                | 1'b0: inactive |
|       |      |                    | 1'b1: active   |
|       |      |                    | NSYNCISR       |
| 7     | RW   | 0x0                | 1'b0: inactive |
|       |      |                    | 1'b1: active   |
|       |      |                    | BMDEISR        |
| 6     | RW   | 0x0                | 1'b0: inactive |
|       |      |                    | 1'b1: active   |

| Bit | Attr | <b>Reset Value</b> | Description    |
|-----|------|--------------------|----------------|
|     |      |                    | RXOIS          |
| 5   | RO   | 0x0                | 1'b0: inactive |
|     |      |                    | 1'b1: active   |
|     |      |                    | RXFIS          |
| 4   | RO   | 0x0                | 1'b0: inactive |
|     |      |                    | 1'b1: active   |
|     |      |                    | NPSPIS         |
| 3   | RW   | 0x0                | 1'b0: inactive |
|     |      |                    | 1'b1: active   |
|     |      |                    | NVLDIS         |
| 2   | RO   | 0x0                | 1'b0: inactive |
|     |      |                    | 1'b1: active   |
|     |      |                    | CSCIS          |
| 1   | RO   | 0x0                | 1'b0: inactive |
|     |      |                    | 1'b1: active   |
|     |      |                    | PEIS           |
| 0   | RO   | 0x0                | 1'b0: inactive |
|     |      |                    | 1'b1: active   |

## SPDIF\_RX\_INTCLR

Address: Operational Base + offset (0x0028)

| Bit   | Attr | <b>Reset Value</b> | Description                                                      |      |                                          |
|-------|------|--------------------|------------------------------------------------------------------|------|------------------------------------------|
| 31:11 | RO   | 0x0                | reserved                                                         |      |                                          |
| 10    | RW   | 0x0                | UBCICLR                                                          |      |                                          |
| 10    | RW   | UXU                | Write 1 to clear user bit change interrupt.                      |      |                                          |
| 9     | RW   | 0x0                | ESYNCICLR                                                        |      |                                          |
| 9     |      | 0.00               | Write 1 to clear Entering Synchronous State interrupt.           |      |                                          |
| 8     | RW   | 0x0                | BTEICLR                                                          |      |                                          |
| 0     |      | 0.00               | Write 1 to clear Block Transfer/Repetition Period End interrupt. |      |                                          |
| 7     | RW   | 0x0                | NSYNCICLR                                                        |      |                                          |
| /     |      | 0x0                | Write 1 to clear CDR Not Synchronization interrupt.              |      |                                          |
| 6     | RW   | 0×0                | BMDEICLR                                                         |      |                                          |
| 0     |      |                    | Write 1 to clear Bi-phase Mark Decoding interrupt.               |      |                                          |
| 5     | RW   | / 0×0              | RXOICLR                                                          |      |                                          |
| 5     | 1    |                    | Write 1 to clear receive overrun interrupt.                      |      |                                          |
| 4     | RW   | W 0x0              | RXFICLR                                                          |      |                                          |
| Ŧ     |      |                    |                                                                  | 0.00 | Write 1 to clear receive full interrupt. |
| 3     | RW   | 0x0                | NPSPICLR                                                         |      |                                          |
| J     |      | 0.00               | Write 1 to clear receive full interrupt.                         |      |                                          |
| 2     | RW   | 0x0                | NVLDICLR                                                         |      |                                          |
| 2     | 1    |                    | Write 1 to clear receive full interrupt.                         |      |                                          |
| 1     | RW   | 0x0                | CSCICLR                                                          |      |                                          |
| ±     | 1    | 0.0                | Write 1 to clear channel status change interrupt.                |      |                                          |

| Bit | Attr | <b>Reset Value</b> | Description                              |  |  |  |  |
|-----|------|--------------------|------------------------------------------|--|--|--|--|
| 0   | RW   | W  0x0             | PEICLR                                   |  |  |  |  |
| 0   | L AN |                    | Write 1 to clear parity error interrupt. |  |  |  |  |

#### SPDIF\_RX\_SMPDR

Address: Operational Base + offset (0x002c)

| Bit  | Attr | <b>Reset Value</b> | Description                   |
|------|------|--------------------|-------------------------------|
| 31:0 | RW   | 0x00000000         | SMPDR<br>Sample Data Register |

#### SPDIF\_RX\_USRDRn

Address: Operational Base + offset (0x0030)

| Bit   | Attr | <b>Reset Value</b>       | Description                  |  |  |  |  |
|-------|------|--------------------------|------------------------------|--|--|--|--|
| 31:16 |      | $O = [0 \times 0 0 0 0]$ | USR_SUB_1                    |  |  |  |  |
| 51:10 | RU   |                          | User Data Bit For Subframe 1 |  |  |  |  |
| 15.0  | RO   | 0,0000                   | USR_SUB_0                    |  |  |  |  |
| 15:0  |      | 0x0000                   | User Data Bit For Subframe 0 |  |  |  |  |

#### SPDIF\_RX\_CHNSRn

Address: Operational Base + offset (0x0060)

| Bit   | Attr | <b>Reset Value</b> | Description                       |  |  |  |  |  |
|-------|------|--------------------|-----------------------------------|--|--|--|--|--|
| 31:16 |      | W 10x0000          | CHNSR_SUB_1                       |  |  |  |  |  |
| 51.10 | RVV  |                    | Channel Status Bit For Subframe 1 |  |  |  |  |  |
| 15.0  |      | 0.4000             | CHNSR_SUB_0                       |  |  |  |  |  |
| 15:0  | RO   | 0x0000             | Channel Status Bit For Subframe 0 |  |  |  |  |  |

### SPDIF RX BURTSINFO

Address: Operational Base + offset (0x0100)

| Bit   | Attr | <b>Reset Value</b> | Description                                                      |  |  |  |
|-------|------|--------------------|------------------------------------------------------------------|--|--|--|
|       |      |                    | PD                                                               |  |  |  |
| 31:16 | RW   | 0x0000             | Preamble Pd for non-linear pcm, indicating the length of burst   |  |  |  |
|       |      |                    | payload in unit of bytes or bits.                                |  |  |  |
|       |      |                    | BSNUM                                                            |  |  |  |
| 15:13 | RW   | 0×0                | This field indicates the bitstream number. Usually the bitstream |  |  |  |
|       |      |                    | number is 0.                                                     |  |  |  |
| 12:8  | RO   | 0x00               | DATAINFO                                                         |  |  |  |
| 12.0  | κŪ   | 0,00               | This field gives the data-type-dependent info                    |  |  |  |
|       |      |                    | ERRFLAG                                                          |  |  |  |
| 7     | RO   | 0x0                | 1'b0: indicates a valid burst-payload                            |  |  |  |
|       |      |                    | 1'b1: indicates that the burst-payload may contain errors        |  |  |  |

| Bit | Attr | Reset Value | Description                                                             |
|-----|------|-------------|-------------------------------------------------------------------------|
|     |      |             | DATATYPE                                                                |
|     |      |             | 7'b0000000: null data                                                   |
|     |      |             | 7'b0000001: AC-3 data                                                   |
|     |      |             | 7'b0000011: Pause data                                                  |
|     |      |             | 7'b0000100: MPEG-1 layer 1 data                                         |
|     |      |             | 7'b0000101: MPEG-1 layer 2 or 3 data or MPEG-2 without                  |
|     |      |             | extension                                                               |
|     |      |             | 7'b0000110: MPEG-2 data with extension                                  |
|     |      |             | 7'b0000111: MPEG-2 AAC                                                  |
|     |      |             | 7'b0001000: MPEG-2, layer-1 low sampling frequency                      |
|     |      |             | 7'b0001001: MPEG-2, layer-2 low sampling frequency                      |
|     |      |             | 7'b0001010: MPEG-2, layer-3 low sampling frequency                      |
|     |      |             | 7'b0001011: DTS type I                                                  |
|     |      | 0×00        | 7'b0001100: DTS type II                                                 |
|     |      |             | 7'b0001101: DTS type III                                                |
|     |      |             | 7'b0001110: ATRAC                                                       |
| 6:0 | RO   |             | 7'b0001111: ATRAC 2/3                                                   |
|     |      |             | 7'b0010000: ATRAC-X                                                     |
|     |      |             | 7'b0010001: DTS type IV                                                 |
|     |      |             | 7'b0010010: WMA professional type I                                     |
|     |      |             | 7'b0110010: WMA professional type II                                    |
|     |      |             | 7'b1010010: WMA professional type III                                   |
|     |      |             | 7'b1110010: WMA professional type IV                                    |
|     |      |             | 7'b0010011: MPEG-2 AAC low sampling frequency                           |
|     |      |             | 7'b0110011: MPEG-2 AAC low sampling frequency                           |
|     |      |             | 7'b1010011: MPEG-2 AAC low sampling frequency                           |
|     |      |             | 7'b1110011: MPEG-2 AAC low sampling frequency<br>7'b0010100: MPEG-4 AAC |
|     |      |             | 7'b0110100: MPEG-4 AAC<br>7'b0110100: MPEG-4 AAC                        |
|     |      |             | 7'b1010100: MPEG-4 AAC                                                  |
|     |      |             | 7'b1110100: MPEG-4 AAC<br>7'b1110100: MPEG-4 AAC                        |
|     |      |             | 7'b0010101: Enhanced AC-3                                               |
|     |      |             | 7'b0010101: Enhanced AC-3<br>7'b0010110: MAT                            |
|     |      |             | others: reserved                                                        |
|     |      |             |                                                                         |

# **29.5 Interface Description**

| Table 29-1 SPDIF receiver interface                       |                                                              |  |  |  |  |  |  |  |
|-----------------------------------------------------------|--------------------------------------------------------------|--|--|--|--|--|--|--|
| Module Pin                                                | Module Pin Dir PIN Name IOMUX Setting                        |  |  |  |  |  |  |  |
| spdif_rx_sdi                                              | spdif_rx_sdi I GPIO0_C2/SPDIF_RX GRF_GPIO0C_IOMUX[5:4]=2'b01 |  |  |  |  |  |  |  |
| Notes: I=input, O=output, I/O=input/output, bidirectional |                                                              |  |  |  |  |  |  |  |

The SPDIF receiver also provides a bypass option for direct transfer of the SPDIF input signal to the SPDIF transmitter by configuring GRF\_SOC\_CON1[14]. If GRF\_SOC\_CON1[14] is set to 1, then the SPDIF receiver input signal will be transferred to the SPDIF transmitter.

# **29.6 Application Notes**



Fig. 29-6 SPDIF receiver operation flow chart The above figure shows the operation flow of SPDIF receiver operation.

# Chapter 30 General Register Files (GRF)

# **30.1** Overview

The general register file will be used to do static setting by software, which is composed of many registers for system control. The GRF is located at several addresses.

- GRF, used for general non-secure system
- USBPHY\_GRF, used for USB PHY configuration
- DETECT\_GRF, used for USB and SDMMC connection and disconnect detect
- CORE\_GRF, used for CORE PVTM and Performance Monitor

# 30.2 Block Diagram

N/A

# **30.3 Function Description**

The function of general register file are:

- IOMUX control
- Control the property of GPIO in power-down mode
- Used for common system control
- Used to record the system state

# **30.4 Register Description**

# 30.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

Table 30-1 GRF Address Mapping Table

| Name       | Address Base |  |  |  |  |  |
|------------|--------------|--|--|--|--|--|
| GRF        | 0xFF000000   |  |  |  |  |  |
| USBPHY_GRF | 0xFF008000   |  |  |  |  |  |
| DETECT_GRF | 0xFF00B000   |  |  |  |  |  |
| CORE_GRF   | 0xFF00C000   |  |  |  |  |  |

## 30.4.2 GRF Registers Summary

| Name                       | Offset  | Size | Reset<br>Value | Description                      |
|----------------------------|---------|------|----------------|----------------------------------|
| <u>GRF GPIO0A IOMUX</u>    | 0x0000  | W    | 0x00000040     | GPIO0A iomux function select     |
| GRF_GPIO0B_IOMUX           | 0x0008  | W    | 0x00000000     | GPIO0B iomux function select     |
| GRF GPIOOC IOMUX           | 0x0010  | W    | 0x00000000     | GPIO0C iomux function select     |
| GRF_GPIO1A_IOMUX           | 0x0020  | W    | 0x00000000     | GPIO1A iomux function select     |
|                            | 0,00.20 | \\/  | 0x00000000     | GPIO1B iomux function select low |
| <u>GRF GPIO1B IOMUX L</u>  | 0x0028  | W    | 0x00000000     | bits                             |
| GRF GPIO1B IOMUX H         | 0x002c  | w    | 0x00000000     | GPIO1B iomux function select     |
| <u>GRI_GFIOIB_IOM0A_II</u> | 00020   | vv   | 0x00000000     | high bits                        |
| GRF GPIO1C IOMUX L         | 0x0030  | w    | 0x00000000     | GPIO1C iomux function select low |
|                            | 0X0030  | vv   | 0x00000000     | bits                             |
| GRF GPIO1C IOMUX H         | 0x0034  | w    | 0x00000440     | GPIO1C iomux function select     |
|                            |         |      |                | high bits                        |
| <u>GRF GPIO1D IOMUX</u>    | 0x0038  | W    | 0x00000000     | GPIO1D iomux function select     |

| Name                | Offset | Size | Reset<br>Value | Description                            |
|---------------------|--------|------|----------------|----------------------------------------|
| GRF_GPIO2A_IOMUX    | 0x0040 | W    | 0x0000000      | GPIO2A iomux function select           |
| GRF GPIO2B IOMUX    | 0x0048 | W    | 0x00000000     | GPIO2B iomux function select           |
| GRF GPIO2C IOMUX    | 0x0050 | W    | 0x00000000     | GPIO2C iomux function select           |
| GRF GPIO3A IOMUX    | 0x0060 | W    | 0x0000000      | GPIO3A iomux function select           |
| GRF GPIO3B IOMUX    | 0x0068 | W    | 0x0000000      | GPIO3B iomux function select           |
| GRF_GPIO4A_IOMUX    | 0x0080 | W    | 0x0000000      | GPIO4A iomux function select           |
| GRF GPIO4B IOMUX    | 0x0088 | W    | 0x0000000      | GPIO4B iomux function select           |
| GRF GPIO4C IOMUX    | 0x0090 | W    | 0x0000000      | GPIO4C iomux function select           |
| GRF GPIO4D IOMUX    | 0x0098 | W    | 0x0000000      | GPIO4D iomux function select           |
| <u>GRF_GPIO0A_P</u> | 0x00a0 | w    | 0x0000a96a     | GPIO0A driver disabled state control   |
| <u>GRF GPIO0B P</u> | 0x00a4 | w    | 0x0000a96a     | GPIO0B driver disabled state control   |
| <u>GRF_GPIOOC_P</u> | 0x00a8 | w    | 0x00000a2a     | GPIO0C driver disabled state control   |
| <u>GRF_GPIO1A_P</u> | 0x00b0 | w    | 0x0000aaaa     | GPIO1A driver disabled state control   |
| <u>GRF_GPIO1B_P</u> | 0x00b4 | w    | 0x0000aaaa     | GPIO1B driver disabled state control   |
| <u>GRF GPIO1C P</u> | 0x00b8 | w    | 0x00005aaa     | GPIO1C driver disabled state control   |
| <u>GRF_GPIO1D_P</u> | 0x00bc | w    | 0x00000005     | GPIO1D driver disabled state control   |
| <u>GRF_GPIO2A_P</u> | 0x00c0 | w    | 0x0000aa55     | GPIO2A driver disabled state control   |
| <u>GRF_GPIO2B_P</u> | 0x00c4 | w    | 0x0000aaaa     | GPIO2B driver disabled state control   |
| <u>GRF GPIO2C P</u> | 0x00c8 | w    | 0x0000002      | GPIO2C driver disabled state control   |
| <u>GRF GPIO3A P</u> | 0x00d0 | w    | 0x00005555     | GPIO3A driver disabled state control   |
| <u>GRF_GPIO3B_P</u> | 0x00d4 | W    | 0x00000599     | GPIO3B driver disabled state control   |
| <u>GRF_GPIO4A_P</u> | 0x00e0 | w    | 0x00005955     | GPIO4A driver disabled state control   |
| <u>GRF GPIO4B P</u> | 0x00e4 | w    | 0x0000aaa5     | GPIO4B driver disabled state control   |
| <u>GRF GPIO4C P</u> | 0x00e8 | w    | 0x00000002     | GPIO4C driver disabled state control   |
| <u>GRF_GPIO4D_P</u> | 0x00ec | w    | 0x00002955     | GPIO4D driver disabled state control   |
| <u>GRF_GPIO0A_E</u> | 0x0100 | W    | 0x00000000     | GPIO0A output drive strength selection |

| Name                 | Offset | Size | Reset<br>Value | Description                               |
|----------------------|--------|------|----------------|-------------------------------------------|
|                      |        |      |                | GPIO0B output drive strength              |
| <u>GRF GPIO0B E</u>  | 0x0104 | W    | 0x00000000     | selection                                 |
|                      | 0.0100 | 14/  | 000000000      | GPIO0C output drive strength              |
| <u>GRF_GPIOOC_E</u>  | 0x0108 | W    | 0x0000000      | selection                                 |
| GRF GPIO1A E         | 0x0110 | W    | 0x00000000     | GPIO1A output drive strength              |
|                      | 0,0110 | vv   | 0.00000000     | selection                                 |
| GRF GPIO1B E         | 0x0114 | w    | 0x00000000     | GPIO1B output drive strength              |
|                      |        |      |                | selection                                 |
| <u>GRF GPIO1C E</u>  | 0x0118 | W    | 0x00000000     | GPIO1C output drive strength              |
|                      |        |      |                | selection                                 |
| <u>GRF_GPIO1D_E</u>  | 0x011c | W    | 0x00000000     | GPIO1D output drive strength selection    |
|                      |        |      |                | GPIO2A output drive strength              |
| <u>GRF GPIO2A E</u>  | 0x0120 | W    | 0x0000000      | selection                                 |
|                      |        |      |                | GPIO2B output drive strength              |
| <u>GRF GPIO2B E</u>  | 0x0124 | W    | 0x0000000      | selection                                 |
|                      |        |      |                | GPIO2C output drive strength              |
| <u>GRF GPIO2C E</u>  | 0x0128 | W    | 0x0000000      | selection                                 |
|                      | 0.0120 | 14/  | 00000          | GPIO3A output drive strength              |
| <u>GRF GPIO3A E</u>  | 0x0130 | W    | 0x0000aaaa     | selection                                 |
| GRF GPIO3B E         | 0x0134 | w    | 0x00000aaa     | GPIO3B output drive strength              |
|                      | 0,0134 | vv   | 0x00000aaa     | selection                                 |
| GRF GPIO4A E         | 0x0140 | w    | 0x00000000     | GPIO4A output drive strength              |
|                      |        |      |                | selection                                 |
| <u>GRF GPIO4B E</u>  | 0x0144 | W    | 0x00000000     | GPIO4B output drive strength              |
|                      |        |      |                | selection                                 |
| <u>GRF GPIO4C E</u>  | 0x0148 | W    | 0x00000000     | GPIO4C output drive strength              |
|                      |        |      |                | selection<br>GPIO4D output drive strength |
| <u>GRF GPIO4D E</u>  | 0x014c | W    | 0x00002aaa     | selection                                 |
| GRF GPIO0A SR        | 0x0150 | W    | 0x00000000     |                                           |
| GRF_GPIO0B_SR        | 0x0154 | W    |                | GPIO0B slew rate control                  |
| GRF GPIOOC SR        | 0x0158 | W    | 0x00000000     |                                           |
| GRF GPIO1A SR        | 0x0160 | W    | 0x00000000     |                                           |
| GRF_GPIO1B_SR        | 0x0164 | W    | 0x0000000      | GPIO1B slew rate control                  |
| GRF GPIO1C SR        | 0x0168 | W    | 0x0000000      | GPIO1C slew rate control                  |
| <u>GRF GPIO1D SR</u> | 0x016c | W    | 0x0000000      | GPIO1D slew rate control                  |
| <u>GRF_GPIO2A_SR</u> | 0x0170 | W    | 0x0000000      | GPIO2A slew rate control                  |
| <u>GRF GPIO2B SR</u> | 0x0174 | W    | 0x0000000      | GPIO2B slew rate control                  |
| <u>GRF_GPIO2C_SR</u> | 0x0178 | W    | 0x0000000      | GPIO2C slew rate control                  |
| <u>GRF GPIO3A SR</u> | 0x0180 | W    | 0x0000000      | GPIO3A slew rate control                  |
| <u>GRF GPIO3B SR</u> | 0x0184 | W    | 0x0000000      | GPIO3B slew rate control                  |
| <u>GRF_GPIO4A_SR</u> | 0x0190 | W    | 0x0000000      | GPIO4A slew rate control                  |

| Name                       | Offset | Size | Reset<br>Value | Description                   |
|----------------------------|--------|------|----------------|-------------------------------|
| GRF_GPIO4B_SR              | 0x0194 | W    | 0x00000000     | GPIO4B slew rate control      |
| GRF GPIO4C SR              | 0x0198 | W    | 0x00000000     | GPIO4C slew rate control      |
| GRF GPIO4D SR              | 0x019c | W    | 0x00000000     | GPIO4D slew rate control      |
| GRF GPIOOA SMT             | 0x01a0 | W    | 0x00000000     | GPIO0A schmitt trigger select |
| GRF GPIOOB SMT             | 0x01a4 | W    | 0x00000000     | GPIO0B schmitt trigger select |
| GRF_GPIO0C_SMT             | 0x01a8 | W    | 0x0000008      | GPIO0C schmitt trigger select |
| <u>GRF GPIO1A SMT</u>      | 0x01b0 | W    | 0x00000000     | GPIO1A schmitt trigger select |
| <u>GRF GPIO1B SMT</u>      | 0x01b4 | W    | 0x00000000     | GPIO1B schmitt trigger select |
| <u>GRF GPIO1C SMT</u>      | 0x01b8 | W    | 0x0000000      | GPIO1C schmitt trigger select |
| <u>GRF GPIO1D SMT</u>      | 0x01bc | W    | 0x00000000     | GPIO1D schmitt trigger select |
| <u>GRF GPIO2A SMT</u>      | 0x01c0 | W    | 0x00000000     | GPIO2A schmitt trigger select |
| <u>GRF_GPIO2B_SMT</u>      | 0x01c4 | W    | 0x00000000     | GPIO2B schmitt trigger select |
| <u>GRF GPIO2C SMT</u>      | 0x01c8 | W    | 0x00000000     | GPIO2C schmitt trigger select |
| <u>GRF_GPIO3A_SMT</u>      | 0x01d0 | W    | 0x0000000      | GPIO3A schmitt trigger select |
| <u>GRF GPIO3B SMT</u>      | 0x01d4 | W    | 0x0000000      | GPIO3B schmitt trigger select |
| <u>GRF GPIO4A SMT</u>      | 0x01e0 | W    | 0x00000000     | GPIO4A schmitt trigger select |
| <u>GRF_GPIO4B_SMT</u>      | 0x01e4 | W    | 0x0000000      | GPIO4B schmitt trigger select |
| <u>GRF GPIO4C SMT</u>      | 0x01e8 | W    | 0x0000000      | GPIO4C schmitt trigger select |
| <u>GRF GPIO4D SMT</u>      | 0x01ec | W    | 0x00000000     | GPIO4D schmitt trigger select |
| <u>GRF SOC CON0</u>        | 0x0300 | W    | 0x0000010      | SOC control register 0        |
| <u>GRF SOC CON1</u>        | 0x0304 | W    | 0x000004e4     | SOC control register 1        |
| <u>GRF_SOC_CON2</u>        | 0x0308 | W    | 0x0000000      | SOC control register 2        |
| <u>GRF_SOC_CON3</u>        | 0x030c | W    | 0x00007c00     | SOC control register 3        |
| <u>GRF_SOC_CON4</u>        | 0x0310 | W    | 0x00001000     | SOC control register 4        |
| <u>GRF_SOC_CON5</u>        | 0x0314 | W    | 0x0000000      | SOC control register 5        |
| <u>GRF SOC CON10</u>       | 0x0328 | W    | 0x000001ff     | SOC control register 10       |
| <u>GRF SOC CON11</u>       | 0x032c | W    | 0x00000208     | SOC control register 11       |
| <u>GRF_SOC_STATUS0</u>     | 0x0380 | W    | 0x0000000f     | SOC status 0                  |
| <u>GRF CPU CONO</u>        | 0x0400 | W    | 0x0000000      | CPU control register 0        |
| <u>GRF_CPU_CON1</u>        | 0x0404 | W    | 0x0000000      | CPU control register 1        |
| <u>GRF CPU CON2</u>        | 0x0408 | W    | 0x0000021      | CPU control register 2        |
| <u>GRF CPU STATUSO</u>     | 0x0420 | W    | 0x0000000      | CPU status 0                  |
| <u>GRF_CPU_STATUS1</u>     | 0x0424 | W    | 0x0000000      | CPU status 1                  |
| <u>GRF PVTM CON0</u>       | 0x0440 | W    | 0x0000000      | PVTM control 0                |
| <u>GRF_PVTM_CON1</u>       | 0x0444 | W    | 0x0000000      | PVTM control 1                |
| <u>GRF PVTM STATUS0</u>    | 0x0448 | W    | 0x0000000      | PVTM status 0                 |
| <u>GRF PVTM STATUS1</u>    | 0x044c | W    | 0x0000000      | PVTM status 1                 |
| <u>GRF_TSADC_TESTBIT_L</u> | 0x0460 | W    | 0x0000000      | TSADC test low bits register  |
| <u>GRF TSADC TESTBIT H</u> | 0x0464 | W    | 0x0000000      | 5 5                           |
| GRF USB2 HOST0 CON0        | 0x0480 | W    | 0x00000820     | USB 2.0 host control 0        |
| GRF USB2 HOST0 CON1        | 0x0484 | W    | 0x000004bc     | USB 2.0 host control 1        |
| GRF USB2 OTG CONO          | 0x0488 | W    | 0x0000000      | USB 2.0 OTG control 0         |

| Name                                     | Offset | Size | Reset<br>Value | Description                                 |
|------------------------------------------|--------|------|----------------|---------------------------------------------|
| <u>GRF_USB2_HOST0_STAT</u><br><u>US0</u> | 0x048c | w    | 0x0000000      | USB 2.0 host 0 status 0                     |
| GRF_MAC_CON0                             | 0x04a0 | W    | 0x00000000     | MAC control 0                               |
| GRF UPCTL CONO                           | 0x04a4 | w    | 0x0000001      | Universal DDR protocol controller control 0 |
| <u>GRF_UPCTL_STATUS0</u>                 | 0x04a8 | W    | 0x0000000      | Universal DDR protocol controller status 0  |
| <u>GRF OS REGO</u>                       | 0x0500 | W    | 0x00000000     | OS register 0                               |
| <u>GRF OS REG1</u>                       | 0x0504 | W    | 0x00000000     | OS register 1                               |
| <u>GRF OS REG2</u>                       | 0x0508 | W    | 0x00000000     | OS register 2                               |
| <u>GRF OS REG3</u>                       | 0x050c | W    | 0x00000000     | OS register 3                               |
| <u>GRF OS REG4</u>                       | 0x0510 | W    | 0x00000000     | OS register 4                               |
| <u>GRF OS REG5</u>                       | 0x0514 | W    | 0x00000000     | OS register 5                               |
| <u>GRF_OS_REG6</u>                       | 0x0518 | W    | 0x00000000     | OS register 6                               |
| <u>GRF OS REG7</u>                       | 0x051c | W    | 0x00000000     | OS register 7                               |
| <u>GRF OS REG8</u>                       | 0x0520 | W    | 0x00000000     | OS register 8                               |
| <u>GRF OS REG9</u>                       | 0x0524 | W    | 0x0000000      | OS register 9                               |
| <u>GRF OS REG10</u>                      | 0x0528 | W    | 0x00000000     | OS register 10                              |
| <u>GRF_OS_REG11</u>                      | 0x052c | W    | 0x0000000      | OS register 11                              |
| GRF SOC CON12                            | 0x0600 | W    | 0x0000000      | SOC control register 12                     |
| GRF CHIP ID                              | 0x0800 | W    | 0x00000cea     | Chip ID register                            |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# **30.4.3 GRF Detail Register Description**

### **GRF GPIO0A IOMUX**

Address: Operational Base + offset (0x0000)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | WU   |                    | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
|       |      | W 0x0              | gpio0a7_sel                                           |
|       |      |                    | 2'b00: GPIO0_A7                                       |
| 15:14 | RW   |                    | 2'b01: Reserved                                       |
|       |      |                    | 2'b10: Reserved                                       |
|       |      |                    | 2'b11: Reserved                                       |

| Bit   | Attr | <b>Reset Value</b> | Description        |
|-------|------|--------------------|--------------------|
|       |      |                    | gpio0a6_sel        |
|       |      |                    | 2'b00: GPIO0_A6    |
| 13:12 | RW   | 0x0                | 2'b01: Reserved    |
|       |      |                    | 2'b10: Reserved    |
|       |      |                    | 2'b11: Reserved    |
|       |      |                    | gpio0a5_sel        |
|       |      |                    | 2'b00: GPIO0_A5    |
| 11:10 | RW   | 0x0                | 2'b01: Reserved    |
|       |      |                    | 2'b10: Reserved    |
|       |      |                    | 2'b11: Reserved    |
|       |      |                    | gpio0a4_sel        |
|       |      |                    | 2'b00: GPIO0_A4    |
| 9:8   | RW   | 0x0                | 2'b01: TEST_CLKOUT |
|       |      |                    | 2'b10: Reserved    |
|       |      |                    | 2'b11: Reserved    |
|       |      |                    | gpio0a3_sel        |
|       |      |                    | 2'b00: GPIO0_A3    |
| 7:6   | RW   | 0x1                | 2'b01: SDMMC_DET   |
|       |      |                    | 2'b10: Reserved    |
|       |      |                    | 2'b11: Reserved    |
|       |      |                    | gpio0a2_sel        |
|       |      |                    | 2'b00: GPIO0_A2    |
| 5:4   | RW   | 0x0                | 2'b01: SDIO_PWREN  |
|       |      |                    | 2'b10: Reserved    |
|       |      |                    | 2'b11: Reserved    |
|       |      |                    | gpio0a1_sel        |
|       |      |                    | 2'b00: GPIO0_A1    |
| 3:2   | RW   | 0x0                | 2'b01: SDIO_WRPT   |
|       |      |                    | 2'b10: Reserved    |
|       |      |                    | 2'b11: Reserved    |
|       |      |                    | gpio0a0_sel        |
|       |      |                    | 2'b00: GPIO0_A0    |
| 1:0   | RW   | 0x0                | 2'b01: SDIO_INTN   |
|       |      |                    | 2'b10: Reserved    |
|       |      |                    | 2'b11: Reserved    |

### **GRF GPIOOB IOMUX**

Address: Operational Base + offset (0x0008)

| Bit   | Attr | Reset Value | Description                                           |
|-------|------|-------------|-------------------------------------------------------|
|       |      |             | write_enable                                          |
|       |      |             | When bit $16=1$ , bit 0 can be written by software.   |
|       |      |             | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 |      | 0000        | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | wO   | 0×0000      | When bit 17=0, bit 1 can not be written by software.  |
|       |      |             |                                                       |
|       |      |             | When bit 31=1, bit 15 can be written by software.     |
|       |      |             | When bit 31=0, bit 15 can not be written by software. |
|       |      |             | gpio0b7_sel                                           |
|       |      |             | 2'b00: GPIO0_B7                                       |
| 15:14 | RW   | 0x0         | 2'b01: PWM2                                           |
|       |      |             | 2'b10: I2C3_SDA_M0                                    |
|       |      |             | 2'b11: Reserved                                       |
|       |      |             | gpio0b6_sel                                           |
|       |      |             | 2'b00: GPIO0_B6                                       |
| 13:12 | RW   | 0x0         | 2'b01: PWM1                                           |
|       |      |             | 2'b10: Reserved                                       |
|       |      |             | 2'b11: Reserved                                       |
|       |      |             | gpio0b5_sel                                           |
|       |      |             | 2'b00: GPIO0_B5                                       |
| 11:10 | RW   | 0x0         | 2'b01: PWM0                                           |
|       |      |             | 2'b10: Reserved                                       |
|       |      |             | 2'b11: Reserved                                       |
|       |      |             | gpio0b4_sel                                           |
|       |      |             | 2'b00: GPIO0_B4                                       |
| 9:8   | RW   | 0x0         | 2'b01: I2C1_SCL                                       |
|       |      |             | 2'b10: Reserved                                       |
|       |      |             | 2'b11: Reserved                                       |
|       |      |             | gpio0b3_sel                                           |
| 7.6   |      |             | 2'b00: GPIO0_B3                                       |
| 7:6   | RW   | 0x0         | 2'b01: I2C1_SDA                                       |
|       |      |             | 2'b10: Reserved                                       |
|       |      |             | 2'b11: Reserved                                       |
|       |      |             | gpio0b2_sel                                           |
| E. 4  | עע   | 0.40        | 2'b00: GPIO0_B2                                       |
| 5:4   | RW   | 0x0         | 2'b01: TSADC_SHUT<br>2'b10: Reserved                  |
|       |      |             | 2'b11: Reserved                                       |
|       |      |             |                                                       |
|       |      |             | gpio0b1_sel<br>2'b00: GPIO0_B1                        |
| 3:2   | RW   | 0x0         | 2'b01: PMIC_SLEEP                                     |
| 5.2   |      |             | 2'b10: Reserved                                       |
|       |      |             | 2'b11: Reserved                                       |
|       |      |             |                                                       |

| Bit | Attr | <b>Reset Value</b> | Description     |
|-----|------|--------------------|-----------------|
|     |      |                    | gpio0b0_sel     |
|     |      |                    | 2'b00: GPIO0_B0 |
| 1:0 | RW   | 0x0                | 2'b01: Reserved |
|     |      |                    | 2'b10: Reserved |
|     |      |                    | 2'b11: Reserved |

# **<u>GRF\_GPIO0C\_IOMUX</u>**

Address: Operational Base + offset (0x0010)

| Bit   |      | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_enable                                                 |
|       |      |                    | When bit 16=1, bit 0 can be written by software.             |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.         |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.             |
| 31:10 | WÜ   | 0x0000             | When bit 17=0, bit 1 can not be written by software.         |
|       |      |                    |                                                              |
|       |      |                    | When bit 31=1, bit 15 can be written by software.            |
|       |      |                    | When bit 31=0, bit 15 can not be written by software.        |
| 15:12 | RO   | 0x0                | reserved                                                     |
|       |      |                    | gpio0c5_sel                                                  |
|       |      |                    | 2'b00: GPIO0_C5/OTG_DRVBUS                                   |
|       |      |                    | 2'b01: Reserved                                              |
| 11:10 | R/\/ | 0x0                | 2'b10: Reserved                                              |
| 11.10 |      | 0.0                | 2'b11: Reserved                                              |
|       |      |                    | When GPIO0_C5 is configured as GPIO function mode, it can be |
|       |      |                    | controlled by SOC_CON0[6], when set otg_drvvbus_out_ctrl     |
|       |      |                    | HIGH, the gpio out data is derived from otg_drvvbus.         |
|       |      |                    | gpio0c4_sel                                                  |
|       |      |                    | 2'b00: GPIO0_C4                                              |
| 9:8   | RW   | 0x0                | 2'b01: Reserved                                              |
|       |      |                    | 2'b10: Reserved                                              |
|       |      |                    | 2'b11: Reserved                                              |
|       |      |                    | gpio0c3_sel                                                  |
|       |      |                    | 2'b00: GPIO0_C3                                              |
| 7:6   | RW   | 0x0                | 2'b01: RTC_CLK                                               |
|       |      |                    | 2'b10: Reserved                                              |
|       |      |                    | 2'b11: Reserved                                              |
|       |      |                    | gpio0c2_sel                                                  |
|       |      |                    | 2'b00: GPIO0_C2                                              |
| 5:4   | RW   | W 0x0              | 2'b01: SPDIF_RX                                              |
|       |      |                    | 2'b10: Reserved                                              |
|       |      |                    | 2'b11: Reserved                                              |

| Bit | Attr | <b>Reset Value</b> | Description        |
|-----|------|--------------------|--------------------|
|     |      |                    | gpio0c1_sel        |
|     |      |                    | 2'b00: GPIO0_C1    |
| 3:2 | RW   | 0x0                | 2'b01: SPDIF_TX    |
|     |      |                    | 2'b10: Reserved    |
|     |      |                    | 2'b11: Reserved    |
|     |      |                    | gpio0c0_sel        |
|     |      |                    | 2'b00: GPIO0_C0    |
| 1:0 | RW   | 0x0                | 2'b01: PWM3        |
|     |      |                    | 2'b10: I2C3_SCL_M0 |
|     |      |                    | 2'b11: Reserved    |

# **GRF GPIO1A IOMUX**

Address: Operational Base + offset (0x0020)

| Bit   |    | <b>Reset Value</b> | Description                                           |
|-------|----|--------------------|-------------------------------------------------------|
|       |    |                    | write_enable                                          |
|       |    |                    | When bit $16=1$ , bit 0 can be written by software.   |
|       |    |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | WU | 00000              | When bit 17=0, bit 1 can not be written by software.  |
|       |    |                    |                                                       |
|       |    |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |    |                    | When bit 31=0, bit 15 can not be written by software. |
|       |    |                    | gpio1a7_sel                                           |
|       |    |                    | 2'b00: GPIO1_A7                                       |
| 15:14 | RW | 0x0                | 2'b01: LCDC_D3                                        |
|       |    |                    | 2'b10: I2S1_8CH_SDO0_M0 (8CH)                         |
|       |    |                    | 2'b11: Reserved                                       |
|       |    |                    | gpio1a6_sel                                           |
|       |    |                    | 2'b00: GPIO1_A6                                       |
| 13:12 | RW | 0x0                | 2'b01: LCDC_D2                                        |
|       |    |                    | 2'b10: I2S1_8CH_LRCK_RX_M0 (8CH)                      |
|       |    |                    | 2'b11: Reserved                                       |
|       |    |                    | gpio1a5_sel                                           |
|       |    |                    | 2'b00: GPIO1_A5                                       |
| 11:10 | RW | 0x0                | 2'b01: LCDC_D1                                        |
|       |    |                    | 2'b10: I2S1_8CH_LRCK_TX_M0 (8CH)                      |
|       |    |                    | 2'b11: Reserved                                       |
|       |    |                    | gpio1a4_sel                                           |
|       |    |                    | 2'b00: GPIO1_A4                                       |
| 9:8   | RW | 0x0                | 2'b01: LCDC_D0                                        |
|       |    |                    | 2'b10: I2S1_8CH_SCLK_RX_M0 (8CH)                      |
|       |    |                    | 2'b11: PDM_8CH_CLK_M0                                 |

| Bit | Attr | Reset Value | Description                      |
|-----|------|-------------|----------------------------------|
|     |      |             | gpio1a3_sel                      |
|     |      |             | 2'b00: GPIO1_A3                  |
| 7:6 | RW   | 0x0         | 2'b01: LCDC_DEN                  |
|     |      |             | 2'b10: I2S1_8CH_SCLK_TX_M0 (8CH) |
|     |      |             | 2'b11: Reserved                  |
|     |      |             | gpio1a2_sel                      |
|     |      |             | 2'b00: GPIO1_A2                  |
| 5:4 | RW   | 0x0         | 2'b01: LCDC_VSYNC                |
|     |      |             | 2'b10: I2S1_8CH_MCLK_M0 (8CH)    |
|     |      |             | 2'b11: Reserved                  |
|     |      |             | gpio1a1_sel                      |
|     |      |             | 2'b00: GPIO1_A1                  |
| 3:2 | RW   | 0x0         | 2'b01: LCDC_HSYNC                |
|     |      |             | 2'b10: Reserved                  |
|     |      |             | 2'b11: Reserved                  |
|     |      |             | gpio1a0_sel                      |
|     |      |             | 2'b00: GPIO1_A0                  |
| 1:0 | RW   | 0x0         | 2'b01: LCDC_DCLK                 |
|     |      |             | 2'b10: Reserved                  |
|     |      |             | 2'b11: Reserved                  |

# **GRF GPIO1B IOMUX L**

Address: Operational Base + offset (0x0028)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | **0  | 0,0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
|       |      | RW 0x0             | gpio1b6_sel                                           |
|       |      |                    | 4'h0: GPIO1_B6                                        |
|       |      |                    | 4'h1: LCDC_D10                                        |
| 15:12 | RW   |                    | 4'h2: I2S1_8CH_SCLK_RX_M1 (8CH)                       |
|       |      |                    | 4'h3: MAC_MDIO                                        |
|       |      |                    | 4'h4: PDM_8CH_CLK_M1                                  |
|       |      |                    | Others: Reserved                                      |
|       |      |                    | gpio1b5_sel                                           |
|       |      |                    | 2'b00: GPIO1_B5                                       |
| 11:10 | RW   | 0x0                | 2'b01: LCDC_D9                                        |
|       |      |                    | 2'b10: I2S1_8CH_SCLK_TX_M1 (8CH)                      |
|       |      |                    | 2'b11: MAC_MDC                                        |

| Bit | Attr | <b>Reset Value</b> | Description                        |
|-----|------|--------------------|------------------------------------|
|     |      |                    | gpio1b4_sel                        |
|     |      |                    | 2'b00: GPIO1_B4                    |
| 9:8 | RW   | 0x0                | 2'b01: LCDC_D8                     |
|     |      |                    | 2'b10: I2S1_8CH_MCLK_M1 (8CH)      |
|     |      |                    | 2'b11: MAC_CLK                     |
|     |      |                    | gpio1b3_sel                        |
|     |      |                    | 2'b00: GPIO1_B3                    |
| 7:6 | RW   | 0x0                | 2'b01: LCDC_D7                     |
|     |      |                    | 2'b10: I2S1_8CH_SDI0_M0 (8CH)      |
|     |      |                    | 2'b11: PDM_8CH_SDI0_M0             |
|     |      |                    | gpio1b2_sel                        |
|     |      |                    | 2'b00: GPIO1_B2                    |
| 5:4 | RW   | 0x0                | 2'b01: LCDC_D6                     |
|     |      |                    | 2'b10: I2S1_8CH_SDO3_SDI1_M0 (8CH) |
|     |      |                    | 2'b11: PDM_8CH_SDI1_M0             |
|     |      |                    | gpio1b1_sel                        |
|     |      |                    | 2'b00: GPIO1_B1                    |
| 3:2 | RW   | 0x0                | 2'b01: LCDC_D5                     |
|     |      |                    | 2'b10: I2S1_8CH_SDO2_SDI2_M0 (8CH) |
|     |      |                    | 2'b11: PDM_8CH_SDI2_M0             |
|     |      |                    | gpio1b0_sel                        |
|     |      |                    | 2'b00: GPIO1_B0                    |
| 1:0 | RW   | 0x0                | 2'b01: LCDC_D4                     |
|     |      |                    | 2'b10: I2S1_8CH_SDO1_SDI3_M0 (8CH) |
|     |      |                    | 2'b11: PDM_8CH_SDI3_M0             |

### **GRF GPIO1B IOMUX H**

Address: Operational Base + offset (0x002c)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 | wo   | 0.40000            | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | WO   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:2  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio1b7_sel                                           |
|       |      |                    | 2'b00: GPIO1_B7                                       |
| 1:0   | RW   |                    | 2'b01: LCDC_D11                                       |
|       |      |                    | 2'b10: I2S1_8CH_LRCK_TX_M1 (8CH)                      |
|       |      |                    | 2'b11: MAC_RXER                                       |

**<u>GRF GPIO1C IOMUX L</u>** Address: Operational Base + offset (0x0030)

| Bit                 | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b><br>31:16 |      | 0x0000             | Wite_enable         When bit 16=1, bit 0 can be written by software.         When bit 16=0, bit 0 can not be written by software.         When bit 17=1, bit 1 can be written by software.         When bit 17=0, bit 1 can not be written by software.         When bit 31=1, bit 15 can be written by software.         When bit 31=0, bit 15 can not be written by software.         gpio1c4_sel |
| 15:12               | RW   | 0×0                | 4'h0: GPIO1_C4<br>4'h1: LCDC_D16<br>4'h2: I2S1_8CH_SDO3_SDI1_M1 (8CH)<br>4'h3: MAC_RXD0<br>4'h4: PDM_8CH_SDI1_M1<br>Others: Reserved                                                                                                                                                                                                                                                                |
| 11:8                | RW   | 0×0                | gpio1c3_sel<br>4'h0: GPIO1_C3<br>4'h1: LCDC_DA15<br>4'h2: I2S1_8CH_SDO2_SDI2_M1 (8CH)<br>4'h3: MAC_TXD1<br>4'h4: PDM_8CH_SDI2_M1<br>Others: Reserved                                                                                                                                                                                                                                                |
| 7:4                 | RW   | 0×0                | gpio1c2_sel<br>4'h0: GPIO1_C2<br>4'h1: LCDC_D14<br>4'h2: I2S1_8CH_SDO1_SDI3_M1 (8CH)<br>4'h3: MAC_TXD0<br>4'h4: PDM_8CH_SDI3_M1<br>Others: Reserved                                                                                                                                                                                                                                                 |
| 3:2                 | RW   | 0×0                | gpio1c1_sel<br>2'b00: GPIO1_C1<br>2'b01: LCDC_D13<br>2'b10: I2S1_8CH_SDO0_M1 (8CH)<br>2'b11: MAC_TXEN                                                                                                                                                                                                                                                                                               |
| 1:0                 | RW   | 0×0                | gpio1c0_sel<br>2'b00: GPIO1_C0<br>2'b01: LCDC_D12<br>2'b10: I2S1_8CH_LRCK_RX_M1 (8CH)<br>2'b11: MAC_RXDV                                                                                                                                                                                                                                                                                            |

### **GRF\_GPIO1C\_IOMUX\_H**

Address: Operational Base + offset (0x0034)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                          |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software.</pre> |
|       |      |                    | When bit $31=0$ , bit 15 can not be written by software.                                                                                                                                                                                                                             |
| 15:12 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                             |
| 11:8  | RW   | 0x4                | gpio1c7_sel<br>4'h0: GPIO1_C7<br>4'h1: UART1_RTSN<br>4'h2: UART2_TX_M0<br>4'h3: SPI2_MOSI<br>4'h4: JTAG_TMS<br>Others: Reserved                                                                                                                                                      |
| 7:4   | RW   | 0x4                | gpio1c6_sel<br>4'h0: GPIO1_C6<br>4'h1: UART1_CTSN<br>4'h2: UART2_RX_M0<br>4'h3: SPI2_MISO<br>4'h4: JTAG_TCK<br>Others: Reserved                                                                                                                                                      |
| 3:0   | RW   | 0×0                | gpio1c5_sel<br>4'h0: GPIO1_C5<br>4'h1: LCDC_D17<br>4'h2: I2S1_8CH_SDI0_M1 (8CH)<br>4'h3: MAC_RXD1<br>4'h4: PDM_8CH_SDI0_M1<br>Others: Reserved                                                                                                                                       |

# **GRF GPIO1D IOMUX**

Address: Operational Base + offset (0x0038)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:4  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |

| Bit | Attr | <b>Reset Value</b> | Description      |
|-----|------|--------------------|------------------|
|     |      |                    | gpio1d1_sel      |
|     |      |                    | 2'b00: GPIO1_D1  |
| 3:2 | RW   | 0x0                | 2'b01: UART1_TX  |
|     |      |                    | 2'b10: I2C0_SCL  |
|     |      |                    | 2'b11: SPI2_CSN0 |
|     |      |                    | gpio1d0_sel      |
|     |      |                    | 2'b00: GPIO1_D0  |
| 1:0 | RW   | 0x0                | 2'b01: UART1_RX  |
|     |      |                    | 2'b10: I2C0_SDA  |
|     |      |                    | 2'b11: SPI2_CLK  |

# **GRF GPIO2A IOMUX**

Address: Operational Base + offset (0x0040)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | ~~~  | 0,0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
|       |      |                    | gpio2a7_sel                                           |
|       |      | 0×0                | 2'b00: GPIO2_A7                                       |
| 15:14 | RW   |                    | 2'b01: I2S0_8CH_LRCK_TX (8CH)                         |
|       |      |                    | 2'b10: Reserved                                       |
|       |      |                    | 2'b11: Reserved                                       |
|       |      | W 0×0              | gpio2a6_sel                                           |
|       |      |                    | 2'b00: GPIO2_A6                                       |
| 13:12 | RW   |                    | 2'b01: I2S0_8CH_SCLK_RX (8CH)                         |
|       |      |                    | 2'b10: PDM_8CH_CLK_S_M2                               |
|       |      |                    | 2'b11: Reserved                                       |
|       |      |                    | gpio2a5_sel                                           |
|       |      |                    | 2'b00: GPIO2_A5                                       |
| 11:10 | RW   | 0x0                | 2'b01: I2S0_8CH_SCLK_TX (8CH)                         |
|       |      |                    | 2'b10: Reserved                                       |
|       |      |                    | 2'b11: Reserved                                       |

| Bit | Attr | Reset Value | Description                                                   |
|-----|------|-------------|---------------------------------------------------------------|
|     |      |             | gpio2a4_sel                                                   |
|     |      |             | 2'b00: GPIO2_A4                                               |
|     |      |             | 2'b01: I2S0_8CH_MCLK (8CH)                                    |
|     |      |             | 2'b10: Reserved                                               |
|     |      |             | 2'b11: Reserved                                               |
| 9:8 | RW   | 0x0         | 2'bxx: PDM_8CH_CLK_M_M2                                       |
| 9.0 |      | 0.00        | When SOC_CON12[2] grf_gpio2a4_pad_out_src_sel is set to       |
|     |      |             | HIGH, the GPIO2_A4 is drived as PDM_8CH_CLK_M_M2              |
|     |      |             | regardless of IOMUX setting of gpio2a4_sel, and the IO output |
|     |      |             | enable is controlled by GPIO0_B1 IO data out signal. To make  |
|     |      |             | sure the functionality works well, the GPIO0_B1 should be     |
|     |      |             | configured as PMIC_SLEEP function as application required.    |
|     |      |             | gpio2a3_sel                                                   |
|     |      |             | 2'b00: GPIO2_A3                                               |
| 7:6 | RW   | 0x0         | 2'b01: UART0_RTSN                                             |
|     |      |             | 2'b10: SPI0_CSN0                                              |
|     |      |             | 2'b11: I2C2_SCL                                               |
|     |      |             | gpio2a2_sel                                                   |
|     |      |             | 2'b00: GPIO2_A2                                               |
| 5:4 | RW   | 0×0         | 2'b01: UART0_CTSN                                             |
|     |      |             | 2'b10: SPI0_CLK                                               |
|     |      |             | 2'b11: I2C2_SDA                                               |
|     |      |             | gpio2a1_sel                                                   |
|     |      |             | 2'b00: GPIO2_A1                                               |
| 3:2 | RW   | 0x0         | 2'b01: UART0_TX                                               |
|     |      |             | 2'b10: SPI0_MOSI                                              |
|     |      |             | 2'b11: Reserved                                               |
|     |      |             | gpio2a0_sel                                                   |
|     |      |             | 2'b00: GPIO2_A0                                               |
| 1:0 | RW   | 0x0         | 2'b01: UARTO_RX                                               |
|     |      |             | 2'b10: SPI0_MISO                                              |
|     |      |             | 2'b11: Reserved                                               |

# **GRF\_GPIO2B\_IOMUX**

Address: Operational Base + offset (0x0048)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |

| Bit   | Attr | Reset Value | Description                   |
|-------|------|-------------|-------------------------------|
|       |      |             | gpio2b7_sel                   |
|       |      |             | 2'b00: GPIO2_B7               |
| 15:14 | RW   | 0x0         | 2'b01: I2S0_8CH_SDI2 (8CH)    |
|       |      |             | 2'b10: PDM_8CH_SDI2_M2        |
|       |      |             | 2'b11: Reserved               |
|       |      |             | gpio2b6_sel                   |
|       |      |             | 2'b00: GPIO2_B6               |
| 13:12 | RW   | 0x0         | 2'b01: I2S0_8CH_SDI1 (8CH)    |
|       |      |             | 2'b10: PDM_8CH_SDI1_M2        |
|       |      |             | 2'b11: Reserved               |
|       |      |             | gpio2b5_sel                   |
|       |      |             | 2'b00: GPIO2_B5               |
| 11:10 | RW   | 0x0         | 2'b01: I2S0_8CH_SDI0 (8CH)    |
|       |      |             | 2'b10: PDM_8CH_SDI0_M2        |
|       |      |             | 2'b11: Reserved               |
|       |      |             | gpio2b4_sel                   |
|       |      |             | 2'b00: GPIO2_B4               |
| 9:8   | RW   | 0x0         | 2'b01: I2S0_8CH_SDO3 (8CH)    |
|       |      |             | 2'b10: Reserved               |
|       |      |             | 2'b11: Reserved               |
|       |      |             | gpio2b3_sel                   |
|       |      |             | 2'b00: GPIO2_B3               |
| 7:6   | RW   | 0x0         | 2'b01: I2S0_8CH_SDO2 (8CH)    |
|       |      |             | 2'b10: Reserved               |
|       |      |             | 2'b11: Reserved               |
|       |      |             | gpio2b2_sel                   |
|       |      |             | 2'b00: GPIO2_B2               |
| 5:4   | RW   | 0x0         | 2'b01: I2S0_8CH_SDO1 (8CH)    |
|       |      |             | 2'b10: Reserved               |
|       |      |             | 2'b11: Reserved               |
|       |      |             | gpio2b1_sel                   |
|       |      |             | 2'b00: GPIO2_B1               |
| 3:2   | RW   | 0x0         | 2'b01: I2S0_8CH_SDO0 (8CH)    |
|       |      |             | 2'b10: Reserved               |
|       |      |             | 2'b11: Reserved               |
|       |      |             | gpio2b0_sel                   |
|       |      |             | 2'b00: GPIO2_B0               |
| 1:0   | RW   | 0x0         | 2'b01: I2S0_8CH_LRCK_RX (8CH) |
|       |      |             | 2'b10: Reserved               |
|       |      |             | 2'b11: Reserved               |

**<u>GRF GPIO2C IOMUX</u>** Address: Operational Base + offset (0x0050)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1:0   | RW   | 0×0                | gpio2c0_sel<br>2'b00: GPIO2_C0<br>2'b01: I2S0_8CH_SDI3 (8CH)<br>2'b10: PDM_8CH_SDI3_M2<br>2'b11: Reserved                                                                                                                                                                                                                                                                                                  |

# **GRF GPIO3A IOMUX**

Address: Operational Base + offset (0x0060)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | WO   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | vv0  | 0,0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
|       |      |                    | gpio3a7_sel                                           |
|       |      |                    | 2'b00: GPIO3_A7                                       |
| 15:14 | RW   | 0x0                | 2'b01: FLASH_D7                                       |
|       |      |                    | 2'b10: EMMC_D7                                        |
|       |      |                    | 2'b11: Reserved                                       |
|       |      | W 0×0              | gpio3a6_sel                                           |
|       |      |                    | 2'b00: GPIO3_A6                                       |
| 13:12 | RW   |                    | 2'b01: FLASH_D6                                       |
|       |      |                    | 2'b10: EMMC_D6                                        |
|       |      |                    | 2'b11: Reserved                                       |
|       |      |                    | gpio3a5_sel                                           |
|       |      |                    | 2'b00: GPIO3_A5                                       |
| 11:10 | RW   | 0x0                | 2'b01: FLASH_D5                                       |
|       |      |                    | 2'b10: EMMC_D5                                        |
|       |      |                    | 2'b11: SFC_CSN0                                       |

| Bit | Attr | Reset Value | Description          |
|-----|------|-------------|----------------------|
|     |      |             | gpio3a4_sel          |
|     |      |             | 2'b00: GPIO3_A4      |
| 9:8 | RW   | 0x0         | 2'b01: FLASH_D4      |
|     |      |             | 2'b10: EMMC_D4       |
|     |      |             | 2'b11: SFC_CLK       |
|     |      |             | gpio3a3_sel          |
|     |      |             | 2'b00: GPIO3_A3      |
| 7:6 | RW   | 0x0         | 2'b01: FLASH_D3      |
|     |      |             | 2'b10: EMMC_D3       |
|     |      |             | 2'b11: SFC_HOLD_SIO3 |
|     |      |             | gpio3a2_sel          |
|     |      |             | 2'b00: GPIO3_A2      |
| 5:4 | RW   | 0x0         | 2'b01: FLASH_D2      |
|     |      |             | 2'b10: EMMC_D2       |
|     |      |             | 2'b11: SFC_WP_SIO2   |
|     |      |             | gpio3a1_sel          |
|     |      |             | 2'b00: GPIO3_A1      |
| 3:2 | RW   | 0x0         | 2'b01: FLASH_D1      |
|     |      |             | 2'b10: EMMC_D1       |
|     |      |             | 2'b11: SFC_SIO1      |
|     |      |             | gpio3a0_sel          |
|     |      |             | 2'b00: GPIO3_A0      |
| 1:0 | RW   | 0x0         | 2'b01: FLASH_D0      |
|     |      |             | 2'b10: EMMC_D0       |
|     |      |             | 2'b11: SFC_SIO0      |

## **GRF GPIO3B IOMUX**

Address: Operational Base + offset (0x0068)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 can not be written by software.</pre> |
| 15:12 | RW   | 0x0         | gpio3b5_sel<br>4'h0: GPIO3_B5<br>4'h1: FLASH_CSN0<br>4'h2: I2C3_SCL_M1<br>4'h3: SPI1_CSN0<br>4'h4: UART3_TX<br>Others: Reserved                                                                                                                                                                                                            |

| Bit  | Attr | <b>Reset Value</b> | Description              |
|------|------|--------------------|--------------------------|
|      |      |                    | gpio3b4_sel              |
|      |      |                    | 4'h0: GPIO3_B4           |
|      |      |                    | 4'h1: FLASH_RDY          |
| 11:8 | RW   | 0x0                | 4'h2: I2C3_SDA_M1        |
|      |      |                    | 4'h3: SPI1_MOSI          |
|      |      |                    | 4'h4: UART3_RX           |
|      |      |                    | Others: Reserved         |
|      |      |                    | gpio3b3_sel              |
|      |      |                    | 2'b00: GPIO3_B3          |
| 7:6  | RW   | 0x0                | 2'b01: FLASH_ALE         |
|      |      |                    | 2'b10: EMMC_PWREN        |
|      |      |                    | 2'b11: SPI1_CLK          |
|      |      |                    | gpio3b2_sel              |
|      |      |                    | 2'b00: GPIO3_B2          |
| 5:4  | RW   | 0x0                | 2'b01: FLASH_RDN         |
|      |      |                    | 2'b10: EMMC_RSTNReserved |
|      |      |                    | 2'b11: SPI1_MISO         |
|      |      |                    | gpio3b1_sel              |
|      |      |                    | 2'b00: GPIO3_B1          |
| 3:2  | RW   | 0x0                | 2'b01: FLASH_CLE         |
|      |      |                    | 2'b10: EMMC_CLK          |
|      |      |                    | 2'b11: Reserved          |
|      |      |                    | gpio3b0_sel              |
|      |      |                    | 2'b00: GPIO3_B0          |
| 1:0  | RW   | W 0x0              | 2'b01: FLASH_WRN         |
|      |      |                    | 2'b10: EMMC_CMD          |
|      |      |                    | 2'b11: Reserved          |

**<u>GRF\_GPIO4A\_IOMUX</u>** Address: Operational Base + offset (0x0080)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0,0000             | When bit 17=1, bit 1 can be written by software.      |
| 21:10 | vvO  | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
|       |      |                    | gpio4a7_sel                                           |
|       |      |                    | 2'b00: GPIO4_A7                                       |
| 15:14 | RW   | 0×0                | 2'b01: UART4_RTSN                                     |
|       |      |                    | 2'b10: Reserved                                       |
|       |      |                    | 2'b11: Reserved                                       |

| Bit   | Attr | Reset Value | Description       |
|-------|------|-------------|-------------------|
|       |      |             | gpio4a6_sel       |
|       |      |             | 2'b00: GPIO4_A6   |
| 13:12 | RW   | 0x0         | 2'b01: UART4_CTSN |
|       |      |             | 2'b10: Reserved   |
|       |      |             | 2'b11: Reserved   |
|       |      |             | gpio4a5_sel       |
|       |      |             | 2'b00: GPIO4_A5   |
| 11:10 | RW   | 0x0         | 2'b01: SDIO_CLK   |
|       |      |             | 2'b10: Reserved   |
|       |      |             | 2'b11: Reserved   |
|       |      |             | gpio4a4_sel       |
|       |      |             | 2'b00: GPIO4_A4   |
| 9:8   | RW   | 0x0         | 2'b01: SDIO_CMD   |
|       |      |             | 2'b10: Reserved   |
|       |      |             | 2'b11: Reserved   |
|       |      |             | gpio4a3_sel       |
|       |      |             | 2'b00: GPIO4_A3   |
| 7:6   | RW   | 0x0         | 2'b01: SDIO_D3    |
|       |      |             | 2'b10: Reserved   |
|       |      |             | 2'b11: Reserved   |
|       |      |             | gpio4a2_sel       |
|       |      |             | 2'b00: GPIO4_A2   |
| 5:4   | RW   | 0x0         | 2'b01: SDIO_D2    |
|       |      |             | 2'b10: Reserved   |
|       |      |             | 2'b11: Reserved   |
|       |      |             | gpio4a1_sel       |
|       |      |             | 2'b00: GPIO4_A1   |
| 3:2   | RW   | 0x0         | 2'b01: SDIO_D1    |
|       |      |             | 2'b10: Reserved   |
|       |      |             | 2'b11: Reserved   |
|       |      |             | gpio4a0_sel       |
|       |      |             | 2'b00: GPIO4_A0   |
| 1:0   | RW   | 0x0         | 2'b01: SDIO_D0    |
|       |      |             | 2'b10: Reserved   |
|       |      |             | 2'b11: Reserved   |

### **GRF GPIO4B IOMUX**

Address: Operational Base + offset (0x0088)

| Bit   | Attr    | Reset Value | Description                                           |
|-------|---------|-------------|-------------------------------------------------------|
|       |         |             | write_enable                                          |
|       |         |             | When bit $16=1$ , bit 0 can be written by software.   |
|       |         |             | When bit 16=0, bit 0 can not be written by software.  |
| 24.46 |         |             | When bit $17=1$ , bit 1 can be written by software.   |
| 31:16 | wO      | 0×0000      | When bit 17=0, bit 1 can not be written by software.  |
|       |         |             |                                                       |
|       |         |             | When bit $31=1$ , bit 15 can be written by software.  |
|       |         |             | When bit 31=0, bit 15 can not be written by software. |
|       |         |             | gpio4b7_sel                                           |
|       |         |             | 2'b00: GPIO4_B7                                       |
| 15:14 | RW      | 0x0         | 2'b01: I2S0_2CH_SDO                                   |
|       |         |             | 2'b10: Reserved                                       |
|       |         |             | 2'b11: Reserved                                       |
|       |         |             | gpio4b6_sel                                           |
|       |         |             | 2'b00: GPIO4_B6                                       |
| 13:12 | RW      | 0x0         | 2'b01: I2S0_2CH_LRCK_TX                               |
|       |         |             | 2'b10: Reserved                                       |
|       |         |             | 2'b11: Reserved                                       |
|       |         |             | gpio4b5_sel                                           |
|       |         |             | 2'b00: GPIO4_B5                                       |
| 11:10 | RW      | 0x0         | 2'b01: I2S0_2CH_SCLK                                  |
|       |         |             | 2'b10: Reserved                                       |
|       |         |             | 2'b11: Reserved                                       |
|       |         |             | gpio4b4_sel                                           |
|       |         |             | 2'b00: GPIO4_B4                                       |
| 9:8   | RW      | 0x0         | 2'b01: I2S0_2CH_MCLK                                  |
|       |         |             | 2'b10: Reserved                                       |
|       |         |             | 2'b11: Reserved                                       |
|       |         |             | gpio4b3_sel                                           |
| 7.6   | <b></b> |             | 2'b00: GPIO4_B3                                       |
| 7:6   | RW      | 0x0         | 2'b01: Reserved                                       |
|       |         |             | 2'b10: Reserved                                       |
|       |         |             | 2'b11: Reserved                                       |
|       |         |             | gpio4b2_sel                                           |
| E. 4  | עע      | 0.40        | 2'b00: GPIO4_B2                                       |
| 5:4   | RW      | 0x0         | 2'b01: Reserved<br>2'b10: Reserved                    |
|       |         |             | 2'b11: Reserved                                       |
|       |         |             |                                                       |
|       |         |             | gpio4b1_sel<br>2'b00: GPIO4_B1                        |
| 3:2   | RW      | 0x0         | 2'b01: UART4_TX                                       |
| 5.2   |         |             | 2'b10: Reserved                                       |
|       |         |             | 2'b11: Reserved                                       |
|       |         |             |                                                       |

| Bit | Attr | <b>Reset Value</b> | Description     |
|-----|------|--------------------|-----------------|
|     |      |                    | gpio4b0_sel     |
|     |      |                    | 2'b00: GPIO4_B0 |
| 1:0 | RW   | 0x0                | 2'b01: UART4_RX |
|     |      |                    | 2'b10: Reserved |
|     |      |                    | 2'b11: Reserved |

### **<u>GRF\_GPIO4C\_IOMUX</u>**

Address: Operational Base + offset (0x0090)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                          |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | write_enable<br>When bit 16=1, bit 0 can be written by software.<br>When bit 16=0, bit 0 can not be written by software.<br>When bit 17=1, bit 1 can be written by software.<br>When bit 17=0, bit 1 can not be written by software. |
|       |      |                    | When bit 31=1, bit 15 can be written by software.<br>When bit 31=0, bit 15 can not be written by software.                                                                                                                           |
| 15:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                             |
| 1:0   | RW   | 0×0                | gpio4c0_sel<br>2'b00: GPIO4_C0<br>2'b01: I2S0_2CH_SDI<br>2'b10: Reserved<br>2'b11: Reserved                                                                                                                                          |

# GRF GPIO4D IOMUX

Address: Operational Base + offset (0x0098)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000      | write_enable<br>When bit 16=1, bit 0 can be written by software.<br>When bit 16=0, bit 0 can not be written by software.<br>When bit 17=1, bit 1 can be written by software. |
|       |      |             | When bit 17=0, bit 1 can not be written by software.<br><br>When bit 31=1, bit 15 can be written by software.<br>When bit 31=0, bit 15 can not be written by software.       |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                     |
| 13:12 | RW   | 0×0         | gpio4d6_sel<br>2'b00: GPIO4_D6<br>2'b01: SDMMC_PWREN<br>2'b10: Reserved<br>2'b11: Reserved                                                                                   |

|    |     | Description<br>gpio4d5_sel                                   |
|----|-----|--------------------------------------------------------------|
|    |     |                                                              |
|    |     | 2'b00: GPIO4_D5/PMU_DEBUG_TX                                 |
|    |     | 2'b01: SDMMC_CLK                                             |
|    |     | 2'b10: Reserved                                              |
| RW | 0x0 | 2'b11: Reserved                                              |
|    |     | When GPIO4_D5 is configured as GPIO function mode, it can be |
|    |     | controlled by SOC_CON1[15], When set                         |
|    |     | pmu_power_state_out_ctrl HIGH, the gpio out data is derived  |
|    |     | from pmu_debug_tx                                            |
|    |     | gpio4d4_sel                                                  |
|    |     | 2'b00: GPIO4_D4/PMU_POWER_STATE_4                            |
|    |     | 2'b01: SDMMC_CMD                                             |
|    |     | 2'b10: Reserved                                              |
| RW | 0x0 | 2'b11: Reserved                                              |
|    |     | When GPIO4_D4 is configured as GPIO function mode, it can be |
|    |     | controlled by SOC_CON1[15], When set                         |
|    |     | pmu_power_state_out_ctrl HIGH, the gpio out data is derived  |
|    |     | from pmu_power_state[4].                                     |
|    |     | gpio4d3_sel                                                  |
|    |     | 2'b00: GPIO4_D3/PMU_POWER_STATE_3                            |
|    |     | 2'b01: SDMMC_D3                                              |
|    |     | 2'b10: UART2_TX_M1                                           |
| RW | 0x0 | 2'b11: Reserved                                              |
|    |     | When GPIO4_D3 is configured as GPIO function mode, it can be |
|    |     | controlled by SOC_CON1[15], When set                         |
|    |     | pmu_power_state_out_ctrl HIGH, the gpio out data is derived  |
|    |     | from pmu_power_state[3].                                     |
|    |     | gpio4d2_sel                                                  |
|    |     | 2'b00: GPIO4_D2/PMU_POWER_STATE_2                            |
|    |     | 2'b01: SDMMC_D2                                              |
|    |     | 2'b10: UART2_RX_M1                                           |
| RW | 0x0 | 2'b11: Reserved                                              |
|    |     | When GPIO4_D2 is configured as GPIO function mode, it can be |
|    |     | controlled by SOC_CON1[15], When set                         |
|    |     | pmu_power_state_out_ctrl HIGH, the gpio out data is derived  |
|    |     | from pmu_power_state[2].                                     |
|    |     | gpio4d1_sel<br>2'b00: GPIO4_D1/PMU_POWER_STATE_1             |
|    |     | 2'b01: SDMMC_D1                                              |
|    |     | 2'b10: Reserved                                              |
| RW | 0x0 | 2'b11: Reserved                                              |
|    |     | When GPIO4_D1 is configured as GPIO function mode, it can be |
|    |     | controlled by SOC_CON1[15], When set                         |
|    |     | pmu_power_state_out_ctrl HIGH, the gpio out data is derived  |
|    |     | from pmu_power_state[1].                                     |
| F  | ۲W  | RW         0×0           RW         0×0                      |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                     |
|-----|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | RW   | 0×0                | <pre>gpio4d0_sel<br/>2'b00: GPIO4_D0/PMU_POWER_STATE_0<br/>2'b01: SDMMC_D0<br/>2'b10: Reserved<br/>2'b11: Reserved<br/>When GPIO4_D0 is configured as GPIO function mode, it can be<br/>controlled by SOC_CON1[15], When set<br/>pmu_power_state_out_ctrl HIGH, the gpio out data is derived<br/>from pmu_power_state[0].</pre> |

# GRF GPIOOA P

Address: Operational Base + offset (0x00a0)

| Bit   | Attr | <b>Reset Value</b> | Description                                              |
|-------|------|--------------------|----------------------------------------------------------|
|       |      |                    | write_enable                                             |
|       |      |                    | When bit 16=1, bit 0 can be written by software.         |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.     |
| 31:16 | WO   | 0x0000             | When bit 17=1, bit 1 can be written by software.         |
| 31:10 | WU   | 0x0000             | When bit 17=0, bit 1 can not be written by software.     |
|       |      |                    |                                                          |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.     |
|       |      |                    | When bit $31=0$ , bit 15 can not be written by software. |
|       |      |                    | gpio0a7_p                                                |
|       |      |                    | Driver disabled state control.                           |
| 15:14 | D\\/ | 0x2                | 2'b00: Z (normal operation)                              |
| 13.14 |      | 0.72               | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio0a6_p                                                |
|       |      |                    | Driver disabled state control.                           |
| 13:12 | RW   | 0x2                | 2'b00: Z (normal operation)                              |
| 13.12 | 1    |                    | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio0a5_p                                                |
|       |      |                    | Driver disabled state control.                           |
| 11:10 | RW   | 0x2                | 2'b00: Z (normal operation)                              |
| 11110 |      | 0//L               | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio0a4_p                                                |
|       |      |                    | Driver disabled state control.                           |
| 9:8   | RW   | 0x1                | 2'b00: Z (normal operation)                              |
|       |      |                    | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      |                    | gpio0a3_p                      |
|     |      |                    | Driver disabled state control. |
| 7:6 | RW   | 0x1                | 2'b00: Z (normal operation)    |
| 7.0 | K VV | UXI                | 2'b01: weak 1 (pull-up)        |
|     |      |                    | 2'b10: weak 0 (pull-down)      |
|     |      |                    | 2'b11: repeater (bus keeper)   |
|     |      |                    | gpio0a2_p                      |
|     |      |                    | Driver disabled state control. |
| 5:4 | RW   | 0x2                | 2'b00: Z (normal operation)    |
| 5.4 | 1    | 0.72               | 2'b01: weak 1 (pull-up)        |
|     |      |                    | 2'b10: weak 0 (pull-down)      |
|     |      |                    | 2'b11: repeater (bus keeper)   |
|     |      |                    | gpio0a1_p                      |
|     |      |                    | Driver disabled state control. |
| 3:2 | RW   | 0x2                | 2'b00: Z (normal operation)    |
| 5.2 |      |                    | 2'b01: weak 1 (pull-up)        |
|     |      |                    | 2'b10: weak 0 (pull-down)      |
|     |      |                    | 2'b11: repeater (bus keeper)   |
|     |      |                    | gpio0a0_p                      |
|     |      |                    | Driver disabled state control. |
| 1:0 | RW   | 0x2                | 2'b00: Z (normal operation)    |
| 1.0 | 1    | W UX2              | 2'b01: weak 1 (pull-up)        |
|     |      |                    | 2'b10: weak 0 (pull-down)      |
|     |      |                    | 2'b11: repeater (bus keeper)   |

**<u>GRF\_GPIO0B\_P</u>** Address: Operational Base + offset (0x00a4)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0,0000             | When bit 17=1, bit 1 can be written by software.      |
| 31:10 | wo   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
|       |      | V 0x2              | gpio0b7_p                                             |
|       |      |                    | Driver disabled state control.                        |
| 15:14 |      |                    | 2'b00: Z (normal operation)                           |
| 15:14 | RVV  |                    | 2'b01: weak 1 (pull-up)                               |
|       |      |                    | 2'b10: weak 0 (pull-down)                             |
|       |      |                    | 2'b11: repeater (bus keeper)                          |

| Bit   | Attr | <b>Reset Value</b> | Description                    |
|-------|------|--------------------|--------------------------------|
|       |      |                    | gpio0b6_p                      |
|       |      |                    | Driver disabled state control. |
| 12.12 |      | 0                  | 2'b00: Z (normal operation)    |
| 13:12 | RW   | 0x2                | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio0b5_p                      |
|       |      |                    | Driver disabled state control. |
| 11.10 |      | 0                  | 2'b00: Z (normal operation)    |
| 11:10 | RW   | 0x2                | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio0b4_p                      |
|       |      |                    | Driver disabled state control. |
| 0.0   |      | 0.1                | 2'b00: Z (normal operation)    |
| 9:8   | RW   | 0x1                | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio0b3_p                      |
|       |      |                    | Driver disabled state control. |
| 7.0   |      | / 0x1              | 2'b00: Z (normal operation)    |
| 7:6   | RW   |                    | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio0b2_p                      |
|       |      |                    | Driver disabled state control. |
| E. 4  | RW   | 0.42               | 2'b00: Z (normal operation)    |
| 5:4   | RW   | W 0x2              | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio0b1_p                      |
|       |      |                    | Driver disabled state control. |
| 3:2   | RW   | 0x2                | 2'b00: Z (normal operation)    |
| 5:2   | RVV  | UXZ                | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio0b0_p                      |
|       |      |                    | Driver disabled state control. |
| 1.0   | RW   | RW 0×2             | 2'b00: Z (normal operation)    |
| 1:0   |      |                    | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |

# GRF GPIOOC P

Address: Operational Base + offset (0x00a8)

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

| Bit   | Attr | Reset Value | Description                                              |
|-------|------|-------------|----------------------------------------------------------|
|       |      |             | write_enable                                             |
|       |      |             | When bit 16=1, bit 0 can be written by software.         |
|       |      |             | When bit $16=0$ , bit 0 can not be written by software.  |
|       |      |             | When bit $17=1$ , bit 1 can be written by software.      |
| 31:16 | wo   | 0×0000      | When bit $17=0$ , bit 1 can not be written by software.  |
|       |      |             |                                                          |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.     |
|       |      |             | When bit $31=0$ , bit 15 can not be written by software. |
| 15:12 | RO   | 0x0         | reserved                                                 |
|       |      |             | gpio0c5_p                                                |
|       |      |             | Driver disabled state control.                           |
|       |      |             | 2'b00: Z (normal operation)                              |
| 11:10 | RW   | 0x2         | 2'b01: weak 1 (pull-up)                                  |
|       |      |             | 2'b10: weak 0 (pull-down)                                |
|       |      |             | 2'b11: repeater (bus keeper)                             |
|       |      |             | gpio0c4_p                                                |
|       |      |             | Driver disabled state control.                           |
|       |      |             | 2'b00: Z (normal operation)                              |
| 9:8   | RW   | 0x2         | 2'b01: weak 1 (pull-up)                                  |
|       |      |             | 2'b10: weak 0 (pull-down)                                |
|       |      |             | 2'b11: repeater (bus keeper)                             |
|       |      |             | gpio0c3_p                                                |
|       |      |             | Driver disabled state control.                           |
|       |      |             | 2'b00: Z (normal operation)                              |
| 7:6   | RW   | 0x0         | 2'b01: weak 1 (pull-up)                                  |
|       |      |             | 2'b10: weak 0 (pull-down)                                |
|       |      |             | 2'b11: repeater (bus keeper)                             |
|       |      |             | gpio0c2_p                                                |
|       |      |             | Driver disabled state control.                           |
|       |      |             | 2'b00: Z (normal operation)                              |
| 5:4   | RW   | 0x2         | 2'b01: weak 1 (pull-up)                                  |
|       |      |             | 2'b10: weak 0 (pull-down)                                |
|       |      |             | 2'b11: repeater (bus keeper)                             |
|       |      |             |                                                          |
|       |      |             | gpio0c1_p<br>Driver disabled state control.              |
|       |      |             |                                                          |
| 3:2   | RW   | 0x2         | 2'b00: Z (normal operation)                              |
|       |      |             | 2'b01: weak 1 (pull-up)                                  |
|       |      |             | 2'b10: weak 0 (pull-down)                                |
|       |      |             | 2'b11: repeater (bus keeper)                             |
|       |      |             | gpio0c0_p                                                |
|       |      |             | Driver disabled state control.                           |
| 1:0   | RW   | 0x2         | 2'b00: Z (normal operation)                              |
|       |      |             | 2'b01: weak 1 (pull-up)                                  |
|       |      |             | 2'b10: weak 0 (pull-down)                                |
|       |      |             | 2'b11: repeater (bus keeper)                             |

# GRF\_GPIO1A\_P

Address: Operational Base + offset (0x00b0)

| Bit   |       | Reset Value | + offset (0x00b0) Description                            |
|-------|-------|-------------|----------------------------------------------------------|
|       |       |             | write_enable                                             |
|       |       |             | When bit 16=1, bit 0 can be written by software.         |
|       |       |             | When bit 16=0, bit 0 can not be written by software.     |
|       |       |             | When bit 17=1, bit 1 can be written by software.         |
| 31:16 | WO    | 0×0000      | When bit 17=0, bit 1 can not be written by software.     |
|       |       |             | , , , , , , , , , , , , , , , , , , ,                    |
|       |       |             | When bit $31=1$ , bit 15 can be written by software.     |
|       |       |             | When bit $31=0$ , bit 15 can not be written by software. |
|       |       |             | gpio1a7_p                                                |
|       |       |             | Driver disabled state control.                           |
|       |       |             | 2'b00: Z (normal operation)                              |
| 15:14 | RW    | 0x2         | 2'b01: weak 1 (pull-up)                                  |
|       |       |             | 2'b10: weak 0 (pull-down)                                |
|       |       |             | 2'b11: repeater (bus keeper)                             |
|       |       |             | gpio1a6_p                                                |
|       |       |             | Driver disabled state control.                           |
| 10.10 | D).4/ | 0.0         | 2'b00: Z (normal operation)                              |
| 13:12 | RW    | 0x2         | 2'b01: weak 1 (pull-up)                                  |
|       |       |             | 2'b10: weak 0 (pull-down)                                |
|       |       |             | 2'b11: repeater (bus keeper)                             |
|       |       |             | gpio1a5_p                                                |
|       |       |             | Driver disabled state control.                           |
| 11:10 | עע    | 0.2         | 2'b00: Z (normal operation)                              |
| 11.10 | RVV   | W 0x2       | 2'b01: weak 1 (pull-up)                                  |
|       |       |             | 2'b10: weak 0 (pull-down)                                |
|       |       |             | 2'b11: repeater (bus keeper)                             |
|       |       |             | gpio1a4_p                                                |
|       |       |             | Driver disabled state control.                           |
| 9:8   | RW    | 0x2         | 2'b00: Z (normal operation)                              |
| 9.0   |       | 0.72        | 2'b01: weak 1 (pull-up)                                  |
|       |       |             | 2'b10: weak 0 (pull-down)                                |
|       |       |             | 2'b11: repeater (bus keeper)                             |
|       |       |             | gpio1a3_p                                                |
|       |       |             | Driver disabled state control.                           |
| 7:6   | RW    | W 0x2       | 2'b00: Z (normal operation)                              |
| /.0   |       |             | 2'b01: weak 1 (pull-up)                                  |
|       |       |             | 2'b10: weak 0 (pull-down)                                |
|       |       |             | 2'b11: repeater (bus keeper)                             |

| Bit | Attr | Reset Value | Description                                                                                                                                                        |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:4 | RW   | 0x2         | gpio1a2_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |
| 3:2 | RW   | 0x2         | <pre>gpio1a1_p Driver disabled state control. 2'b00: Z (normal operation) 2'b01: weak 1 (pull-up) 2'b10: weak 0 (pull-down) 2'b11: repeater (bus keeper)</pre>     |
| 1:0 | RW   | 0x2         | gpio1a0_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |

**<u>GRF GPIO1B P</u>** Address: Operational Base + offset (0x00b4)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:14 | RW   | 0x2                | <pre>gpio1b7_p Driver disabled state control. 2'b00: Z (normal operation) 2'b01: weak 1 (pull-up) 2'b10: weak 0 (pull-down) 2'b11: repeater (bus keeper)</pre>                                                                                                                                                                                                                                             |
| 13:12 | RW   | 0x2                | gpio1b6_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper)                                                                                                                                                                                                                                         |

| Bit   | Attr | <b>Reset Value</b> | Description                    |
|-------|------|--------------------|--------------------------------|
|       |      |                    | gpio1b5_p                      |
|       |      |                    | Driver disabled state control. |
| 11:10 |      | 0.42               | 2'b00: Z (normal operation)    |
| 11:10 | RVV  | 0x2                | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio1b4_p                      |
|       |      |                    | Driver disabled state control. |
| 9:8   | RW   | 0x2                | 2'b00: Z (normal operation)    |
| 9.0   | ĸw   | UXZ                | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio1b3_p                      |
|       |      |                    | Driver disabled state control. |
| 7:6   | RW   | 0x2                | 2'b00: Z (normal operation)    |
| /:0   | ĸw   | 0x2                | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio1b2_p                      |
|       |      |                    | Driver disabled state control. |
| 5:4   | RW   | 0.2                | 2'b00: Z (normal operation)    |
| 5.4   |      | W 0x2              | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio1b1_p                      |
|       |      |                    | Driver disabled state control. |
| 3:2   | RW   |                    | 2'b00: Z (normal operation)    |
| 5.2   |      | 0x2                | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |
|       |      |                    | gpio1b0_p                      |
|       |      |                    | Driver disabled state control. |
| 1:0   | D\// | ₹₩ 0×2             | 2'b00: Z (normal operation)    |
| 1.0   | KVV  |                    | 2'b01: weak 1 (pull-up)        |
|       |      |                    | 2'b10: weak 0 (pull-down)      |
|       |      |                    | 2'b11: repeater (bus keeper)   |

**<u>GRF\_GPIO1C\_P</u>** Address: Operational Base + offset (0x00b8)

| Bit   | Attr | <b>Reset Value</b> | Description                                              |
|-------|------|--------------------|----------------------------------------------------------|
|       |      |                    | write_enable                                             |
|       |      |                    | When bit 16=1, bit 0 can be written by software.         |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.     |
|       |      |                    | When bit $17=1$ , bit 1 can be written by software.      |
| 31:16 | wo   | 0×0000             | When bit $17=0$ , bit 1 can not be written by software.  |
|       |      |                    | · · · · · · · · · · · · · · · · · · ·                    |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.     |
|       |      |                    | When bit $31=0$ , bit 15 can not be written by software. |
|       |      |                    | gpio1c7_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 15:14 | RW   | 0x1                | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio1c6_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 13:12 | RW   | V 0x1              | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio1c5_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 11:10 | RW   | 0x2                | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio1c4_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 9:8   | RW   | 0x2                | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio1c3_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 7:6   | RW   | 0x2                | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio1c2_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 5:4   | RW   | 0x2                | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | ב אדדי יבאבמובו (אמא גבבאבו)                             |

| Bit | Attr | <b>Reset Value</b> | Description                                                                          |
|-----|------|--------------------|--------------------------------------------------------------------------------------|
|     |      | 0x2                | gpio1c1_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)           |
| 3:2 | RW   |                    | 2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)                                 |
|     |      |                    | 2'b11: repeater (bus keeper)                                                         |
|     | RW   | V 0x2              | gpio1c0_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)           |
| 1:0 |      |                    | 2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |

# <u>GRF\_GPIO1D\_P</u>

Address: Operational Base + offset (0x00bc)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51:10 | WU   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:4  | RO   | 0x0                | reserved                                              |
|       |      | W Ox1              | gpio1d1_p                                             |
|       |      |                    | Driver disabled state control.                        |
| 3:2   | DW   |                    | 2'b00: Z (normal operation)                           |
| 5.2   | ĸw   |                    | 2'b01: weak 1 (pull-up)                               |
|       |      |                    | 2'b10: weak 0 (pull-down)                             |
|       |      |                    | 2'b11: repeater (bus keeper)                          |
|       |      |                    | gpio1d0_p                                             |
|       |      |                    | Driver disabled state control.                        |
| 1:0   | RW   | 0x1                | 2'b00: Z (normal operation)                           |
| 1.0   | 1    |                    | 2'b01: weak 1 (pull-up)                               |
|       |      |                    | 2'b10: weak 0 (pull-down)                             |
|       |      |                    | 2'b11: repeater (bus keeper)                          |

**<u>GRF GPIO2A P</u>** Address: Operational Base + offset (0x00c0)

| Bit   | Attr | <b>Reset Value</b> | Description                                              |
|-------|------|--------------------|----------------------------------------------------------|
|       |      |                    | write_enable                                             |
|       |      |                    | When bit 16=1, bit 0 can be written by software.         |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.     |
|       |      |                    | When bit 17=1, bit 1 can be written by software.         |
| 31:16 | wo   | 0×0000             | When bit 17=0, bit 1 can not be written by software.     |
|       |      |                    | · · · · · · · · · · · · · · · · · · ·                    |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.     |
|       |      |                    | When bit $31=0$ , bit 15 can not be written by software. |
|       |      |                    | gpio2a7_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 15:14 | RW   | 0x2                | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio2a6_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 13:12 | RW   | / 0x2              | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio2a5_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 11:10 | RW   | 0x2                | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio2a4_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 9:8   | RW   | 0x2                | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio2a3_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 7:6   | RW   | 0x1                | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | gpio2a2_p                                                |
|       |      |                    | Driver disabled state control.                           |
|       |      |                    | 2'b00: Z (normal operation)                              |
| 5:4   | RW   | 0x1                | 2'b01: weak 1 (pull-up)                                  |
|       |      |                    | 2'b10: weak 0 (pull-down)                                |
|       |      |                    | 2'b11: repeater (bus keeper)                             |
|       |      |                    | ב הדדי ובהבמובו (התא גבבהבו)                             |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      |                    | gpio2a1_p                      |
|     |      |                    | Driver disabled state control. |
| 2.2 |      | 0.1                | 2'b00: Z (normal operation)    |
| 3:2 | RW   | 0×1                | 2'b01: weak 1 (pull-up)        |
|     |      |                    | 2'b10: weak 0 (pull-down)      |
|     |      |                    | 2'b11: repeater (bus keeper)   |
|     |      | W 0x1              | gpio2a0_p                      |
|     |      |                    | Driver disabled state control. |
| 1.0 |      |                    | 2'b00: Z (normal operation)    |
| 1:0 | RVV  |                    | 2'b01: weak 1 (pull-up)        |
|     |      |                    | 2'b10: weak 0 (pull-down)      |
|     |      |                    | 2'b11: repeater (bus keeper)   |

**<u>GRF GPIO2B P</u>** Address: Operational Base + offset (0x00c4)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                   |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 |      | 0×0000             | write_enable<br>When bit 16=1, bit 0 can be written by software.<br>When bit 16=0, bit 0 can not be written by software.<br>When bit 17=1, bit 1 can be written by software.<br>When bit 17=0, bit 1 can not be written by software.<br><br>When bit 31=1, bit 15 can be written by software. |
| 15:14 | RW   | 0x2                | When bit 31=0, bit 15 can not be written by software.<br>gpio2b7_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper)                                                                   |
| 13:12 | RW   | 0x2                | <pre>gpio2b6_p Driver disabled state control. 2'b00: Z (normal operation) 2'b01: weak 1 (pull-up) 2'b10: weak 0 (pull-down) 2'b11: repeater (bus keeper)</pre>                                                                                                                                |
| 11:10 | RW   | 0x2                | gpio2b5_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper)                                                                                                                            |

| Bit | Attr | Reset Value | Description                    |
|-----|------|-------------|--------------------------------|
|     |      |             | gpio2b4_p                      |
|     |      |             | Driver disabled state control. |
| 0.0 |      | 02          | 2'b00: Z (normal operation)    |
| 9:8 | RW   | 0x2         | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio2b3_p                      |
|     |      |             | Driver disabled state control. |
| 7:6 | RW   | 0x2         | 2'b00: Z (normal operation)    |
| /.0 | r vv | 0.72        | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio2b2_p                      |
|     |      |             | Driver disabled state control. |
| 5:4 | RW   | 0x2         | 2'b00: Z (normal operation)    |
| 5.1 |      |             | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      | 0x2         | gpio2b1_p                      |
|     |      |             | Driver disabled state control. |
| 3:2 | RW   |             | 2'b00: Z (normal operation)    |
| 0.2 |      |             | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio2b0_p                      |
|     |      | W 0x2       | Driver disabled state control. |
| 1:0 | RW   |             | 2'b00: Z (normal operation)    |
|     |      |             | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |

**<u>GRF\_GPIO2C\_P</u>** Address: Operational Base + offset (0x00c8)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      |                    | gpio2c0_p                      |
|     |      |                    | Driver disabled state control. |
| 1:0 | RW   | 0x2                | 2'b00: Z (normal operation)    |
| 1:0 |      |                    | 2'b01: weak 1 (pull-up)        |
|     |      |                    | 2'b10: weak 0 (pull-down)      |
|     |      |                    | 2'b11: repeater (bus keeper)   |

# GRF\_GPIO3A\_P

Address: Operational Base + offset (0x00d0)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | WU   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
|       |      |                    | gpio3a7_p                                             |
|       |      |                    | Driver disabled state control.                        |
| 15:14 | RW   | 0x1                | 2'b00: Z (normal operation)                           |
| 13.14 | 1    | 0/1                | 2'b01: weak 1 (pull-up)                               |
|       |      |                    | 2'b10: weak 0 (pull-down)                             |
|       |      |                    | 2'b11: repeater (bus keeper)                          |
|       |      |                    | gpio3a6_p                                             |
|       |      |                    | Driver disabled state control.                        |
| 13:12 | RW   | 0x1                | 2'b00: Z (normal operation)                           |
| 10112 |      |                    | 2'b01: weak 1 (pull-up)                               |
|       |      |                    | 2'b10: weak 0 (pull-down)                             |
|       |      |                    | 2'b11: repeater (bus keeper)                          |
|       |      |                    | gpio3a5_p                                             |
|       | RW   |                    | Driver disabled state control.                        |
| 11:10 |      | 0x1                | 2'b00: Z (normal operation)                           |
|       |      |                    | 2'b01: weak 1 (pull-up)                               |
|       |      |                    | 2'b10: weak 0 (pull-down)                             |
|       |      |                    | 2'b11: repeater (bus keeper)                          |
|       |      |                    | gpio3a4_p                                             |
|       | RW   | W 0×1              | Driver disabled state control.                        |
| 9:8   |      |                    | 2'b00: Z (normal operation)                           |
|       |      |                    | 2'b01: weak 1 (pull-up)                               |
|       |      |                    | 2'b10: weak 0 (pull-down)                             |
|       |      |                    | 2'b11: repeater (bus keeper)                          |

| Bit | Attr | Reset Value | Description                    |
|-----|------|-------------|--------------------------------|
|     |      |             | gpio3a3_p                      |
|     |      |             | Driver disabled state control. |
| 7.0 |      |             | 2'b00: Z (normal operation)    |
| 7:6 | RW   | 0x1         | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio3a2_p                      |
|     |      |             | Driver disabled state control. |
| 5:4 | RW   | 0×1         | 2'b00: Z (normal operation)    |
| 5.4 |      | UX1         | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio3a1_p                      |
|     |      |             | Driver disabled state control. |
| 3:2 | RW   | / 0x1       | 2'b00: Z (normal operation)    |
| 5.2 |      |             | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio3a0_p                      |
|     |      | W 0x1       | Driver disabled state control. |
| 1:0 | RW   |             | 2'b00: Z (normal operation)    |
|     |      |             | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |

**<u>GRF\_GPIO3B\_P</u>** Address: Operational Base + offset (0x00d4)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                        |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | wo   | 0×0000             | write_enable<br>When bit 16=1, bit 0 can be written by software.<br>When bit 16=0, bit 0 can not be written by software.                                           |
| 31:16 |      |                    | When bit 17=1, bit 1 can be written by software.                                                                                                                   |
| 51110 |      |                    | When bit 17=0, bit 1 can not be written by software.<br><br>When bit 31=1, bit 15 can be written by software.                                                      |
|       |      |                    | When bit 31=0, bit 15 can not be written by software.                                                                                                              |
| 15:12 | RO   | 0x0                | reserved                                                                                                                                                           |
| 11:10 | RW   | 0x1                | gpio3b5_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |

| Bit | Attr | Reset Value | Description                    |
|-----|------|-------------|--------------------------------|
|     |      |             | gpio3b4_p                      |
|     |      |             | Driver disabled state control. |
| 9:8 | RW   | 0x1         | 2'b00: Z (normal operation)    |
| 9.0 | K VV | UXI         | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio3b3_p                      |
|     |      |             | Driver disabled state control. |
| 7:6 | RW   | 0x2         | 2'b00: Z (normal operation)    |
| /.0 |      | 0.72        | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio3b2_p                      |
|     |      |             | Driver disabled state control. |
| 5:4 | RW   | 0x1         | 2'b00: Z (normal operation)    |
| 5.4 | ĸvv  | UX1         | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      | 0x2         | gpio3b1_p                      |
|     |      |             | Driver disabled state control. |
| 3:2 | RW   |             | 2'b00: Z (normal operation)    |
| 5.2 |      |             | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio3b0_p                      |
|     |      | W 0x1       | Driver disabled state control. |
| 1:0 | RW   |             | 2'b00: Z (normal operation)    |
|     |      |             | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |

**<u>GRF\_GPIO4A\_P</u>** Address: Operational Base + offset (0x00e0)

| Bit A   | \ttr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 V | vo   | 0x0000      | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |

| Bit   | Attr | Reset Value | Description                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14 | RW   | 0x1         | gpio4a7_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |
| 13:12 | RW   | 0x1         | <pre>gpio4a6_p Driver disabled state control. 2'b00: Z (normal operation) 2'b01: weak 1 (pull-up) 2'b10: weak 0 (pull-down) 2'b11: repeater (bus keeper)</pre>     |
| 11:10 | RW   | 0x2         | gpio4a5_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |
| 9:8   | RW   | 0×1         | gpio4a4_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |
| 7:6   | RW   | 0x1         | gpio4a3_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |
| 5:4   | RW   | 0x1         | gpio4a2_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |
| 3:2   | RW   | 0x1         | gpio4a1_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |

| Bit | Attr | <b>Reset Value</b> | Description                    |
|-----|------|--------------------|--------------------------------|
|     |      | / 0x1              | gpio4a0_p                      |
|     | RW   |                    | Driver disabled state control. |
| 1:0 |      |                    | 2'b00: Z (normal operation)    |
| 1:0 |      |                    | 2'b01: weak 1 (pull-up)        |
|     |      |                    | 2'b10: weak 0 (pull-down)      |
|     |      |                    | 2'b11: repeater (bus keeper)   |

### GRF GPIO4B P

Address: Operational Base + offset (0x00e4)

| Bit   |       | <b>Reset Value</b> | Description                                           |
|-------|-------|--------------------|-------------------------------------------------------|
|       |       |                    | write_enable                                          |
|       |       |                    | When bit 16=1, bit 0 can be written by software.      |
|       |       |                    | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 | wo    | 0000               | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | WÜ    | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |       |                    |                                                       |
|       |       |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |       |                    | When bit 31=0, bit 15 can not be written by software. |
|       |       |                    | gpio4b7_p                                             |
|       |       |                    | Driver disabled state control.                        |
| 15:14 | D\\/  | 0x2                | 2'b00: Z (normal operation)                           |
| 13.14 |       | 0.72               | 2'b01: weak 1 (pull-up)                               |
|       |       |                    | 2'b10: weak 0 (pull-down)                             |
|       |       |                    | 2'b11: repeater (bus keeper)                          |
|       |       |                    | gpio4b6_p                                             |
|       |       |                    | Driver disabled state control.                        |
| 13:12 | RW    | / 0x2              | 2'b00: Z (normal operation)                           |
| 13.12 |       |                    | 2'b01: weak 1 (pull-up)                               |
|       |       |                    | 2'b10: weak 0 (pull-down)                             |
|       |       |                    | 2'b11: repeater (bus keeper)                          |
|       |       |                    | gpio4b5_p                                             |
|       |       |                    | Driver disabled state control.                        |
| 11:10 | RW    | 0x2                | 2'b00: Z (normal operation)                           |
| 11.10 | 1     | 0.72               | 2'b01: weak 1 (pull-up)                               |
|       |       |                    | 2'b10: weak 0 (pull-down)                             |
|       |       |                    | 2'b11: repeater (bus keeper)                          |
|       |       |                    | gpio4b4_p                                             |
|       |       |                    | Driver disabled state control.                        |
| 9:8   | RW    | 2W 0x2             | 2'b00: Z (normal operation)                           |
| 5.0   | 12.00 |                    | 2'b01: weak 1 (pull-up)                               |
|       |       |                    | 2'b10: weak 0 (pull-down)                             |
|       |       |                    | 2'b11: repeater (bus keeper)                          |

| Bit | Attr | Reset Value | Description                    |
|-----|------|-------------|--------------------------------|
|     |      |             | gpio4b3_p                      |
|     |      |             | Driver disabled state control. |
| 7.0 |      | 02          | 2'b00: Z (normal operation)    |
| 7:6 | RW   | 0x2         | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio4b2_p                      |
|     |      |             | Driver disabled state control. |
| 5:4 | RW   | 0x2         | 2'b00: Z (normal operation)    |
| 5.4 | r vv | 0xz         | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio4b1_p                      |
|     |      |             | Driver disabled state control. |
| 3:2 | RW   | W 0×1       | 2'b00: Z (normal operation)    |
| 5.2 |      |             | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |
|     |      |             | gpio4b0_p                      |
|     |      |             | Driver disabled state control. |
| 1:0 | DW/  | RW 0x1      | 2'b00: Z (normal operation)    |
| 1.0 |      |             | 2'b01: weak 1 (pull-up)        |
|     |      |             | 2'b10: weak 0 (pull-down)      |
|     |      |             | 2'b11: repeater (bus keeper)   |

**<u>GRF\_GPIO4C\_P</u>** Address: Operational Base + offset (0x00e8)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 | wo   | 0,4000             | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | wo   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:2  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio4c0_p                                             |
|       |      |                    | Driver disabled state control.                        |
| 1.0   |      | 0.42               | 2'b00: Z (normal operation)                           |
| 1:0   | RW   | -                  | 2'b01: weak 1 (pull-up)                               |
|       |      |                    | 2'b10: weak 0 (pull-down)                             |
|       |      |                    | 2'b11: repeater (bus keeper)                          |

### <u>GRF\_GPIO4D\_P</u>

Address: Operational Base + offset (0x00ec)

| Bit   |    | Reset Value | + offset (0x00ec) Description                           |
|-------|----|-------------|---------------------------------------------------------|
|       |    |             | write_enable                                            |
|       |    |             | When bit $16=1$ , bit 0 can be written by software.     |
|       |    |             | When bit 16=0, bit 0 can not be written by software.    |
| 24.46 |    |             | When bit $17=1$ , bit 1 can be written by software.     |
| 31:16 | WO | 0×0000      | When bit $17=0$ , bit 1 can not be written by software. |
|       |    |             | · · · · ·                                               |
|       |    |             | When bit $31=1$ , bit 15 can be written by software.    |
|       |    |             | When bit 31=0, bit 15 can not be written by software.   |
| 15:14 | RO | 0x0         | reserved                                                |
|       |    |             | gpio4d6_p                                               |
|       |    |             | Driver disabled state control.                          |
| 10.10 |    |             | 2'b00: Z (normal operation)                             |
| 13:12 | RW | 0x2         | 2'b01: weak 1 (pull-up)                                 |
|       |    |             | 2'b10: weak 0 (pull-down)                               |
|       |    |             | 2'b11: repeater (bus keeper)                            |
|       |    |             | gpio4d5_p                                               |
|       |    |             | Driver disabled state control.                          |
| 11.10 |    | 0x2         | 2'b00: Z (normal operation)                             |
| 11:10 | RW |             | 2'b01: weak 1 (pull-up)                                 |
|       |    |             | 2'b10: weak 0 (pull-down)                               |
|       |    |             | 2'b11: repeater (bus keeper)                            |
|       |    |             | gpio4d4_p                                               |
|       | RW |             | Driver disabled state control.                          |
| 9:8   |    | 0.v1        | 2'b00: Z (normal operation)                             |
| 9.0   |    | N 0x1       | 2'b01: weak 1 (pull-up)                                 |
|       |    |             | 2'b10: weak 0 (pull-down)                               |
|       |    |             | 2'b11: repeater (bus keeper)                            |
|       |    |             | gpio4d3_p                                               |
|       |    |             | Driver disabled state control.                          |
| 7:6   | RW | 0x1         | 2'b00: Z (normal operation)                             |
| 7.0   |    |             | 2'b01: weak 1 (pull-up)                                 |
|       |    |             | 2'b10: weak 0 (pull-down)                               |
|       |    |             | 2'b11: repeater (bus keeper)                            |
|       |    |             | gpio4d2_p                                               |
|       |    |             | Driver disabled state control.                          |
| 5:4   | RW | 0x1         | 2'b00: Z (normal operation)                             |
|       |    | W UXI       | 2'b01: weak 1 (pull-up)                                 |
|       |    |             | 2'b10: weak 0 (pull-down)                               |
|       |    |             | 2'b11: repeater (bus keeper)                            |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                        |
|-----|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2 | RW   | 0×1                | gpio4d1_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)                                                                 |
| 1:0 | RW   | 0x1                | 2'b11: repeater (bus keeper)<br>gpio4d0_p<br>Driver disabled state control.<br>2'b00: Z (normal operation)<br>2'b01: weak 1 (pull-up)<br>2'b10: weak 0 (pull-down)<br>2'b11: repeater (bus keeper) |

**<u>GRF\_GPIO0A\_E</u>** Address: Operational Base + offset (0x0100)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | WU   | 00000              | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
|       |      |                    | gpio0a7_e                                             |
|       |      |                    | 2'b00: 2mA                                            |
| 15:14 | RW   | 0x0                | 2'b01: 4mA                                            |
|       |      |                    | 2'b10: 8mA                                            |
|       |      |                    | 2'b11: 12mA                                           |
|       |      |                    | gpio0a6_e                                             |
|       |      |                    | 2'b00: 2mA                                            |
| 13:12 | RW   | 0x0                | 2'b01: 4mA                                            |
|       |      |                    | 2'b10: 8mA                                            |
|       |      |                    | 2'b11: 12mA                                           |
|       |      |                    | gpio0a5_e                                             |
|       |      |                    | 2'b00: 2mA                                            |
| 11:10 | RW   | 0x0                | 2'b01: 4mA                                            |
|       |      |                    | 2'b10: 8mA                                            |
|       |      |                    | 2'b11: 12mA                                           |
|       |      |                    | gpio0a4_e                                             |
|       |      |                    | 2'b00: 2mA                                            |
| 9:8   | RW   | 0x0                | 2'b01: 4mA                                            |
|       |      |                    | 2'b10: 8mA                                            |
|       |      |                    | 2'b11: 12mA                                           |

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
|     |      |             | gpio0a3_e   |
|     |      |             | 2'b00: 2mA  |
| 7:6 | RW   | 0x0         | 2'b01: 4mA  |
|     |      |             | 2'b10: 8mA  |
|     |      |             | 2'b11: 12mA |
|     |      |             | gpio0a2_e   |
|     |      |             | 2'b00: 2mA  |
| 5:4 | RW   | 0x0         | 2'b01: 4mA  |
|     |      |             | 2'b10: 8mA  |
|     |      |             | 2'b11: 12mA |
|     |      |             | gpio0a1_e   |
|     |      |             | 2'b00: 2mA  |
| 3:2 | RW   | 0x0         | 2'b01: 4mA  |
|     |      |             | 2'b10: 8mA  |
|     |      |             | 2'b11: 12mA |
|     |      |             | gpio0a0_e   |
|     |      |             | 2'b00: 2mA  |
| 1:0 | RW   | 0x0         | 2'b01: 4mA  |
|     |      |             | 2'b10: 8mA  |
|     |      |             | 2'b11: 12mA |

## **<u>GRF\_GPIO0B\_E</u>** Address: Operational Base + offset (0x0104)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | WO   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | WU   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
|       |      | W 0x0              | gpio0b7_e                                             |
|       | RW   |                    | 2'b00: 2mA                                            |
| 15:14 |      |                    | 2'b01: 4mA                                            |
|       |      |                    | 2'b10: 8mA                                            |
|       |      |                    | 2'b11: 12mA                                           |
|       |      |                    | gpio0b6_e                                             |
|       |      |                    | 2'b00: 2mA                                            |
| 13:12 | RW   | 0x0                | 2'b01: 4mA                                            |
|       |      |                    | 2'b10: 8mA                                            |
|       |      |                    | 2'b11: 12mA                                           |

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
|       |      |             | gpio0b5_e   |
|       |      |             | 2'b00: 2mA  |
| 11:10 | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |
|       |      |             | gpio0b4_e   |
|       |      |             | 2'b00: 2mA  |
| 9:8   | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |
|       |      |             | gpio0b3_e   |
|       |      |             | 2'b00: 2mA  |
| 7:6   | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |
|       |      |             | gpio0b2_e   |
|       |      |             | 2'b00: 2mA  |
| 5:4   | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |
|       |      |             | gpio0b1_e   |
|       |      |             | 2'b00: 2mA  |
| 3:2   | RW   | 0×0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |
|       |      |             | gpio0b0_e   |
| 1.0   |      |             | 2'b00: 2mA  |
| 1:0   | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |

**<u>GRF GPIOOC E</u>** Address: Operational Base + offset (0x0108)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:12 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
|       |      |             | gpio0c5_e   |
|       |      |             | 2'b00: 2mA  |
| 11:10 | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |
|       |      |             | gpio0c4_e   |
|       |      |             | 2'b00: 2mA  |
| 9:8   | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |
|       |      |             | gpio0c3_e   |
|       |      |             | 2'b00: 2mA  |
| 7:6   | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |
|       |      |             | gpio0c2_e   |
|       |      |             | 2'b00: 2mA  |
| 5:4   | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |
|       |      |             | gpio0c1_e   |
|       |      |             | 2'b00: 2mA  |
| 3:2   | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |
|       |      |             | gpio0c0_e   |
|       |      |             | 2'b00: 2mA  |
| 1:0   | RW   | 0x0         | 2'b01: 4mA  |
|       |      |             | 2'b10: 8mA  |
|       |      |             | 2'b11: 12mA |

**<u>GRF GPIO1A E</u>** Address: Operational Base + offset (0x0110)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |

| Bit   | Attr | <b>Reset Value</b> | Description |
|-------|------|--------------------|-------------|
|       |      |                    | gpio1a7_e   |
|       |      |                    | 2'b00: 2mA  |
| 15:14 | RW   | 0x0                | 2'b01: 4mA  |
|       |      |                    | 2'b10: 8mA  |
|       |      |                    | 2'b11: 12mA |
|       |      |                    | gpio1a6_e   |
|       |      |                    | 2'b00: 2mA  |
| 13:12 | RW   | 0x0                | 2'b01: 4mA  |
|       |      |                    | 2'b10: 8mA  |
|       |      |                    | 2'b11: 12mA |
|       |      |                    | gpio1a5_e   |
|       |      |                    | 2'b00: 2mA  |
| 11:10 | RW   | 0x0                | 2'b01: 4mA  |
|       |      |                    | 2'b10: 8mA  |
|       |      |                    | 2'b11: 12mA |
|       |      |                    | gpio1a4_e   |
|       |      |                    | 2'b00: 2mA  |
| 9:8   | RW   | 0x0                | 2'b01: 4mA  |
|       |      |                    | 2'b10: 8mA  |
|       |      |                    | 2'b11: 12mA |
|       |      |                    | gpio1a3_e   |
|       |      |                    | 2'b00: 2mA  |
| 7:6   | RW   | 0x0                | 2'b01: 4mA  |
|       |      |                    | 2'b10: 8mA  |
|       |      |                    | 2'b11: 12mA |
|       |      |                    | gpio1a2_e   |
|       |      |                    | 2'b00: 2mA  |
| 5:4   | RW   | 0x0                | 2'b01: 4mA  |
|       |      |                    | 2'b10: 8mA  |
|       |      |                    | 2'b11: 12mA |
|       |      |                    | gpio1a1_e   |
|       |      |                    | 2'b00: 2mA  |
| 3:2   | RW   | 0x0                | 2'b01: 4mA  |
|       |      |                    | 2'b10: 8mA  |
|       |      |                    | 2'b11: 12mA |
|       |      |                    | gpio1a0_e   |
|       |      |                    | 2'b00: 2mA  |
| 1:0   | RW   | 0x0                | 2'b01: 4mA  |
|       |      |                    | 2'b10: 8mA  |
|       |      |                    | 2'b11: 12mA |

**<u>GRF GPIO1B E</u>** Address: Operational Base + offset (0x0114)

| Bit   | Attr | Reset Value | Description                                           |
|-------|------|-------------|-------------------------------------------------------|
|       |      |             | write_enable                                          |
|       |      |             | When bit 16=1, bit 0 can be written by software.      |
|       |      |             | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 | wo   | 0000        | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | wo   | 0x0000      | When bit 17=0, bit 1 can not be written by software.  |
|       |      |             |                                                       |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |             | When bit 31=0, bit 15 can not be written by software. |
|       |      |             | gpio1b7_e                                             |
|       |      |             | 2'b00: 2mA                                            |
| 15:14 | RW   | 0x0         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |
|       |      |             | gpio1b6_e                                             |
|       |      |             | 2'b00: 2mA                                            |
| 13:12 | RW   | 0x0         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |
|       |      |             | gpio1b5_e                                             |
|       |      |             | 2'b00: 2mA                                            |
| 11:10 | RW   | 0x0         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |
|       |      |             | gpio1b4_e                                             |
|       |      |             | 2'b00: 2mA                                            |
| 9:8   | RW   | 0x0         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |
|       |      |             | gpio1b3_e                                             |
|       |      |             | 2'b00: 2mA                                            |
| 7:6   | RW   | 0x0         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |
|       |      |             | gpio1b2_e                                             |
|       |      |             | 2'b00: 2mA                                            |
| 5:4   | RW   | 0x0         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |
|       |      |             | gpio1b1_e                                             |
|       | D    |             | 2'b00: 2mA                                            |
| 3:2   | RW   | 0x0         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|     |      |                    | gpio1b0_e   |
|     |      |                    | 2'b00: 2mA  |
| 1:0 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |

#### <u>GRF\_GPIO1C\_E</u>

Address: Operational Base + offset (0x0118)

| Bit   |              | Reset Value | Description                                           |
|-------|--------------|-------------|-------------------------------------------------------|
|       |              |             | write_enable                                          |
|       |              |             | When bit 16=1, bit 0 can be written by software.      |
|       |              |             | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo           | 0x0000      | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | **0          | 0,0000      | When bit 17=0, bit 1 can not be written by software.  |
|       |              |             |                                                       |
|       |              |             | When bit $31=1$ , bit 15 can be written by software.  |
|       |              |             | When bit 31=0, bit 15 can not be written by software. |
|       |              |             | gpio1c7_e                                             |
|       |              |             | 2'b00: 2mA                                            |
| 15:14 | RW           | 0x0         | 2'b01: 4mA                                            |
|       |              |             | 2'b10: 8mA                                            |
|       |              |             | 2'b11: 12mA                                           |
|       |              |             | gpio1c6_e                                             |
|       |              |             | 2'b00: 2mA                                            |
| 13:12 | RW           | 0x0         | 2'b01: 4mA                                            |
|       |              |             | 2'b10: 8mA                                            |
|       |              |             | 2'b11: 12mA                                           |
|       |              |             | gpio1c5_e                                             |
|       |              |             | 2'b00: 2mA                                            |
| 11:10 | RW           | 0x0         | 2'b01: 4mA                                            |
|       |              |             | 2'b10: 8mA                                            |
|       |              |             | 2'b11: 12mA                                           |
|       |              |             | gpio1c4_e                                             |
| 0.0   | <b>D</b> 14/ |             | 2'b00: 2mA                                            |
| 9:8   | RW           | 0x0         | 2'b01: 4mA                                            |
|       |              |             | 2'b10: 8mA                                            |
|       |              |             | 2'b11: 12mA                                           |
|       |              |             | gpio1c3_e                                             |
| 7.6   |              |             | 2'b00: 2mA                                            |
| 7:6   | RW           | 0x0         | 2'b01: 4mA                                            |
|       |              |             | 2'b10: 8mA                                            |
|       |              |             | 2'b11: 12mA                                           |

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|     |      |                    | gpio1c2_e   |
|     |      |                    | 2'b00: 2mA  |
| 5:4 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |
|     |      |                    | gpio1c1_e   |
|     |      |                    | 2'b00: 2mA  |
| 3:2 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |
|     |      |                    | gpio1c0_e   |
|     |      |                    | 2'b00: 2mA  |
| 1:0 | RW   | / 0x0              | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |

#### **<u>GRF\_GPIO1D\_E</u>**

### Address: Operational Base + offset (0x011c)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000      | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:4  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3:2   | RW   | 0×0         | gpio1d1_e<br>2'b00: 2mA<br>2'b01: 4mA<br>2'b10: 8mA<br>2'b11: 12mA                                                                                                                                                                                                                                                                                                                                         |
| 1:0   | RW   | 0×0         | gpio1d0_e<br>2'b00: 2mA<br>2'b01: 4mA<br>2'b10: 8mA<br>2'b11: 12mA                                                                                                                                                                                                                                                                                                                                         |

**<u>GRF GPIO2A E</u>** Address: Operational Base + offset (0x0120)

| Bit   | Attr | <b>Reset Value</b> | Description                                              |
|-------|------|--------------------|----------------------------------------------------------|
|       |      |                    | write_enable                                             |
|       |      |                    | When bit $16=1$ , bit 0 can be written by software.      |
|       |      |                    | When bit $16=0$ , bit 0 can not be written by software.  |
|       |      |                    | When bit $17=1$ , bit 1 can be written by software.      |
| 31:16 | WO   | 0×0000             | When bit $17=0$ , bit 1 can not be written by software.  |
|       |      |                    |                                                          |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.     |
|       |      |                    | When bit $31=0$ , bit 15 can not be written by software. |
|       |      |                    | gpio2a7_e                                                |
|       |      |                    | 2'b00: 2mA                                               |
| 15:14 | RW   | 0x0                | 2'b01: 4mA                                               |
|       |      |                    | 2'b10: 8mA                                               |
|       |      |                    | 2'b11: 12mA                                              |
|       |      |                    | gpio2a6_e                                                |
|       |      |                    | 2'b00: 2mA                                               |
| 13:12 | RW   | 0x0                | 2'b01: 4mA                                               |
|       |      |                    | 2'b10: 8mA                                               |
|       |      |                    | 2'b11: 12mA                                              |
|       |      |                    | gpio2a5_e                                                |
|       |      |                    | 2'b00: 2mA                                               |
| 11:10 | RW   | 0x0                | 2'b01: 4mA                                               |
|       |      |                    | 2'b10: 8mA                                               |
|       |      |                    | 2'b11: 12mA                                              |
|       |      |                    | gpio2a4_e                                                |
|       |      |                    | 2'b00: 2mA                                               |
| 9:8   | RW   | 0x0                | 2'b01: 4mA                                               |
|       |      |                    | 2'b10: 8mA                                               |
|       |      |                    | 2'b11: 12mA                                              |
|       |      |                    | gpio2a3_e                                                |
|       |      |                    | 2'b00: 2mA                                               |
| 7:6   | RW   | 0x0                | 2'b01: 4mA                                               |
|       |      |                    | 2'b10: 8mA                                               |
|       |      |                    | 2'b11: 12mA                                              |
|       |      |                    | gpio2a2_e                                                |
|       |      |                    | 2'b00: 2mA                                               |
| 5:4   | RW   | 0x0                | 2'b01: 4mA                                               |
|       |      |                    | 2'b10: 8mA                                               |
|       |      |                    | 2'b11: 12mA                                              |
|       |      |                    | gpio2a1_e                                                |
|       |      |                    | 2'b00: 2mA                                               |
| 3:2   | RW   | 0×0                | 2'b01: 4mA                                               |
|       |      |                    | 2'b10: 8mA                                               |
|       |      |                    | 2'b11: 12mA                                              |

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|     |      |                    | gpio2a0_e   |
|     |      |                    | 2'b00: 2mA  |
| 1:0 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |

### **GRF\_GPIO2B\_E**

Address: Operational Base + offset (0x0124)

| Bit   |              | <b>Reset Value</b> | Description                                           |
|-------|--------------|--------------------|-------------------------------------------------------|
|       |              |                    | write_enable                                          |
|       |              |                    | When bit 16=1, bit 0 can be written by software.      |
|       |              |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo           | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | **0          | 0,0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |              |                    |                                                       |
|       |              |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |              |                    | When bit 31=0, bit 15 can not be written by software. |
|       |              |                    | gpio2b7_e                                             |
|       |              |                    | 2'b00: 2mA                                            |
| 15:14 | RW           | 0x0                | 2'b01: 4mA                                            |
|       |              |                    | 2'b10: 8mA                                            |
|       |              |                    | 2'b11: 12mA                                           |
|       |              |                    | gpio2b6_e                                             |
|       |              |                    | 2'b00: 2mA                                            |
| 13:12 | RW           | 0x0                | 2'b01: 4mA                                            |
|       |              |                    | 2'b10: 8mA                                            |
|       |              |                    | 2'b11: 12mA                                           |
|       |              |                    | gpio2b5_e                                             |
|       |              |                    | 2'b00: 2mA                                            |
| 11:10 | RW           | 0x0                | 2'b01: 4mA                                            |
|       |              |                    | 2'b10: 8mA                                            |
|       |              |                    | 2'b11: 12mA                                           |
|       |              |                    | gpio2b4_e                                             |
|       | <b>D</b> 14/ |                    | 2'b00: 2mA                                            |
| 9:8   | RW           | 0x0                | 2'b01: 4mA                                            |
|       |              |                    | 2'b10: 8mA                                            |
|       |              |                    | 2'b11: 12mA                                           |
|       |              |                    | gpio2b3_e                                             |
| 7.6   |              |                    | 2'b00: 2mA                                            |
| 7:6   | RW           | 0x0                | 2'b01: 4mA                                            |
|       |              |                    | 2'b10: 8mA                                            |
|       |              |                    | 2'b11: 12mA                                           |

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|     |      |                    | gpio2b2_e   |
|     |      |                    | 2'b00: 2mA  |
| 5:4 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |
|     |      |                    | gpio2b1_e   |
|     |      | 0x0                | 2'b00: 2mA  |
| 3:2 | RW   |                    | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |
|     |      |                    | gpio2b0_e   |
|     |      |                    | 2'b00: 2mA  |
| 1:0 | RW   | V 0x0              | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |

### <u>GRF\_GPIO2C\_E</u>

#### Address: Operational Base + offset (0x0128)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 | wo   | 0.40000            | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | WO   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:2  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio2c0_e                                             |
|       |      |                    | 2'b00: 2mA                                            |
| 1:0   | RW   |                    | 2'b01: 4mA                                            |
|       |      |                    | 2'b10: 8mA                                            |
|       |      |                    | 2'b11: 12mA                                           |

### <u>GRF\_GPIO3A\_E</u>

Address: Operational Base + offset (0x0130)

| Bit   | Attr | Reset Value | Description                                              |
|-------|------|-------------|----------------------------------------------------------|
|       |      |             | write_enable                                             |
|       |      |             | When bit $16=1$ , bit 0 can be written by software.      |
|       |      |             | When bit 16=0, bit 0 can not be written by software.     |
|       |      |             | When bit $17=1$ , bit 1 can be written by software.      |
| 31:16 | wo   | 0×0000      | When bit $17=0$ , bit 1 can not be written by software.  |
|       |      |             | · · · · · · · · · · · · · · · · · · ·                    |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.     |
|       |      |             | When bit $31=0$ , bit 15 can not be written by software. |
|       |      |             | gpio3a7_e                                                |
|       |      |             | 2'b00: 2mA                                               |
| 15:14 | RW   | 0x2         | 2'b01: 4mA                                               |
|       |      |             | 2'b10: 8mA                                               |
|       |      |             | 2'b11: 12mA                                              |
|       |      |             | gpio3a6_e                                                |
|       |      |             | 2'b00: 2mA                                               |
| 13:12 | RW   | 0x2         | 2'b01: 4mA                                               |
|       |      |             | 2'b10: 8mA                                               |
|       |      |             | 2'b11: 12mA                                              |
|       |      |             | gpio3a5_e                                                |
|       |      |             | 2'b00: 2mA                                               |
| 11:10 | RW   | 0x2         | 2'b01: 4mA                                               |
|       |      |             | 2'b10: 8mA                                               |
|       |      |             | 2'b11: 12mA                                              |
|       |      |             | gpio3a4_e                                                |
|       |      |             | 2'b00: 2mA                                               |
| 9:8   | RW   | 0x2         | 2'b01: 4mA                                               |
|       |      |             | 2'b10: 8mA                                               |
|       |      |             | 2'b11: 12mA                                              |
|       |      |             | gpio3a3_e                                                |
|       |      |             | 2'b00: 2mA                                               |
| 7:6   | RW   | 0x2         | 2'b01: 4mA                                               |
|       |      |             | 2'b10: 8mA                                               |
|       |      |             | 2'b11: 12mA                                              |
|       |      |             | gpio3a2_e                                                |
|       |      |             | 2'b00: 2mA                                               |
| 5:4   | RW   | 0x2         | 2'b01: 4mA                                               |
|       |      |             | 2'b10: 8mA                                               |
|       |      |             | 2'b11: 12mA                                              |
|       |      |             | gpio3a1_e                                                |
|       |      |             | 2'b00: 2mA                                               |
| 3:2   | RW   | 0x2         | 2'b01: 4mA                                               |
|       |      |             | 2'b10: 8mA                                               |
|       |      |             | 2'b11: 12mA                                              |

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|     |      |                    | gpio3a0_e   |
|     |      |                    | 2'b00: 2mA  |
| 1:0 | RW   | 0x2                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |

### **GRF\_GPIO3B\_E**

Address: Operational Base + offset (0x0134)

| Bit   | · ·  | Reset Value | Description                                           |
|-------|------|-------------|-------------------------------------------------------|
|       |      |             | write_enable                                          |
|       |      |             | When bit $16=1$ , bit 0 can be written by software.   |
|       |      |             | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000      | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | **0  | 0,0000      | When bit 17=0, bit 1 can not be written by software.  |
|       |      |             |                                                       |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |             | When bit 31=0, bit 15 can not be written by software. |
| 15:12 | RO   | 0x0         | reserved                                              |
|       |      |             | gpio3b5_e                                             |
|       |      |             | 2'b00: 2mA                                            |
| 11:10 | RW   | 0x2         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |
|       |      |             | gpio3b4_e                                             |
|       |      |             | 2'b00: 2mA                                            |
| 9:8   | RW   | 0x2         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |
|       |      |             | gpio3b3_e                                             |
|       |      |             | 2'b00: 2mA                                            |
| 7:6   | RW   | 0x2         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |
|       |      |             | gpio3b2_e                                             |
| - 4   |      |             | 2'b00: 2mA                                            |
| 5:4   | RW   | 0x2         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |
|       |      |             | gpio3b1_e                                             |
| 2.2   | יאים | 0.2         | 2'b00: 2mA                                            |
| 3:2   | RW   | 0x2         | 2'b01: 4mA                                            |
|       |      |             | 2'b10: 8mA                                            |
|       |      |             | 2'b11: 12mA                                           |

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|     |      |                    | gpio3b0_e   |
|     |      |                    | 2'b00: 2mA  |
| 1:0 | RW   | 0x2                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |

### <u>GRF\_GPIO4A\_E</u>

Address: Operational Base + offset (0x0140)

| Bit   |              | <b>Reset Value</b> | Description                                           |
|-------|--------------|--------------------|-------------------------------------------------------|
|       |              |                    | write_enable                                          |
|       |              |                    | When bit 16=1, bit 0 can be written by software.      |
|       |              |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo           | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | **0          | 0,0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |              |                    |                                                       |
|       |              |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |              |                    | When bit 31=0, bit 15 can not be written by software. |
|       |              |                    | gpio4a7_e                                             |
|       |              |                    | 2'b00: 2mA                                            |
| 15:14 | RW           | 0x0                | 2'b01: 4mA                                            |
|       |              |                    | 2'b10: 8mA                                            |
|       |              |                    | 2'b11: 12mA                                           |
|       |              |                    | gpio4a6_e                                             |
|       |              |                    | 2'b00: 2mA                                            |
| 13:12 | RW           | 0x0                | 2'b01: 4mA                                            |
|       |              |                    | 2'b10: 8mA                                            |
|       |              |                    | 2'b11: 12mA                                           |
|       |              |                    | gpio4a5_e                                             |
|       | <b>D</b> 111 |                    | 2'b00: 2mA                                            |
| 11:10 | RW           | 0x0                | 2'b01: 4mA                                            |
|       |              |                    | 2'b10: 8mA                                            |
|       |              |                    | 2'b11: 12mA                                           |
|       |              |                    | gpio4a4_e                                             |
| 0.0   |              | 0.40               | 2'b00: 2mA<br>2'b01: 4mA                              |
| 9:8   | RW           | 0x0                |                                                       |
|       |              |                    | 2'b10: 8mA<br>2'b11: 12mA                             |
|       |              |                    | gpio4a3_e                                             |
|       |              |                    | 2'b00: 2mA                                            |
| 7:6   | RW           | 0x0                | 2'b01: 4mA                                            |
| /.0   |              |                    | 2'b10: 8mA                                            |
|       |              |                    | 2'b11: 12mA                                           |
|       |              |                    |                                                       |

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|     |      |                    | gpio4a2_e   |
|     |      |                    | 2'b00: 2mA  |
| 5:4 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |
|     |      |                    | gpio4a1_e   |
|     |      | W 0x0              | 2'b00: 2mA  |
| 3:2 | RW   |                    | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |
|     |      |                    | gpio4a0_e   |
|     |      |                    | 2'b00: 2mA  |
| 1:0 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |

# **<u>GRF\_GPIO4B\_E</u>** Address: Operational Base + offset (0x0144)

| Bit   |     | <b>Reset Value</b> | Description                                              |
|-------|-----|--------------------|----------------------------------------------------------|
|       |     |                    | write_enable                                             |
|       |     |                    | When bit 16=1, bit 0 can be written by software.         |
|       |     |                    | When bit 16=0, bit 0 can not be written by software.     |
| 31:16 | wo  | 0x0000             | When bit 17=1, bit 1 can be written by software.         |
| 51.10 | **0 | 0,0000             | When bit 17=0, bit 1 can not be written by software.     |
|       |     |                    |                                                          |
|       |     |                    | When bit $31=1$ , bit 15 can be written by software.     |
|       |     |                    | When bit $31=0$ , bit 15 can not be written by software. |
|       |     |                    | gpio4b7_e                                                |
|       |     | / 0×0              | 2'b00: 2mA                                               |
| 15:14 | RW  |                    | 2'b01: 4mA                                               |
|       |     |                    | 2'b10: 8mA                                               |
|       |     |                    | 2'b11: 12mA                                              |
|       |     |                    | gpio4b6_e                                                |
|       |     | N 0×0              | 2'b00: 2mA                                               |
| 13:12 | RW  |                    | 2'b01: 4mA                                               |
|       |     |                    | 2'b10: 8mA                                               |
|       |     |                    | 2'b11: 12mA                                              |
|       |     |                    | gpio4b5_e                                                |
|       |     |                    | 2'b00: 2mA                                               |
| 11:10 | RW  | 0x0                | 2'b01: 4mA                                               |
|       |     |                    | 2'b10: 8mA                                               |
|       |     |                    | 2'b11: 12mA                                              |

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|     |      |                    | gpio4b4_e   |
|     |      |                    | 2'b00: 2mA  |
| 9:8 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |
|     |      |                    | gpio4b3_e   |
|     |      |                    | 2'b00: 2mA  |
| 7:6 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |
|     |      |                    | gpio4b2_e   |
|     |      |                    | 2'b00: 2mA  |
| 5:4 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |
|     |      |                    | gpio4b1_e   |
|     |      |                    | 2'b00: 2mA  |
| 3:2 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |
|     |      |                    | gpio4b0_e   |
|     |      |                    | 2'b00: 2mA  |
| 1:0 | RW   | 0x0                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |

### <u>GRF\_GPIO4C\_E</u>

Address: Operational Base + offset (0x0148)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1:0   | RW   | 0×0                | gpio4c0_e<br>2'b00: 2mA<br>2'b01: 4mA<br>2'b10: 8mA<br>2'b11: 12mA                                                                                                                                                                                                                                                                                                                                         |

**<u>GRF GPIO4D E</u>** Address: Operational Base + offset (0x014c)

| Bit   |    | <b>Reset Value</b> | + offset (0x014c) Description                           |
|-------|----|--------------------|---------------------------------------------------------|
|       |    |                    | write_enable                                            |
|       |    |                    | When bit $16=1$ , bit 0 can be written by software.     |
|       |    |                    | When bit $16=0$ , bit 0 can not be written by software. |
| 21.16 |    |                    | When bit $17=1$ , bit 1 can be written by software.     |
| 31:16 | wo | 0×0000             | When bit $17=0$ , bit 1 can not be written by software. |
|       |    |                    | · · · · · ·                                             |
|       |    |                    | When bit $31=1$ , bit 15 can be written by software.    |
|       |    |                    | When bit 31=0, bit 15 can not be written by software.   |
| 15:14 | RO | 0x0                | reserved                                                |
|       |    |                    | gpio4d6_e                                               |
|       |    |                    | 2'b00: 2mA                                              |
| 13:12 | RW | 0x2                | 2'b01: 4mA                                              |
|       |    |                    | 2'b10: 8mA                                              |
|       |    |                    | 2'b11: 12mA                                             |
|       |    |                    | gpio4d5_e                                               |
|       |    |                    | 2'b00: 2mA                                              |
| 11:10 | RW | 0x2                | 2'b01: 4mA                                              |
|       |    |                    | 2'b10: 8mA                                              |
|       |    |                    | 2'b11: 12mA                                             |
|       |    |                    | gpio4d4_e                                               |
|       |    |                    | 2'b00: 2mA                                              |
| 9:8   | RW | 0x2                | 2'b01: 4mA                                              |
|       |    |                    | 2'b10: 8mA                                              |
|       |    |                    | 2'b11: 12mA                                             |
|       |    |                    | gpio4d3_e                                               |
|       |    |                    | 2'b00: 2mA                                              |
| 7:6   | RW | 0x2                | 2'b01: 4mA                                              |
|       |    |                    | 2'b10: 8mA                                              |
|       |    |                    | 2'b11: 12mA                                             |
|       |    |                    | gpio4d2_e                                               |
|       |    |                    | 2'b00: 2mA                                              |
| 5:4   | RW | 0x2                | 2'b01: 4mA                                              |
|       |    |                    | 2'b10: 8mA                                              |
|       |    |                    | 2'b11: 12mA                                             |
|       |    |                    | gpio4d1_e                                               |
|       |    |                    | 2'b00: 2mA                                              |
| 3:2   | RW | 0x2                | 2'b01: 4mA                                              |
|       |    |                    | 2'b10: 8mA                                              |
|       |    |                    | 2'b11: 12mA                                             |

| Bit | Attr | <b>Reset Value</b> | Description |
|-----|------|--------------------|-------------|
|     |      |                    | gpio4d0_e   |
|     |      |                    | 2'b00: 2mA  |
| 1:0 | RW   | 0x2                | 2'b01: 4mA  |
|     |      |                    | 2'b10: 8mA  |
|     |      |                    | 2'b11: 12mA |

### GRF\_GPIO0A\_SR

Address: Operational Base + offset (0x0150)

| Bit   |    | Reset Value | Description                                           |
|-------|----|-------------|-------------------------------------------------------|
|       |    |             | write_enable                                          |
|       |    |             | When bit 16=1, bit 0 can be written by software.      |
|       |    |             | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo | 0x0000      | When bit 17=1, bit 1 can be written by software.      |
| 51:10 | WU | 0x0000      | When bit 17=0, bit 1 can not be written by software.  |
|       |    |             |                                                       |
|       |    |             | When bit $31=1$ , bit 15 can be written by software.  |
|       |    |             | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO | 0x0         | reserved                                              |
|       |    |             | gpio0a7_sr                                            |
| 7     | RW | 0x0         | 1'b0: Slow(half frequency)                            |
|       |    |             | 1'b1: Fast                                            |
|       |    |             | gpio0a6_sr                                            |
| 6     | RW | 0x0         | 1'b0: Slow(half frequency)                            |
|       |    |             | 1'b1: Fast                                            |
|       |    |             | gpio0a5_sr                                            |
| 5     | RW | 0x0         | 1'b0: Slow(half frequency)                            |
|       |    |             | 1'b1: Fast                                            |
|       |    | 0x0         | gpio0a4_sr                                            |
| 4     | RW |             | 1'b0: Slow(half frequency)                            |
|       |    |             | 1'b1: Fast                                            |
|       |    |             | gpio0a3_sr                                            |
| 3     | RW | 0x0         | 1'b0: Slow(half frequency)                            |
|       |    |             | 1'b1: Fast                                            |
|       |    |             | gpio0a2_sr                                            |
| 2     | RW | 0x0         | 1'b0: Slow(half frequency)                            |
|       |    |             | 1'b1: Fast                                            |
|       |    |             | gpio0a1_sr                                            |
| 1     | RW | 0x0         | 1'b0: Slow(half frequency)                            |
|       |    |             | 1'b1: Fast                                            |
|       |    |             | gpio0a0_sr                                            |
| 0     | RW | 0x0         | 1'b0: Slow(half frequency)                            |
|       |    |             | 1'b1: Fast                                            |

### <u>GRF\_GPIO0B\_SR</u>

Address: Operational Base + offset (0x0154)

| Bit   | Attr | <b>Reset Value</b> | Description                                             |
|-------|------|--------------------|---------------------------------------------------------|
|       |      |                    | write_enable                                            |
|       |      |                    | When bit $16=1$ , bit 0 can be written by software.     |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.    |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.        |
| 51110 |      |                    | When bit $17=0$ , bit 1 can not be written by software. |
|       |      |                    |                                                         |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.    |
|       |      |                    | When bit 31=0, bit 15 can not be written by software.   |
| 15:8  | RO   | 0x0                | reserved                                                |
|       |      |                    | gpio0b7_sr                                              |
| 7     | RW   | 0x0                | 1'b0: Slow(half frequency)                              |
|       |      |                    | 1'b1: Fast                                              |
|       |      |                    | gpio0b6_sr                                              |
| 6     | RW   | 0x0                | 1'b0: Slow(half frequency)                              |
|       |      |                    | 1'b1: Fast                                              |
|       |      |                    | gpio0b5_sr                                              |
| 5     | RW   | 0x0                | 1'b0: Slow(half frequency)                              |
|       |      |                    | 1'b1: Fast                                              |
|       |      |                    | gpio0b4_sr                                              |
| 4     | RW   | 0x0                | 1'b0: Slow(half frequency)                              |
|       |      |                    | 1'b1: Fast                                              |
|       |      |                    | gpio0b3_sr                                              |
| 3     | RW   | 0x0                | 1'b0: Slow(half frequency)                              |
|       |      |                    | 1'b1: Fast                                              |
|       |      |                    | gpio0b2_sr                                              |
| 2     | RW   | 0x0                | 1'b0: Slow(half frequency)                              |
|       |      |                    | 1'b1: Fast                                              |
|       |      |                    | gpio0b1_sr                                              |
| 1     | RW   | 0x0                | 1'b0: Slow(half frequency)                              |
|       |      |                    | 1'b1: Fast                                              |
|       |      |                    | gpio0b0_sr                                              |
| 0     | RW   | 0x0                | 1'b0: Slow(half frequency)                              |
|       |      |                    | 1'b1: Fast                                              |

#### GRF\_GPIOOC\_SR

Address: Operational Base + offset (0x0158)

| Bit   | Attr | Reset Value | Description                                           |
|-------|------|-------------|-------------------------------------------------------|
|       |      |             | write_enable                                          |
|       |      |             | When bit 16=1, bit 0 can be written by software.      |
|       |      |             | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000      | When bit 17=1, bit 1 can be written by software.      |
| 51:10 | WU   | 0x0000      | When bit 17=0, bit 1 can not be written by software.  |
|       |      |             |                                                       |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |             | When bit 31=0, bit 15 can not be written by software. |
| 15:6  | RO   | 0x0         | reserved                                              |
|       |      |             | gpio0c5_sr                                            |
| 5     | RW   | 0×0         | 1'b0: Slow(half frequency)                            |
|       |      |             | 1'b1: Fast                                            |
|       |      |             | gpio0c4_sr                                            |
| 4     | RW   | 0×0         | 1'b0: Slow(half frequency)                            |
|       |      |             | 1'b1: Fast                                            |
|       |      |             | gpio0c3_sr                                            |
| 3     | RW   | 0x0         | 1'b0: Slow(half frequency)                            |
|       |      |             | 1'b1: Fast                                            |
|       |      |             | gpio0c2_sr                                            |
| 2     | RW   | 0x0         | 1'b0: Slow(half frequency)                            |
|       |      |             | 1'b1: Fast                                            |
|       |      |             | gpio0c1_sr                                            |
| 1     | RW   | 0x0         | 1'b0: Slow(half frequency)                            |
|       |      |             | 1'b1: Fast                                            |
|       |      |             | gpio0c0_sr                                            |
| 0     | RW   | RW 0x0      | 1'b0: Slow(half frequency)                            |
|       |      |             | 1'b1: Fast                                            |

**<u>GRF\_GPIO1A\_SR</u>** Address: Operational Base + offset (0x0160)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0×0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | vvO  |                    | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio1a7_sr                                            |
| 7     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |

| Bit | Attr | <b>Reset Value</b> | Description                |
|-----|------|--------------------|----------------------------|
|     |      |                    | gpio1a6_sr                 |
| 6   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio1a5_sr                 |
| 5   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio1a4_sr                 |
| 4   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio1a3_sr                 |
| 3   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio1a2_sr                 |
| 2   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio1a1_sr                 |
| 1   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio1a0_sr                 |
| 0   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |

### <u>GRF\_GPIO1B\_SR</u>

Address: Operational Base + offset (0x0164)

| Bit   |    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                |
|-------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo | 0×0000      | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 can not be written by software.</pre> |
| 15:8  | RO | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                   |
| 7     | RW | 0x0         | gpio1b7_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                     |
| 6     | RW | 0×0         | gpio1b6_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                     |
| 5     | RW | 0x0         | gpio1b5_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                     |

| Bit | Attr | Reset Value | Description                |
|-----|------|-------------|----------------------------|
|     |      |             | gpio1b4_sr                 |
| 4   | RW   | 0x0         | 1'b0: Slow(half frequency) |
|     |      |             | 1'b1: Fast                 |
|     |      |             | gpio1b3_sr                 |
| 3   | RW   | 0x0         | 1'b0: Slow(half frequency) |
|     |      |             | 1'b1: Fast                 |
|     |      |             | gpio1b2_sr                 |
| 2   | RW   | 0x0         | 1'b0: Slow(half frequency) |
|     |      |             | 1'b1: Fast                 |
|     |      |             | gpio1b1_sr                 |
| 1   | RW   | 0x0         | 1'b0: Slow(half frequency) |
|     |      |             | 1'b1: Fast                 |
|     |      |             | gpio1b0_sr                 |
| 0   | RW   | 0x0         | 1'b0: Slow(half frequency) |
|     |      |             | 1'b1: Fast                 |

### GRF\_GPIO1C\_SR

Address: Operational Base + offset (0x0168)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0,4000             | When bit 17=1, bit 1 can be written by software.      |
| 31:10 | WU   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio1c7_sr                                            |
| 7     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio1c6_sr                                            |
| 6     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio1c5_sr                                            |
| 5     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio1c4_sr                                            |
| 4     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio1c3_sr                                            |
| 3     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |

| Bit | Attr | <b>Reset Value</b> | Description                |
|-----|------|--------------------|----------------------------|
|     |      |                    | gpio1c2_sr                 |
| 2   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio1c1_sr                 |
| 1   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio1c0_sr                 |
| 0   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |

**<u>GRF GPIO1D SR</u>** Address: Operational Base + offset (0x016c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:2  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1     | RW   | 0×0                | gpio1d1_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                                                                                     |
| 0     | RW   | 0×0                | gpio1d0_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                                                                                     |

#### **GRF\_GPIO2A\_SR**

Address: Operational Base + offset (0x0170)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 21:10 | vvO  | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       |      | V 0x0              | gpio2a7_sr                                            |
| 7     | RW   |                    | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |

| Bit | Attr | <b>Reset Value</b> | Description                |
|-----|------|--------------------|----------------------------|
|     |      |                    | gpio2a6_sr                 |
| 6   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio2a5_sr                 |
| 5   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio2a4_sr                 |
| 4   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio2a3_sr                 |
| 3   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio2a2_sr                 |
| 2   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio2a1_sr                 |
| 1   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio2a0_sr                 |
| 0   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |

### GRF GPIO2B SR

Address: Operational Base + offset (0x0174)

| Bit   |    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                |
|-------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo | 0×0000      | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 can not be written by software.</pre> |
| 15:8  | RO | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                   |
| 7     | RW | 0x0         | gpio2b7_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                     |
| 6     | RW | 0×0         | gpio2b6_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                     |
| 5     | RW | 0x0         | gpio2b5_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                     |

| Bit | Attr | Reset Value | Description                |
|-----|------|-------------|----------------------------|
|     |      |             | gpio2b4_sr                 |
| 4   | RW   | 0x0         | 1'b0: Slow(half frequency) |
|     |      |             | 1'b1: Fast                 |
|     |      |             | gpio2b3_sr                 |
| 3   | RW   | 0x0         | 1'b0: Slow(half frequency) |
|     |      |             | 1'b1: Fast                 |
|     |      |             | gpio2b2_sr                 |
| 2   | RW   | 0x0         | 1'b0: Slow(half frequency) |
|     |      |             | 1'b1: Fast                 |
|     |      |             | gpio2b1_sr                 |
| 1   | RW   | 0x0         | 1'b0: Slow(half frequency) |
|     |      |             | 1'b1: Fast                 |
|     |      |             | gpio2b0_sr                 |
| 0   | RW   | 0x0         | 1'b0: Slow(half frequency) |
|     |      |             | 1'b1: Fast                 |

#### **GRF\_GPIO2C\_SR**

Address: Operational Base + offset (0x0178)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                  |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 |      | 0x0000             | write_enable<br>When bit 16=1, bit 0 can be written by software.<br>When bit 16=0, bit 0 can not be written by software.<br>When bit 17=1, bit 1 can be written by software. |
|       |      |                    | When bit 17=0, bit 1 can not be written by software.<br><br>When bit 31=1, bit 15 can be written by software.<br>When bit 31=0, bit 15 can not be written by software.       |
| 15:1  | RO   | 0x0                | reserved                                                                                                                                                                     |
| 0     | RW   | 0×0                | gpio2c0_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                       |

### GRF\_GPIO3A\_SR

Address: Operational Base + offset (0x0180)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                   |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 |      | 0×0000             | write_enable<br>When bit 16=1, bit 0 can be written by software.<br>When bit 16=0, bit 0 can not be written by software.<br>When bit 17=1, bit 1 can be written by software.<br>When bit 17=0, bit 1 can not be written by software.<br><br>When bit 31=1, bit 15 can be written by software. |
|       |      |                    | When bit 31=0, bit 15 can not be written by software.                                                                                                                                                                                                                                         |
| 15:8  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                      |

| Bit | Attr | <b>Reset Value</b> | Description                |
|-----|------|--------------------|----------------------------|
|     |      |                    | gpio3a7_sr                 |
| 7   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio3a6_sr                 |
| 6   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio3a5_sr                 |
| 5   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio3a4_sr                 |
| 4   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio3a3_sr                 |
| 3   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio3a2_sr                 |
| 2   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio3a1_sr                 |
| 1   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio3a0_sr                 |
| 0   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |

### <u>GRF\_GPIO3B\_SR</u>

Address: Operational Base + offset (0x0184)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 can not be written by software.</pre> |
| 15:6  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                   |
| 5     | RW   | 0×0                | gpio3b5_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                     |
| 4     | RW   | 0×0                | gpio3b4_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                     |

| Bit | Attr | <b>Reset Value</b> | Description                |
|-----|------|--------------------|----------------------------|
|     |      |                    | gpio3b3_sr                 |
| 3   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio3b2_sr                 |
| 2   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio3b1_sr                 |
| 1   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio3b0_sr                 |
| 0   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |

**<u>GRF\_GPIO4A\_SR</u>** Address: Operational Base + offset (0x0190)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0,4000             | When bit 17=1, bit 1 can be written by software.      |
| 31:10 | WÜ   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio4a7_sr                                            |
| 7     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4a6_sr                                            |
| 6     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4a5_sr                                            |
| 5     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4a4_sr                                            |
| 4     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4a3_sr                                            |
| 3     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4a2_sr                                            |
| 2     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |

| Bit | Attr | <b>Reset Value</b> | Description                |
|-----|------|--------------------|----------------------------|
|     |      |                    | gpio4a1_sr                 |
| 1   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |
|     |      |                    | gpio4a0_sr                 |
| 0   | RW   | 0x0                | 1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                 |

**<u>GRF\_GPIO4B\_SR</u>** Address: Operational Base + offset (0x0194)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | 000  | 0,0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio4b7_sr                                            |
| 7     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4b6_sr                                            |
| 6     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4b5_sr                                            |
| 5     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4b4_sr                                            |
| 4     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4b3_sr                                            |
| 3     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4b2_sr                                            |
| 2     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4b1_sr                                            |
| 1     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |
|       |      |                    | gpio4b0_sr                                            |
| 0     | RW   | 0x0                | 1'b0: Slow(half frequency)                            |
|       |      |                    | 1'b1: Fast                                            |

### GRF GPIO4C SR

Address: Operational Base + offset (0x0198)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:1  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0     | RW   | 0x0                | gpio4c0_sr<br>1'b0: Slow(half frequency)<br>1'b1: Fast                                                                                                                                                                                                                                                                                                                                                     |

#### GRF\_GPIO4D\_SR

Address: Operational Base + offset (0x019c)

| Bit   |    | <b>Reset Value</b> | Description                                           |
|-------|----|--------------------|-------------------------------------------------------|
|       |    |                    | write_enable                                          |
|       |    |                    | When bit $16=1$ , bit 0 can be written by software.   |
|       |    |                    | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 | wo | 0000               | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | WO | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |    |                    |                                                       |
|       |    |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |    |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:7  | RO | 0x0                | reserved                                              |
|       |    |                    | gpio4d6_sr                                            |
| 6     | RW | 0x0                | 1'b0: Slow(half frequency)                            |
|       |    |                    | 1'b1: Fast                                            |
|       |    |                    | gpio4d5_sr                                            |
| 5     | RW | 0x0                | 1'b0: Slow(half frequency)                            |
|       |    |                    | 1'b1: Fast                                            |
|       |    |                    | gpio4d4_sr                                            |
| 4     | RW | 0x0                | 1'b0: Slow(half frequency)                            |
|       |    |                    | 1'b1: Fast                                            |
|       |    |                    | gpio4d3_sr                                            |
| 3     | RW | 0x0                | 1'b0: Slow(half frequency)                            |
|       |    |                    | 1'b1: Fast                                            |
|       |    |                    | gpio4d2_sr                                            |
| 2     | RW | 0x0                | 1'b0: Slow(half frequency)                            |
|       |    |                    | 1'b1: Fast                                            |
|       |    |                    | gpio4d1_sr                                            |
| 1     | RW | 0x0                | 1'b0: Slow(half frequency)                            |
|       |    |                    | 1'b1: Fast                                            |

| Bit | Attr | <b>Reset Value</b> | Description                              |
|-----|------|--------------------|------------------------------------------|
| 0   | RW   |                    | gpio4d0_sr<br>1'b0: Slow(half frequency) |
|     |      |                    | 1'b1: Fast                               |

### GRF GPIOOA SMT

Address: Operational Base + offset (0x01a0)

| Bit   |    | <b>Reset Value</b> | Description                                           |
|-------|----|--------------------|-------------------------------------------------------|
|       |    |                    | write_enable                                          |
|       |    |                    | When bit 16=1, bit 0 can be written by software.      |
|       |    |                    | When bit 16=0, bit 0 can not be written by software.  |
| 21.16 | WO | 0×0000             | When bit 17=1, bit 1 can be written by software.      |
| 21:10 |    |                    | When bit 17=0, bit 1 can not be written by software.  |
|       |    |                    |                                                       |
|       |    |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |    |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO | 0x0                | reserved                                              |
|       |    |                    | gpio0a7_smt                                           |
| 7     | RW | 0x0                | 1'b0: No hysteresis                                   |
|       |    |                    | 1'b1: Schmitt trigger enabled                         |
|       |    |                    | gpio0a6_smt                                           |
| 6     | RW | 0x0                | 1'b0: No hysteresis                                   |
|       |    |                    | 1'b1: Schmitt trigger enabled                         |
|       |    | 0×0                | gpio0a5_smt                                           |
| 5     | RW |                    | 1'b0: No hysteresis                                   |
|       |    |                    | 1'b1: Schmitt trigger enabled                         |
|       | RW | 0×0                | gpio0a4_smt                                           |
| 4     |    |                    | 1'b0: No hysteresis                                   |
|       |    |                    | 1'b1: Schmitt trigger enabled                         |
|       |    |                    | gpio0a3_smt                                           |
| 3     | RW | 0x0                | 1'b0: No hysteresis                                   |
|       |    |                    | 1'b1: Schmitt trigger enabled                         |
|       | RW | 0×0                | gpio0a2_smt                                           |
| 2     |    |                    | 1'b0: No hysteresis                                   |
|       |    |                    | 1'b1: Schmitt trigger enabled                         |
|       | RW | 0×0                | gpio0a1_smt                                           |
| 1     |    |                    | 1'b0: No hysteresis                                   |
|       |    |                    | 1'b1: Schmitt trigger enabled                         |
|       |    |                    | gpio0a0_smt                                           |
| 0     | RW | 0x0                | 1'b0: No hysteresis                                   |
|       |    |                    | 1'b1: Schmitt trigger enabled                         |

#### **GRF\_GPIOOB\_SMT**

Address: Operational Base + offset (0x01a4)

| Bit   | Attr | Reset Value | Description                                           |
|-------|------|-------------|-------------------------------------------------------|
|       |      |             | write_enable                                          |
|       |      |             | When bit 16=1, bit 0 can be written by software.      |
|       |      |             | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 |      |             | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | WO   | 0x0000      | When bit 17=0, bit 1 can not be written by software.  |
|       |      |             |                                                       |
|       |      |             | When bit 31=1, bit 15 can be written by software.     |
|       |      |             | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0         | reserved                                              |
|       |      |             | gpio0b7_smt                                           |
| 7     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio0b6_smt                                           |
| 6     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio0b5_smt                                           |
| 5     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio0b4_smt                                           |
| 4     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio0b3_smt                                           |
| 3     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio0b2_smt                                           |
| 2     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio0b1_smt                                           |
| 1     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio0b0_smt                                           |
| 0     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |

**<u>GRF GPIOOC SMT</u>** Address: Operational Base + offset (0x01a8)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 15:6 | RO   | 0x0         | reserved                      |
|      |      |             | gpio0c5_smt                   |
| 5    | RW   | 0x0         | 1'b0: No hysteresis           |
|      |      |             | 1'b1: Schmitt trigger enabled |
|      |      |             | gpio0c4_smt                   |
| 4    | RW   | 0x0         | 1'b0: No hysteresis           |
|      |      |             | 1'b1: Schmitt trigger enabled |
|      |      |             | gpio0c3_smt                   |
| 3    | RW   | 0x1         | 1'b0: No hysteresis           |
|      |      |             | 1'b1: Schmitt trigger enabled |
|      |      |             | gpio0c2_smt                   |
| 2    | RW   | 0x0         | 1'b0: No hysteresis           |
|      |      |             | 1'b1: Schmitt trigger enabled |
|      |      |             | gpio0c1_smt                   |
| 1    | RW   | 0x0         | 1'b0: No hysteresis           |
|      |      |             | 1'b1: Schmitt trigger enabled |
|      |      |             | gpio0c0_smt                   |
| 0    | RW   | 0x0         | 1'b0: No hysteresis           |
|      |      |             | 1'b1: Schmitt trigger enabled |

#### **GRF\_GPIO1A\_SMT**

Address: Operational Base + offset (0x01b0)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       | wo   | 0×0000             | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31.16 |      |                    | When bit 17=1, bit 1 can be written by software.      |
| 51.10 |      |                    | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       | RW   | 0×0                | gpio1a7_smt                                           |
| 7     |      |                    | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
| 6     | RW   | 0×0                | gpio1a6_smt                                           |
|       |      |                    | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1a5_smt                                           |
| 5     | RW   |                    | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       | RW   | N 0x0              | gpio1a4_smt                                           |
| 4     |      |                    | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |

| Bit | Attr | <b>Reset Value</b> | Description                   |
|-----|------|--------------------|-------------------------------|
|     |      |                    | gpio1a3_smt                   |
| 3   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |
|     |      |                    | gpio1a2_smt                   |
| 2   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |
|     |      |                    | gpio1a1_smt                   |
| 1   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |
|     |      |                    | gpio1a0_smt                   |
| 0   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |

**<u>GRF\_GPIO1B\_SMT</u>** Address: Operational Base + offset (0x01b4)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      | 0×0000             | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       | wo   |                    | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 |      |                    | When bit 17=1, bit 1 can be written by software.      |
| 31:10 |      |                    | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio1b7_smt                                           |
| 7     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1b6_smt                                           |
| 6     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1b5_smt                                           |
| 5     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1b4_smt                                           |
| 4     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1b3_smt                                           |
| 3     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       | RW   |                    | gpio1b2_smt                                           |
| 2     |      |                    | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |

| Bit | Attr | <b>Reset Value</b> | Description                   |
|-----|------|--------------------|-------------------------------|
|     |      |                    | gpio1b1_smt                   |
| 1   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |
|     |      |                    | gpio1b0_smt                   |
| 0   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |

**<u>GRF GPIO1C SMT</u>** Address: Operational Base + offset (0x01b8)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | WO   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | **0  | 0,0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio1c7_smt                                           |
| 7     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1c6_smt                                           |
| 6     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1c5_smt                                           |
| 5     | RW   | 0×0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1c4_smt                                           |
| 4     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1c3_smt                                           |
| 3     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1c2_smt                                           |
| 2     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1c1_smt                                           |
| 1     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1c0_smt                                           |
| 0     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |

## GRF\_GPIO1D\_SMT

Address: Operational Base + offset (0x01bc)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 | wo   | 0,4000             | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | WO   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:2  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio1d1_smt                                           |
| 1     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio1d0_smt                                           |
| 0     | RW   |                    | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |

#### **GRF\_GPIO2A\_SMT**

Address: Operational Base + offset (0x01c0)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit $16=1$ , bit 0 can be written by software.   |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51:10 | WU   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio2a7_smt                                           |
| 7     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      | / 0×0              | gpio2a6_smt                                           |
| 6     | RW   |                    | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio2a5_smt                                           |
| 5     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio2a4_smt                                           |
| 4     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio2a3_smt                                           |
| 3     | RW   | W 0x0              | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |

| Bit | Attr | <b>Reset Value</b> | Description                   |
|-----|------|--------------------|-------------------------------|
|     |      |                    | gpio2a2_smt                   |
| 2   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |
|     |      |                    | gpio2a1_smt                   |
| 1   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |
|     |      |                    | gpio2a0_smt                   |
| 0   | RW   | 0x0                | 1'b0: No hysteresis           |
| l   |      |                    | 1'b1: Schmitt trigger enabled |

## **GRF\_GPIO2B\_SMT**

Address: Operational Base + offset (0x01c4)

| Bit   | Attr | <b>Reset Value</b> | Description                                              |
|-------|------|--------------------|----------------------------------------------------------|
|       |      |                    | write_enable                                             |
|       |      |                    | When bit 16=1, bit 0 can be written by software.         |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.     |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.         |
| 51.10 | vv0  | 00000              | When bit 17=0, bit 1 can not be written by software.     |
|       |      |                    |                                                          |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.     |
|       |      |                    | When bit $31=0$ , bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                                 |
|       |      |                    | gpio2b7_smt                                              |
| 7     | RW   | 0x0                | 1'b0: No hysteresis                                      |
|       |      |                    | 1'b1: Schmitt trigger enabled                            |
|       |      |                    | gpio2b6_smt                                              |
| 6     | RW   | 0x0                | 1'b0: No hysteresis                                      |
|       |      |                    | 1'b1: Schmitt trigger enabled                            |
|       |      | 0x0                | gpio2b5_smt                                              |
| 5     | RW   |                    | 1'b0: No hysteresis                                      |
|       |      |                    | 1'b1: Schmitt trigger enabled                            |
|       | RW   | W 0×0              | gpio2b4_smt                                              |
| 4     |      |                    | 1'b0: No hysteresis                                      |
|       |      |                    | 1'b1: Schmitt trigger enabled                            |
|       |      |                    | gpio2b3_smt                                              |
| 3     | RW   | 0x0                | 1'b0: No hysteresis                                      |
|       |      |                    | 1'b1: Schmitt trigger enabled                            |
|       |      |                    | gpio2b2_smt                                              |
| 2     | RW   | 0x0                | 1'b0: No hysteresis                                      |
|       |      |                    | 1'b1: Schmitt trigger enabled                            |
|       |      |                    | gpio2b1_smt                                              |
| 1     | RW   | W 0×0              | 1'b0: No hysteresis                                      |
|       |      |                    | 1'b1: Schmitt trigger enabled                            |

| Bit | Attr | <b>Reset Value</b> | Description                        |
|-----|------|--------------------|------------------------------------|
| 0   | RW   |                    | gpio2b0_smt<br>1'b0: No hysteresis |
| 0   | L AN |                    | 1'b1: Schmitt trigger enabled      |

## **GRF GPIO2C SMT**

Address: Operational Base + offset (0x01c8)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 31:10 | vvO  | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:1  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio2c0_smt                                           |
| 0     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |

## **GRF\_GPIO3A\_SMT**

Address: Operational Base + offset (0x01d0)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | WO   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | vvO  | 0,0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio3a7_smt                                           |
| 7     | RW   | / 0x0              | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio3a6_smt                                           |
| 6     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio3a5_smt                                           |
| 5     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio3a4_smt                                           |
| 4     | RW   | W 0x0              | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |

| Bit | Attr | <b>Reset Value</b> | Description                   |
|-----|------|--------------------|-------------------------------|
|     |      |                    | gpio3a3_smt                   |
| 3   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |
|     |      |                    | gpio3a2_smt                   |
| 2   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |
|     |      |                    | gpio3a1_smt                   |
| 1   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |
|     |      |                    | gpio3a0_smt                   |
| 0   | RW   | 0x0                | 1'b0: No hysteresis           |
|     |      |                    | 1'b1: Schmitt trigger enabled |

**<u>GRF\_GPIO3B\_SMT</u>** Address: Operational Base + offset (0x01d4)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 31:10 | WÜ   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:6  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio3b5_smt                                           |
| 5     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio3b4_smt                                           |
| 4     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio3b3_smt                                           |
| 3     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio3b2_smt                                           |
| 2     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio3b1_smt                                           |
| 1     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio3b0_smt                                           |
| 0     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |

## **GRF\_GPIO4A\_SMT**

Address: Operational Base + offset (0x01e0)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit $16=1$ , bit 0 can be written by software.   |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0,40000            | When bit 17=1, bit 1 can be written by software.      |
| 31:10 | WU   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0                | reserved                                              |
|       |      |                    | gpio4a7_smt                                           |
| 7     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio4a6_smt                                           |
| 6     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio4a5_smt                                           |
| 5     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio4a4_smt                                           |
| 4     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio4a3_smt                                           |
| 3     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio4a2_smt                                           |
| 2     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio4a1_smt                                           |
| 1     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |
|       |      |                    | gpio4a0_smt                                           |
| 0     | RW   | 0x0                | 1'b0: No hysteresis                                   |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |

#### **GRF\_GPIO4B\_SMT**

Address: Operational Base + offset (0x01e4)

| Bit   | Attr | Reset Value | Description                                           |
|-------|------|-------------|-------------------------------------------------------|
|       |      |             | write_enable                                          |
|       |      |             | When bit $16=1$ , bit 0 can be written by software.   |
|       |      |             | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 | wo   | 0000        | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | WO   | 0x0000      | When bit 17=0, bit 1 can not be written by software.  |
|       |      |             |                                                       |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |             | When bit 31=0, bit 15 can not be written by software. |
| 15:8  | RO   | 0x0         | reserved                                              |
|       |      |             | gpio4b7_smt                                           |
| 7     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio4b6_smt                                           |
| 6     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio4b5_smt                                           |
| 5     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio4b4_smt                                           |
| 4     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio4b3_smt                                           |
| 3     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio4b2_smt                                           |
| 2     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio4b1_smt                                           |
| 1     | RW   | 0x0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |
|       |      |             | gpio4b0_smt                                           |
| 0     | RW   | 0×0         | 1'b0: No hysteresis                                   |
|       |      |             | 1'b1: Schmitt trigger enabled                         |

**<u>GRF GPIO4C SMT</u>** Address: Operational Base + offset (0x01e8)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 15:1 | RO   | 0x0         | reserved                      |
|      |      |             | gpio4c0_smt                   |
| 0    | RW   | 0x0         | 1'b0: No hysteresis           |
|      |      |             | 1'b1: Schmitt trigger enabled |

# GRF\_GPIO4D\_SMT

Address: Operational Base + offset (0x01ec)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |  |  |  |  |  |  |                               |
|-------|------|--------------------|-------------------------------------------------------|--|--|--|--|--|--|-------------------------------|
|       |      |                    | write_enable                                          |  |  |  |  |  |  |                               |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |  |  |  |  |  |  |                               |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |  |  |  |  |  |  |                               |
| 31:16 | WO   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |  |  |  |  |  |  |                               |
| 51.10 | vvO  | 0,0000             | When bit 17=0, bit 1 can not be written by software.  |  |  |  |  |  |  |                               |
|       |      |                    |                                                       |  |  |  |  |  |  |                               |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |  |  |  |  |  |  |                               |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |  |  |  |  |  |  |                               |
| 15:7  | RO   | 0x0                | reserved                                              |  |  |  |  |  |  |                               |
|       |      |                    | gpio4d6_smt                                           |  |  |  |  |  |  |                               |
| 6     | RW   | 0x0                | 1'b0: No hysteresis                                   |  |  |  |  |  |  |                               |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |  |  |  |  |  |  |                               |
|       |      |                    | gpio4d5_smt                                           |  |  |  |  |  |  |                               |
| 5     | RW   | 0x0                | 1'b0: No hysteresis                                   |  |  |  |  |  |  |                               |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |  |  |  |  |  |  |                               |
|       |      | 0×0                | gpio4d4_smt                                           |  |  |  |  |  |  |                               |
| 4     | RW   |                    | 1'b0: No hysteresis                                   |  |  |  |  |  |  |                               |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |  |  |  |  |  |  |                               |
|       |      |                    | gpio4d3_smt                                           |  |  |  |  |  |  |                               |
| 3     | RW   | 0x0                | 1'b0: No hysteresis                                   |  |  |  |  |  |  |                               |
|       |      |                    |                                                       |  |  |  |  |  |  | 1'b1: Schmitt trigger enabled |
|       |      |                    | gpio4d2_smt                                           |  |  |  |  |  |  |                               |
| 2     | RW   | 0x0                | 1'b0: No hysteresis                                   |  |  |  |  |  |  |                               |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |  |  |  |  |  |  |                               |
|       |      |                    | gpio4d1_smt                                           |  |  |  |  |  |  |                               |
| 1     | RW   | 0x0                | 1'b0: No hysteresis                                   |  |  |  |  |  |  |                               |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |  |  |  |  |  |  |                               |
|       |      |                    | gpio4d0_smt                                           |  |  |  |  |  |  |                               |
| 0     | RW   | 0x0                | 1'b0: No hysteresis                                   |  |  |  |  |  |  |                               |
|       |      |                    | 1'b1: Schmitt trigger enabled                         |  |  |  |  |  |  |                               |

## **<u>GRF\_SOC\_CON0</u>**

Address: Operational Base + offset (0x0300)

| Bit   | Attr | Reset Value | Description                                                     |
|-------|------|-------------|-----------------------------------------------------------------|
|       |      |             | write_enable                                                    |
|       |      |             | When bit 16=1, bit 0 can be written by software.                |
|       |      |             | When bit 16=0, bit 0 can not be written by software.            |
|       |      |             | When bit $17=1$ , bit 1 can be written by software.             |
| 31:16 | wo   | 0×0000      | When bit $17=0$ , bit 1 can not be written by software.         |
|       |      |             | · · · · · · · · · · · · · · · · · · ·                           |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.            |
|       |      |             | When bit $31=0$ , bit 15 can not be written by software.        |
| 15:9  | RO   | 0x0         | reserved                                                        |
|       |      |             | io_vsel3_ctrl                                                   |
|       |      |             | After power up, the software can use io_vsel3 to take over the  |
|       |      |             | control. The software should configure the io_vsel3 same value  |
| 8     | RW   | 0x0         | with GPIO0_A4 power-up input before setting this bit.           |
|       |      |             | 1'b0: VCC IO 3 voltage is controlled by GPIO0_A4 function input |
|       |      |             | 1'b1: VCC IO 3 voltage is controlled by io_vsel3                |
| 7     | RO   | 0x0         | reserved                                                        |
| ,     |      |             | otg_drvvbus_out_ctrl                                            |
|       |      |             | In GPIO function mode.                                          |
| 6     | RW   | 0x0         | 1'b0: GPIO0_C5 function output data from GPIO function          |
| Ŭ     |      | 0.00        | 1'b1: GPIO0_C5 function output data from USB 2.0 OTG PHY UTMI   |
|       |      |             | drvvbus                                                         |
|       |      | 0x0         | io_vsel5                                                        |
|       |      |             | VCC IO 5 voltage select.                                        |
| 5     | RW   |             | 1'b0: 3.3V                                                      |
|       |      |             | 1'b1: 1.8V                                                      |
|       |      |             | io_vsel4                                                        |
|       |      |             | VCC IO 4 voltage select.                                        |
| 4     | RW   | 0×1         | 1'b0: 3.3V                                                      |
|       |      |             | 1'b1: 1.8V                                                      |
|       |      |             | io_vsel3                                                        |
|       |      |             | VCC IO 3 voltage select.                                        |
| 3     | RW   | 0x0         | 1'b0: 3.3V                                                      |
|       |      |             | 1'b1: 1.8V                                                      |
|       |      |             | io_vsel2                                                        |
|       |      |             | VCC IO 2 voltage select.                                        |
| 2     | RW   | 0x0         | 1'b0: 3.3V                                                      |
|       |      |             | 1'b1: 1.8V                                                      |
|       |      |             | io_vsel1                                                        |
|       |      |             | VCC IO 1 voltage select.                                        |
| 1     | RW   | 0x0         | 1'b0: 3.3V                                                      |
|       |      |             | 1'b1: 1.8V                                                      |
|       |      |             | io_vsel0                                                        |
|       |      |             | VCC IO 0 voltage select.                                        |
| 0     | RW   | V 0×0       | 1'b0: 3.3V                                                      |
|       |      |             |                                                                 |
|       |      |             | 1'b1: 1.8V                                                      |

Address: Operational Base + offset (0x0304)

| Bit   |      | Reset Value | + offset (0x0304) Description                            |
|-------|------|-------------|----------------------------------------------------------|
|       |      |             | write_enable                                             |
|       |      |             | When bit $16=1$ , bit 0 can be written by software.      |
|       |      |             | When bit 16=0, bit 0 can not be written by software.     |
|       |      |             | When bit $17=1$ , bit 1 can be written by software.      |
| 31:16 | RW   | 0x0000      | When bit $17=0$ , bit 1 can not be written by software.  |
|       |      |             |                                                          |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.     |
|       |      |             | When bit $31=0$ , bit 15 can not be written by software. |
|       |      |             | pmu_debug_tx_out_ctrl                                    |
| . –   |      |             | In GPIO function mode.                                   |
| 15    | RW   | 0x0         | 1'b0: GPIO4_D5 function output from gpio                 |
|       |      |             | 1'b1: GPIO4_D5 function output from pmu_debug_tx         |
|       |      |             | spdif_txsdo_src_sel                                      |
|       |      |             | SPDIF transmit serial data out selection.                |
| 14    | RW   | 0x0         | 1'b0: tx sdo select from spdif tx                        |
|       |      |             | 1'b1: tx sdo select from spdif rx IO input               |
|       |      |             | i2s1_2ch_sdi0_sel                                        |
|       |      |             | 2 channel I2S1 sdi 0 source selection.                   |
|       |      | 0x0         | 2'b00: select from acodec sdo 0                          |
| 13:12 | RW   |             | 2'b01: select from acodec sdo 1                          |
|       |      |             | 2'b10: select from acodec sdo 2                          |
|       |      |             | 2'b11: select from acodec sdo 3                          |
|       |      |             | i2s3_8ch_sdi1_sel                                        |
|       |      |             | 8 channel I2S3 sdi 1 source selection.                   |
| 11.10 |      | 01          | 2'b00: select from acodec sdo 0                          |
| 11:10 | RW   | W 0×1       | 2'b01: select from acodec sdo 1                          |
|       |      |             | 2'b10: select from acodec sdo 2                          |
|       |      |             | 2'b11: select from acodec sdo 3                          |
|       |      |             | i2s3_8ch_sdi0_sel                                        |
|       |      |             | 8 channel I2S3 sdi 0 source selection.                   |
| 9:8   |      | 0.20        | 2'b00: select from acodec sdo 0                          |
| 9:0   | RW   | 0x0         | 2'b01: select from acodec sdo 1                          |
|       |      |             | 2'b10: select from acodec sdo 2                          |
|       |      |             | 2'b11: select from acodec sdo 3                          |
|       |      |             | i2s2_8ch_sdi3_sel                                        |
|       |      |             | 8 channel I2S2 sdi 3 source selection.                   |
| 7:6   | D\\/ | 0x3         | 2'b00: select from acodec sdo 0                          |
| 1.0   | RW   |             | 2'b01: select from acodec sdo 1                          |
|       |      |             | 2'b10: select from acodec sdo 2                          |
|       |      |             | 2'b11: select from acodec sdo 3                          |

| Bit  | Attr | <b>Reset Value</b> | Description                            |
|------|------|--------------------|----------------------------------------|
|      |      |                    | i2s2_8ch_sdi2_sel                      |
|      |      |                    | 8 channel I2S2 sdi 2 source selection. |
| E. 4 |      | 0.42               | 2'b00: select from acodec sdo 0        |
| 5:4  | RW   | 0x2                | 2'b01: select from acodec sdo 1        |
|      |      |                    | 2'b10: select from acodec sdo 2        |
|      |      |                    | 2'b11: select from acodec sdo 3        |
|      |      | W 0x1              | i2s2_8ch_sdi1_sel                      |
|      |      |                    | 8 channel I2S2 sdi 1 source selection. |
| 3:2  |      |                    | 2'b00: select from acodec sdo 0        |
| 5.2  | ĸvv  |                    | 2'b01: select from acodec sdo 1        |
|      |      |                    | 2'b10: select from acodec sdo 2        |
|      |      |                    | 2'b11: select from acodec sdo 3        |
|      |      |                    | i2s2_8ch_sdi0_sel                      |
|      |      |                    | 8 channel I2S2 sdi 0 source selection. |
| 1:0  | RW   | 0.20               | 2'b00: select from acodec sdo 0        |
| 1.0  | ĸvv  | RW 0x0             | 2'b01: select from acodec sdo 1        |
|      |      |                    | 2'b10: select from acodec sdo 2        |
|      |      |                    | 2'b11: select from acodec sdo 3        |

**<u>GRF SOC CON2</u>** Address: Operational Base + offset (0x0308)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15    | RW   | 0×0                | pmu_power_state_out_ctrl<br>In GPIO function mode.<br>1'b0: GPIO4_D0~GPIO4_D4 function output from gpio<br>1'b1: GPIO4_D0~GPIO4_D4 function output from<br>pmu_power_state                                                                                                                                                                                                                                 |
| 14    | RW   | 0×0                | <ul> <li>i2s_16ch_ctrl_en</li> <li>8 channel I2S0 and 8 channel I2S1 are combined into 16 channels.</li> <li>1'b0: disable. I2S0 8ch and I2S1 8ch is individual</li> <li>1'b1: enable. The tx clock (including sclk and lrck) is connected to the other side of I2S controller inside the chip</li> </ul>                                                                                                  |

| Bit    | Attr | <b>Reset Value</b> | Description                                                      |
|--------|------|--------------------|------------------------------------------------------------------|
|        |      |                    | pdm_multi_iofunc_src_sel                                         |
|        |      |                    | PDM multiplex IO function selection.                             |
|        |      |                    | 2'b00: PDM select multiplex IO function from pad group 0(m0)     |
| 13:12  | RW   | 0x0                | 2'b01: PDM select multiplex IO function from pad group 1(m1)     |
|        |      |                    | 2'b10: PDM select multiplex IO function from pad group 2(m2)     |
|        |      |                    | 2'b11: reserved                                                  |
| 1 1    |      | 0.40               |                                                                  |
| 11     | RO   | 0x0                | reserved                                                         |
|        |      |                    | i2s0_8ch_mclk_out_src_sel                                        |
| 10     | RW   | 0x0                | 8 channel I2S0 mclk out selection.                               |
| -      |      |                    | 1'b0: select 8 channel I2S0 mclk IO out from tx mclk             |
|        |      |                    | 1'b1: select 8 channel I2S0 mclk IO out from rx mclk             |
|        |      |                    | i2s0_8ch_sclk_in_rx_src_sel                                      |
|        |      |                    | 8 channel I2S0 rx sclk in selection.                             |
| 9      | RW   | 0x0                | 1'b0: select 8 channel I2S0 rx sclk in from sclk relative rx IO  |
| 9      | K VV | 0.00               | input                                                            |
|        |      |                    | 1'b1: select 8 channel I2S0 rx sclk in from sclk relative tx IO  |
|        |      |                    | input                                                            |
|        |      |                    | i2s0_8ch_sclk_in_tx_src_sel                                      |
|        |      |                    | 8 channel I2S0 tx sclk in selection.                             |
|        |      |                    | 1'b0: select 8 channel I2S0 tx sclk in from sclk relative tx IO  |
| 8      | RW   | 0×0                | input                                                            |
|        |      |                    | 1'b1: select 8 channel I2S0 tx sclk in from sclk relative rx IO  |
|        |      |                    | input                                                            |
|        |      |                    | i2s1_8ch_sd_ioe3                                                 |
|        |      |                    | 8 channel I2S1 sd io3 (GPIO1_B0 and GPIO1_C4) pin output         |
| 7      | RW   | 0x0                | enable.                                                          |
| ,<br>, |      | 0,00               | 1'b0: drive disable                                              |
|        |      |                    | 1'b1: normal operation                                           |
|        |      |                    | i2s1_8ch_sd_ioe2                                                 |
|        |      |                    | 8 channel I2S1 sd io2(GPIO1_B1 and GPIO1_C3) pin output          |
| 6      | RW   | 0x0                | enable.                                                          |
| 0      | L AA | 0.00               | 1'b0: drive disable                                              |
|        |      |                    |                                                                  |
|        |      |                    | 1'b1: normal operation                                           |
|        |      |                    | i2s1_8ch_sd_ioe1                                                 |
| _      |      |                    | 8 channel I2S1 sd io1(GPIO1_B0 and GPIO1_C2) pin output          |
| 5      | RW   | 0x0                | enable.                                                          |
|        |      |                    | 1'b0: drive disable                                              |
|        |      |                    | 1'b1: normal operation                                           |
| 4      | RO   | 0x0                | reserved                                                         |
|        |      |                    | i2s1_8ch_multi_iofunc_src_sel                                    |
|        |      |                    | 8 channel I2S1 multiplex IO function selection.                  |
| 3      | RW   | 0x0                | 1'b0: 8 channel I2S1 select multiplex IO function from pad group |
| 5      |      |                    | 0(m0)                                                            |
|        |      |                    | 1'b1: 8 channel I2S1 select multiplex IO function from pad group |
|        |      |                    | 1(m1)                                                            |

| Bit | Attr | <b>Reset Value</b> | Description                                                     |
|-----|------|--------------------|-----------------------------------------------------------------|
|     |      |                    | i2s1_8ch_mclk_out_src_sel                                       |
| 2   | RW   | 0x0                | 8 channel I2S1 mclk out selection.                              |
| Z   | RVV  | 0.00               | 1'b0: select 8 channel I2S1 mclk IO out from tx mclk            |
|     |      |                    | 1'b1: select 8 channel I2S1 mclk IO out from rx mclk            |
|     |      |                    | i2s1_8ch_sclk_in_rx_src_sel                                     |
|     |      | 0x0                | 8 channel I2S1 rx sclk in selection.                            |
| 1   |      |                    | 1'b0: select 8 channel I2S1 rx sclk in from sclk relative rx IO |
| 1   | RW   |                    | input                                                           |
|     |      |                    | 1'b1: select 8 channel I2S1 rx sclk in from sclk relative tx IO |
|     |      |                    | input                                                           |
|     |      | ₹₩ 0×0             | i2s1_8ch_sclk_in_tx_src_sel                                     |
|     |      |                    | 8 channel I2S1 tx sclk in selection.                            |
| 0   |      |                    | 1'b0: select 8 channel I2S1 tx sclk in from sclk relative tx IO |
| 0   | RVV  |                    | input                                                           |
|     |      |                    | 1'b1: select 8 channel I2S1 tx sclk in from sclk relative rx IO |
|     |      |                    | input                                                           |

## GRF\_SOC\_CON3

Address: Operational Base + offset (0x030c)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | WU   | 00000              | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15    | RO   | 0x0                | reserved                                              |
|       |      |                    | uart4_dma_req_ctrl                                    |
| 14    | RW   | 0x1                | 1'b0: normal dma request                              |
|       |      |                    | 1'b1: mask dma request                                |
|       |      |                    | uart3_dma_req_ctrl                                    |
| 13    | RW   | 0x1                | 1'b0: normal dma request                              |
|       |      |                    | 1'b1: mask dma request                                |
|       |      |                    | uart2_dma_req_ctrl                                    |
| 12    | RW   | 0x1                | 1'b0: normal dma request                              |
|       |      |                    | 1'b1: mask dma request                                |
|       |      |                    | uart1_dma_req_ctrl                                    |
| 11    | RW   | 0x1                | 1'b0: normal dma request                              |
|       |      |                    | 1'b1: mask dma request                                |
|       |      |                    | uart0_dma_req_ctrl                                    |
| 10    | RW   | 0x1                | 1'b0: normal dma request                              |
|       |      |                    | 1'b1: mask dma request                                |

| Bit | Attr | <b>Reset Value</b> | Description                 |
|-----|------|--------------------|-----------------------------|
|     |      |                    | uart4_rts_inv_sel           |
| 9   | RW   | 0x0                | 1'b0: normal rts connection |
|     |      |                    | 1'b1: invert rts connection |
|     |      |                    | uart3_rts_inv_sel           |
| 8   | RW   | 0x0                | 1'b0: normal rts connection |
|     |      |                    | 1'b1: invert rts connection |
|     |      |                    | uart2_rts_inv_sel           |
| 7   | RW   | 0x0                | 1'b0: normal rts connection |
|     |      |                    | 1'b1: invert rts connection |
|     |      |                    | uart1_rts_inv_sel           |
| 6   | RW   | 0x0                | 1'b0: normal rts connection |
|     |      |                    | 1'b1: invert rts connection |
|     |      |                    | uart0_rts_inv_sel           |
| 5   | RW   | 0x0                | 1'b0: normal rts connection |
|     |      |                    | 1'b1: invert rts connection |
|     |      |                    | uart4_cts_inv_sel           |
| 4   | RW   | 0x0                | 1'b0: normal cts connection |
|     |      |                    | 1'b1: invert cts connection |
|     |      |                    | uart3_cts_inv_sel           |
| 3   | RW   | 0x0                | 1'b0: normal cts connection |
|     |      |                    | 1'b1: invert cts connection |
|     |      |                    | uart2_cts_inv_sel           |
| 2   | RW   | 0x0                | 1'b0: normal cts connection |
|     |      |                    | 1'b1: invert cts connection |
|     |      |                    | uart1_cts_inv_sel           |
| 1   | RW   | 0x0                | 1'b0: normal cts connection |
|     |      |                    | 1'b1: invert cts connection |
|     |      |                    | uart0_cts_inv_sel           |
| 0   | RW   | 0x0                | 1'b0: normal cts connection |
|     |      |                    | 1'b1: invert cts connection |

## GRF\_SOC\_CON4

Address: Operational Base + offset (0x0310)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0×0000             | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 can not be written by software.</pre> |
| 15:13 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                   |

| Bit | Attr | Reset Value | Description                                                                                                |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------|
| 12  | RW   | 0x1         | grf_vop_dcf_idle<br>VOP dcf idle setting.<br>1'b0: set vop dcf not idle<br>1'b1: set vop dcf idle(default) |
| 11  | RW   | 0x0         | grf_con_id_dmac1_aw<br>Reserved                                                                            |
| 10  | RW   | 0x0         | grf_con_id_dmac1_ar<br>Reserved                                                                            |
| 9   | RW   | 0x0         | grf_con_id_dmac0_aw<br>Reserved                                                                            |
| 8   | RW   | 0x0         | grf_con_id_dmac0_ar<br>Reserved                                                                            |
| 7   | RW   | 0x0         | grf_con_id_vop_aw<br>Reserved                                                                              |
| 6   | RW   | 0x0         | grf_con_id_vop_ar<br>Reserved                                                                              |
| 5   | RW   | 0x0         | grf_con_id_mac_aw<br>Reserved                                                                              |
| 4   | RW   | 0x0         | grf_con_id_mac_ar<br>Reserved                                                                              |
| 3   | RW   | 0x0         | grf_con_id_crypto_aw<br>Reserved                                                                           |
| 2   | RW   | 0x0         | grf_con_id_crypto_ar<br>Reserved                                                                           |
| 1   | RW   | 0x0         | grf_con_id_cpu_aw<br>Reserved                                                                              |
| 0   | RW   | 0x0         | grf_con_id_cpu_ar<br>Reserved                                                                              |

Address: Operational Base + offset (0x0314)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:9  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |

| Bit | Attr | Reset Value | Description                                                      |
|-----|------|-------------|------------------------------------------------------------------|
|     |      |             | grf_acodec_ad2da_loop                                            |
| 0   | DW   | 0.40        | Acodec AD to DA loop enable control.                             |
| 8   | RW   | 0x0         | 1'b0: Acodec AD to DA loop disable                               |
|     |      |             | 1'b1: Acodec AD to DA loop enable                                |
|     |      |             | grf_vnpor_delay_ctrl                                             |
| 7   |      | 0.40        | The delay time of asserting npor high after VDD33 > VDET+        |
| 7   | RW   | 0x0         | 1'b0: 50ms                                                       |
|     |      |             | 1'b1: 100ms                                                      |
|     |      |             | grf_vnpor_delay_ctrl_src_sel                                     |
|     |      |             | The software can set this bit high to enable the                 |
| 6   | RW   | 0x0         | grf_vnpor_delay_ctrl takes over the delay control.               |
|     |      |             | 1'b0: delay control setting from GPIO0_C5                        |
|     |      |             | 1'b1: delay control setting from grf_vnpor_delay_ctrl            |
|     |      |             | grf_vnpor_latch                                                  |
|     |      |             | VNPOR high level latch enable. When this bit is set to high, the |
| F   |      | 0.40        | NPOR output from power detection module will keep latched even   |
| 5   | RW   | 0x0         | though the 3.3V supply is power off.                             |
|     |      |             | 1'b0: latch disable                                              |
|     |      |             | 1'b1: latch enable                                               |
|     |      |             | grf_i2c3_multi_iofunc_src_sel                                    |
| 4   |      | 0.40        | I2C3 multiplex IO function selection.                            |
| 4   | RW   | 0×0         | 1'b0: I2C3 select multiplex IO function from pad group 0(m0)     |
|     |      |             | 1'b1: I2C3 select multiplex IO function from pad group 1(m1)     |
|     |      |             | grf_uart2_multi_iofunc_src_sel                                   |
|     |      |             | UART2 multiplex IO function selection.                           |
|     |      |             | 2'b00: UART2 select multiplex IO function from pad group 0(m0)   |
| 3:2 | RW   | 0x0         | 2'b01: UART2 select multiplex IO function from pad group 1(m1)   |
|     |      |             | 2'b10: UART2 select multiplex IO function from usb phy uart      |
|     |      |             | debug port                                                       |
|     |      |             | 2'b11: reserved                                                  |
|     |      |             | grf_wifi_ioe                                                     |
| 1   | RW   | 0x0         | WIFI clock (REF_CLKOUT) output enable.                           |
| 1   | K VV | 0.00        | 1'b0: drive disable                                              |
|     |      |             | 1'b1: output enable                                              |
|     |      |             | grf_rtc_32k_ioe                                                  |
| 0   | RW   |             | 32K RTC clock output enable.                                     |
| 0   | L AA | V 0x0       | 1'b0: drive disable                                              |
|     |      |             | 1'b1: output enable                                              |

Address: Operational Base + offset (0x0328)

| Bit   | Attr | Reset Value | Description                                           |
|-------|------|-------------|-------------------------------------------------------|
|       |      |             | write_enable                                          |
|       |      |             | When bit $16=1$ , bit 0 can be written by software.   |
|       |      |             | When bit 16=0, bit 0 can not be written by software.  |
| 21.10 |      | 0000        | When bit 17=1, bit 1 can be written by software.      |
| 31:16 | ĸw   | 0x0000      | When bit 17=0, bit 1 can not be written by software.  |
|       |      |             |                                                       |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |             | When bit 31=0, bit 15 can not be written by software. |
| 15:9  | RO   | 0x0         | reserved                                              |
|       |      |             | grf_con_fw_req_link_pwrDiscTarg_pwrStall              |
| 8     | RW   | 0x1         | 1'b0: bus return error response                       |
|       |      |             | 1'b1: bus return ok response                          |
|       |      |             | grf_con_cpu2servicevoice_req_pwrDiscTarg_pwrStall     |
| 7     | RW   | 0x1         | 1'b0: bus return error response                       |
|       |      |             | 1'b1: bus return ok response                          |
|       |      |             | grf_con_bus2voiceslv_req_pwrDiscTarg_pwrStall         |
| 6     | RW   | 0x1         | 1'b0: bus return error response                       |
|       |      |             | 1'b1: bus return ok response                          |
|       |      | 0x1         | grf_con_bus2peri_req_pwrDiscTarg_pwrStall             |
| 5     | RW   |             | 1'b0: bus return error response                       |
|       |      |             | 1'b1: bus return ok response                          |
|       |      | V 0x1       | grf_con_cpu2bus_req_pwrDiscTarg_pwrStall              |
| 4     | RW   |             | 1'b0: bus return error response                       |
|       |      |             | 1'b1: bus return ok response                          |
|       |      |             | grf_con_cpu2srvmsch_req_pwrDiscTarg_pwrStall          |
| 3     | RW   | 0x1         | 1'b0: bus return error response                       |
|       |      |             | 1'b1: bus return ok response                          |
|       |      |             | grf_con_bus2msch_req_pwrDiscTarg_pwrStall             |
| 2     | RW   | 0x1         | 1'b0: bus return error response                       |
|       |      |             | 1'b1: bus return ok response                          |
|       |      |             | grf_con_peri2msch_req_pwrDiscTarg_pwrStall            |
| 1     | RW   | 0x1         | 1'b0: bus return error response                       |
|       |      |             | 1'b1: bus return ok response                          |
|       |      |             | grf_con_cpu2msch_req_pwrDiscTarg_pwrStall             |
| 0     | RW   | 0×1         | 1'b0: bus return error response                       |
|       |      |             | 1'b1: bus return ok response                          |

Address: Operational Base + offset (0x032c)

| Bit   | Attr | Reset Value | Description                                              |
|-------|------|-------------|----------------------------------------------------------|
|       |      |             | write_enable                                             |
|       |      |             | When bit 16=1, bit 0 can be written by software.         |
|       |      |             | When bit 16=0, bit 0 can not be written by software.     |
|       |      |             | When bit $17=1$ , bit 1 can be written by software.      |
| 31:16 | wo   | 0×0000      | When bit 17=0, bit 1 can not be written by software.     |
|       |      |             | , , , , , , , , , , , , , , , , , , ,                    |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.     |
|       |      |             | When bit $31=0$ , bit 15 can not be written by software. |
| 15:12 | RO   | 0x0         | reserved                                                 |
|       |      |             | grf_wificlk_e                                            |
|       |      |             | REF_CLKOUT output drive strength selection.              |
|       |      |             | 2'b00: 2mA                                               |
| 11:10 | RW   | 0x0         | 2'b01: 4mA                                               |
|       |      |             | 2'b10: 8mA                                               |
|       |      |             | 2'b11: 12mA                                              |
|       |      |             | grf_wificlk_p                                            |
|       |      |             | REF CLKOUT driver disabled state control.                |
|       |      |             | 2'b00: Z (normal operation)                              |
| 9:8   | RW   | 0x2         | 2'b01: weak 1 (pull-up)                                  |
|       |      |             | 2'b10: weak 0 (pull-down)                                |
|       |      |             | 2'b11: repeater (bus keeper)                             |
|       |      |             | grf_wificlk_sr                                           |
|       |      | 0×0         | REF_CLKOUT slew rate control.                            |
| 7     | RW   |             | 1'b0: slow (half frequency)                              |
|       |      |             | 1'b1: fast                                               |
|       |      |             | grf_wificlk_smt                                          |
|       |      |             | REF_CLKOUT Schmitt trigger control.                      |
| 6     | RW   | 0x0         | 1'b0: No hysteresis                                      |
|       |      |             | 1'b1: Schmitt trigger enabled                            |
|       |      |             | grf_nporbypass_e                                         |
|       |      |             | NPOR_BYPASS output drive strength selection.             |
|       |      |             | 2'b00: 2mA                                               |
| 5:4   | RW   | 0x0         | 2'b01: 4mA                                               |
|       |      |             | 2'b10: 8mA                                               |
|       |      |             | 2'b11: 12mA                                              |
|       |      |             | grf_nporbypass_p                                         |
|       |      |             | NPOR_BYPASS driver disabled state control.               |
|       |      |             | 2'b00: Z (normal operation)                              |
| 3:2   | RW   | 0x2         | 2'b01: weak 1 (pull-up)                                  |
|       |      |             | 2'b10: weak 0 (pull-down)                                |
|       |      |             | 2'b11: repeater (bus keeper)                             |
|       |      |             | grf_nporbypass_sr                                        |
|       |      |             | NPOR_BYPASS slew rate control.                           |
| 1     | RW   | 0x0         | 1'b0: slow (half frequency)                              |
|       |      |             | 1'b1: fast                                               |
|       |      |             | ד אדי ומפר                                               |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                        |  |
|-----|------|--------------------|--------------------------------------------------------------------------------------------------------------------|--|
| 0   | RW   | 0×0                | grf_nporbypass_smt<br>NPOR_BYPASS Schmitt trigger control.<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |  |

# GRF\_SOC\_STATUS0

Address: Operational Base + offset (0x0380)

| Bit   |    | <b>Reset Value</b> | Description                                                                                                                                                                                      |
|-------|----|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO | 0x0                | reserved                                                                                                                                                                                         |
| 27    | RO | 0×0                | acodec_dac_master_en_st<br>Acodec ADC master enable status.<br>1'b0: Audio codec adc is in disable state                                                                                         |
| 26    | RO | 0x0                | 1'b1: Audio codec dac is in enable state<br>acodec_adc_master_en_st<br>Acodec ADC master enable status.<br>1'b0: Audio codec adc is in disable state<br>1'b1: Audio codec dac is in enable state |
| 25    | RO | 0x0                | vop_dsp_hold<br>VOP display hold status.<br>1'b0: dispaly is not in hold state<br>1'b1: dispaly is in hold state                                                                                 |
| 24    | RO | 0×0                | vop_dma_finish<br>VOP dma finish status.<br>1'b0: dma is not finish<br>1'b1: dma finish                                                                                                          |
| 23:18 | RO | 0x00               | rkstimer_en_st<br>Secure timer0~5 enable status.<br>1'b0: timer disable<br>1'b1: timer enable                                                                                                    |
| 17:12 |    | 0×00               | rktimer_en_st<br>Non-secure timer0~5 enable status.<br>1'b0: timer disable<br>1'b1: timer enable                                                                                                 |
| 11:10 | RO | 0x0                | reserved                                                                                                                                                                                         |
| 9     | RO | 0×0                | otpcns_sbpi_busy_st<br>Non-secure OTP controller sbpi busy status.<br>1'b0: idle state<br>1'b1: busy state                                                                                       |
| 8     | RO | 0×0                | otpcns_user_busy_st<br>Non-secure OTP controller user busy status.<br>1'b0: idle state<br>1'b1: busy state                                                                                       |

| Bit | Attr | Reset Value | Description                                                                                           |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------|
| 7   | RO   | 0×0         | otpcs_sbpi_busy_st<br>Secure OTP controller sbpi busy status.<br>1'b0: idle state<br>1'b1: busy state |
| 6   | RO   | 0x0         | otpcs_user_busy_st<br>Secure OTP controller user busy status.<br>1'b0: idle state<br>1'b1: busy state |
| 5   | RO   | 0×0         | nandc_master_idle_st<br>NANDC master idle status.<br>1'b0: busy state<br>1'b1: idle state             |
| 4   | RO   | 0x0         | reserved                                                                                              |
| 3   | RO   | 0x1         | vpll1_lock_st<br>VPLL1 lock status.<br>1'b0: PLL is not in lock state<br>1'b1: PLL is in lock state   |
| 2   | RO   | 0x1         | vpll0_lock_st<br>VPLL0 lock status.<br>1'b0: PLL is not in lock state<br>1'b1: PLL is in lock state   |
| 1   | RO   | 0x1         | dpll_lock_st<br>DPLL lock status.<br>1'b0: PLL is not in lock state<br>1'b1: PLL is in lock state     |
| 0   | RO   | 0x1         | apll_lock_st<br>APLL lock status.<br>1'b0: PLL is not in lock state<br>1'b1: PLL is in lock state     |

## <u>GRF\_CPU\_CON0</u>

Address: Operational Base + offset (0x0400)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:12 | RW   | 0×0         | <ul> <li>grf_con_cfgte</li> <li>Enable T32 exception. It sets the initial value of the TE bit in the</li> <li>SCTLR and HSCTLR register. Each bit is defined below.</li> <li>1'b0: TE bit is low</li> <li>1'b1: TE bit is high</li> <li>These bits are sampled only during reset of the core. Tie low for</li> <li>the ARM instruction set for exception handling. Tie high for the</li> <li>Thumb instruction set for exception handling.</li> <li>Only change it when the core is in the reset state</li> </ul> |
| 11:8  | RW   | 0×0         | <pre>grf_con_cfgend<br/>Endianness configuration at reset. It sets the initial value of the<br/>EE bits in the SCTLR, HSCTLR, SCTLR_EL1, SCTLR_EL2, and<br/>SCTLR_EL3 registers. Each bit is defined below.<br/>1'b0: EE bit is low<br/>1'b1: EE bit is high<br/>These bits are sampled only during reset of the core. Tie high for<br/>big-endian data during exception handling. Tie it low for little-<br/>endian data during exception handling.<br/>Only change it when the cores are in the state</pre>     |
| 7:5   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4     | RW   | 0x0         | grf_con_l2rstdisable<br>Disable automatic L2 cache invalidate at reset.<br>1'b0: enable<br>1'b1: disable<br>Assert high to disable L2 cache invalidate at reset.<br>Assert low to enable L2 cache invalidate at reset.<br>Only change it when the processor is in the reset state                                                                                                                                                                                                                                 |
| 3:1   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0     | RW   | 0×0         | grf_con_dbgl1rstdisable<br>Disable L1 data cache automatic invalidate on reset functionality.<br>1'b0: enable<br>1'b1: disable<br>This value is sampled only during reset of the processor. Assert<br>low for normal L1 data cache behavior on rest.<br>Assert it high to disable automatic invalidation of L1 data cache<br>on reset for debugging purpose only.<br>This bit must be driven Low during normal processor powerup<br>sequences                                                                     |

**<u>GRF</u> <u>CPU</u> <u>CON1</u>** Address: Operational Base + offset (0x0404)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 |      | 0×0000      | write_enable<br>When bit 16=1, bit 0 can be written by software.<br>When bit 16=0, bit 0 can not be written by software.<br>When bit 17=1, bit 1 can be written by software.<br>When bit 17=0, bit 1 can not be written by software.<br><br>When bit 31=1, bit 15 can be written by software.                    |
|       |      |             | When bit $31=0$ , bit 15 can not be written by software.                                                                                                                                                                                                                                                         |
| 15:7  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                         |
| 6     | RW   | 0x0         | grf_con_cpu_ema_detect_en<br>CPU memory EMA change detection enable.<br>1'b0: disable<br>1'b1: enable<br>When<br>grf_ema_l2d/grf_emaw_l2d/grf_ema_ra/grf_emaw_ra/grf_emas_<br>ra changed, hardware automatically stops CPU and make it valid<br>to CPU                                                           |
| 5     | RW   | 0x0         | grf_con_evento_clear<br>Set this bit to clear the evento rising edge state                                                                                                                                                                                                                                       |
| 4     | RW   | 0×0         | grf_con_eventi<br>Event input for processor wake-up from WFE state. This pin must<br>be asserted for at least one CLKIN clock cycles. When this signal<br>is asserted, it acts as WFE wake-up event to all the cores in the<br>cluster                                                                           |
| 3:2   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                         |
| 1     | RW   | 0×0         | grf_con_cfgsdisable<br>Prevents modification of certain Secure registers, including bits<br>that correspond to the Lockable SPIs. CFGSDISABLE is typically<br>de-asserted from reset until Secure software has configured the<br>GIC-400 and then subsequently asserted permanently to provide<br>extra security |
| 0     | RW   | 0×0         | grf_con_clrexmonreq<br>Request to clear the external global exclusive monitor. This sends<br>a WFE wake-up event to all cores in the cluster.<br>When set high the global exclusive monitor in the system is<br>requesting the processor EVENT registers to be set high                                          |

## GRF\_CPU\_CON2

Address: Operational Base + offset (0x0408)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:11 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |
| 10    | wo   | 0x0                | grf_emas_ra<br>Extra margin adjustment sense amplifier pulse, affects cycle time<br>in the read cycle                                                                                                                                                                                                                                                                                                      |
| 9:8   | RW   | 0x0                | grf_emaw_ra<br>Extra margin adjustment for write access                                                                                                                                                                                                                                                                                                                                                    |
| 7:5   | RW   | 0x1                | grf_ema_ra<br>Extra margin adjustment                                                                                                                                                                                                                                                                                                                                                                      |
| 4:3   | RW   | 0x0                | grf_emaw_l2d<br>Extra margin adjustment for write access                                                                                                                                                                                                                                                                                                                                                   |
| 2:0   | RW   | 0x1                | grf_ema_l2d<br>Extra margin adjustment                                                                                                                                                                                                                                                                                                                                                                     |

**<u>GRF</u><u>CPU</u>** STATUSO Address: Operational Base + offset (0x0420)

| Bit   | Attr | Reset Value | Description                                                        |
|-------|------|-------------|--------------------------------------------------------------------|
| 31:22 | RO   | 0x0         | reserved                                                           |
|       |      |             | grf_st_cpu_boost_fsm                                               |
| 21:15 | RW   | 0x00        | Indicates the status of CPU boost state, detail description refers |
|       |      |             | to CRU (CPU boost)                                                 |
| 14    | RO   | 0x0         | grf_st_l2flushdone                                                 |
| 14    | κυ   | 0.00        | High indicates L2 hardware flush complete                          |
| 13    | RO   | 0x0         | grf_st_clrexmonack                                                 |
| 13    | κυ   | UXU         | High indicates the ack from clrexmonreq                            |
|       |      |             | grf_st_jtagnsw                                                     |
| 12    | RO   | 0x0         | Current TAP mode of operation. High if JTAG selected, low if SWD   |
|       |      |             | selected SWJ-DP                                                    |
|       |      |             | grf_st_jtagtop                                                     |
| 11    | RO   | 0x0         | JTAG TAP controller in one of top 4 states (TLR, RTI, Sel-DR or    |
|       |      |             | Sel-IR)                                                            |
|       |      |             | evento_rising_edge                                                 |
| 10    | RO   | 0x0         | When event output rising edge is detected, this bit keeps high     |
|       |      |             | until set evento_clear to clear this bit                           |
| 9:4   | RO   | 0x0         | reserved                                                           |
| 3:0   | RO   | 0x0         | grf_st_smpnamp                                                     |
| 5.0   |      | UXU         | Indicate whether a core is taking part in coherency                |

### **GRF CPU STATUS1**

Address: Operational Base + offset (0x0424)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 12    | RO   | 0×0                | <ul> <li>grf_st_standbywfil2</li> <li>Indicates whether the L2 memory system is in WFI low-power state. This signal is active when the following conditions are met.</li> <li>1. All cores are in WFI low-power state, held in reset, or nL2RESET is asserted LOW.</li> <li>2. If ACE has been configured, ACINACTM is asserted high.</li> <li>3. If ACP has been configured, AINACTS is asserted high.</li> <li>4. If CHI has been configured, SINACT is asserted high.</li> <li>5. L2 memory system is idle.</li> <li>The system power controller must not remove power from the processor when this signal is LOW. This restriction includes configurations where you have set the L2_CACHE_PRESENT parameter to 0</li> </ul> |
| 11:8  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7:4   | RO   | 0×0                | grf_st_standbywfi<br>Indicates whether a core is in WFI low-power state.<br>1'b0: Core not in WFI low-power state<br>1'b1: Core in WFI low-power state. This is the reset condition<br>The system power controller must not remove power from an<br>individual core when the corresponding bit of this signal is low                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3:0   | RO   | 0×0                | grf_st_standbywfe<br>Indicates whether a core is in WFE low-power state.<br>1'b0: Core not in WFE low-power state<br>1'b1: Core in WFE low-power state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

## **GRF\_PVTM\_CON0**

Address: Operational Base + offset (0x0440)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 can not be written by software.</pre> |
| 15:12 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                   |
| 11:2  | RW   | 0x000       | pvtm_pmu_clkout_div<br>Clock divider setting of pvtm output clock, the 12bit divider is<br>controlled by pvtm_clkout_div,2'b0                                                                                                                                                                                                              |

| Bit | Attr | <b>Reset Value</b> | Description                                                    |
|-----|------|--------------------|----------------------------------------------------------------|
| 1   | RW   | 10X0               | pvtm_pmu_osc_en<br>Set high to enable the osc_ring in the PVTM |
| 0   | RW   | ()X()              | pvtm_pmu_start<br>Set high to start pmu pvtm                   |

## **GRF\_PVTM\_CON1**

Address: Operational Base + offset (0x0444)

| Bit  | Attr | <b>Reset Value</b> | Description                  |
|------|------|--------------------|------------------------------|
| 31:0 | RW   | 0x00000000         | pvtm_pmu_cal_cnt             |
| 51.0 |      | 0,00000000         | PMU pvtm calculation counter |

#### **GRF PVTM STATUS0**

Address: Operational Base + offset (0x0448)

| Bit  | Attr | <b>Reset Value</b> | Description                                                        |
|------|------|--------------------|--------------------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                           |
| 0    | RO   | ()X()              | pvtm_pmu_freq_done<br>High indicates pmu pvtm frequency count done |

### **GRF PVTM STATUS1**

Address: Operational Base + offset (0x044c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                           |
|------|------|--------------------|-----------------------------------------------------------------------|
| 31:0 | RO   |                    | pvtm_pmu_freq_cnt<br>Indicates the cycle counts of the osc ring clock |

#### **GRF\_TSADC\_TESTBIT\_L**

Address: Operational Base + offset (0x0460)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:0  | RW   | 0×0000             | grf_tsadc_testbit_l<br>TSADC test low bits                                                                                                                                                                                                                                                                                                                                                                 |

### **GRF TSADC TESTBIT H**

Address: Operational Base + offset (0x0464)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000      | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 can not be written by software.</pre> |
| 15:0  | RW   | 0x0000      | grf_tsadc_testbit_h<br>TSADC test high bits                                                                                                                                                                                                                                                                                                |

## GRF USB2 HOSTO CONO

Address: Operational Base + offset (0x0480)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                 |
|-------|------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> </ul> |
| 15:12 | RO   | 0x0                | When bit 31=0, bit 15 can not be written by software. reserved                                                                                                                                                                                                                                                                              |
| 11:6  | RW   | 0x20               | grf_con_host0_fladj_val_common<br>Frame Length Adjustment Register per Port.<br>This value must be the same as that of grf_con_host0_fladj_val.                                                                                                                                                                                             |
| 5:0   | RW   | 0x20               | grf_con_host0_fladj_val<br>Frame Length Adjustment Register.<br>This feature adjusts any offset from the clock source that drives<br>the uSOF counter. The uSOF cycle is equal to 59,488 plus this<br>value. The default value is 0x20, which gives an SOF cycle time<br>of 60,000.                                                         |

## GRF USB2 HOST0 CON1

Address: Operational Base + offset (0x0484)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0x0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                               |
|-----|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | RO   | 0x0                | reserved                                                                                                                                                                                  |
| 14  | RW   | 0×0                | grf_con_usbphy_host_port_wakeup_irq_en<br>USB 2.0 PHY host port wake up interrupt enable control.<br>1'b0: disable<br>1'b1: enable                                                        |
| 13  | RW   | 0x0                | grf_con_host0_arb_pause<br>USB 2.0 HOST0 ehci/ohci arbiter pause control.                                                                                                                 |
| 12  | RW   | 0×0                | grf_con_host0_ohci_susp_lgcy<br>Static OCHI clock control signal. Must be 0 if the OHCI 48/12 Mhz<br>clocks must be suspended when EHCI and OHCI controllers are<br>not active.           |
| 11  | RW   | 0×0                | grf_con_host0_ohci_cntsel<br>Selects the counter value for simulation or real time for 1ms.<br>1'b1: Simulation time<br>1'b0: Count full 1 ms                                             |
| 10  | RW   | 0x1                | grf_con_host0_ohci_clkcktrst<br>Initial reset signal for the DPLL. This is needed only for<br>simulation.                                                                                 |
| 9   | RW   | 0×0                | <pre>grf_con_host0_app_prt_ovrcur Port overcurrent indication from application. When set to 1, the corresponding port enters Disable state.</pre>                                         |
| 8   | RW   | 0×0                | grf_con_host0_autoppd_on_overcur_en<br>Auto port power disable on overcurrent bit. This bit enables<br>automatic port power disable in the host controller.                               |
| 7   | RW   | 0x1                | grf_con_host0_word_if<br>Selects the data width of the UTMI/UTMI+ PHY interface.<br>1'b1: 16-bit interface<br>1'b0: 8-bit interface                                                       |
| 6   | RW   | 0×0                | grf_con_host0_sim_mode<br>Used only for simulation. When set to 1'b1, this bit sets the PHY<br>in a non-driving mode so the EHCI can detect device connection.                            |
| 5   | RW   | 0x1                | grf_con_host0_incrx_en<br>Burst alignment enable.<br>1'b1: Start INCRX burst only on burst x-aligned addresses<br>1'b0: Normal AHB operation; start bursts on any double word<br>boundary |
| 4   | RW   | 0x1                | grf_con_host0_incr8_en<br>AHB burst type INCR8 enable.                                                                                                                                    |
| 3   | RW   | 0x1                | grf_con_host0_incr4_en<br>AHB burst type INCR4 enable.                                                                                                                                    |
| 2   | RW   | 0x1                | grf_con_host0_incr16_en<br>AHB burst type INCR16 enable.                                                                                                                                  |

| Bit | Attr | <b>Reset Value</b> | Description                                                      |
|-----|------|--------------------|------------------------------------------------------------------|
|     |      |                    | grf_con_host0_hubsetup_min                                       |
| 1   | RW   | 0x0                | Hub setup time control signal.                                   |
| 1   | r vv | 0.00               | 1'b1: four FS clocks of hub setup time is used                   |
|     |      |                    | 1'b0: five FS clocks of hub setup time is used                   |
|     |      | ₹₩ 0×0             | grf_con_host0_app_start_clk                                      |
|     |      |                    | OHCI Clock control signal.                                       |
|     |      |                    | This is an asynchronous primary input to the host core. When the |
| 0   | RW   |                    | OHCI clocks are suspended, the system has to assert this signal  |
|     |      |                    | to start the clocks (12 and 48 Mhz). This should be deasserted   |
|     |      |                    | after the clocks are started and before the host is suspended    |
|     |      |                    | again.                                                           |

## GRF USB2 OTG CON0

Address: Operational Base + offset (0x0488)

| Bit   | Attr | <b>Reset Value</b> | Description                                                  |
|-------|------|--------------------|--------------------------------------------------------------|
|       |      |                    | write_enable                                                 |
|       |      |                    | When bit $16=1$ , bit 0 can be written by software.          |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.         |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.             |
| 51.10 | **0  | 0x0000             | When bit 17=0, bit 1 can not be written by software.         |
|       |      |                    |                                                              |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.         |
|       |      |                    | When bit 31=0, bit 15 can not be written by software.        |
| 15:3  | RO   | 0x0                | reserved                                                     |
| 2     | RW   | 0x0                | otg_dbnce_fltr_bypass                                        |
| Z     |      |                    | OTG signals debounce filter bypass.                          |
|       |      |                    | otg_scaledown_mode                                           |
|       |      |                    | Scale-Down mode selects. resulting in faster simulations.    |
|       |      |                    | 2'b00: Disables all scale-downs                              |
| 1:0   |      | 0.20               | 2'b01: Enables scale-down of all timing values except Device |
| 1.0   | RW   |                    | mode suspend and resume                                      |
|       |      |                    | 2'b10: Enables scale-down of Device mode suspend and resume  |
|       |      |                    | timing values only                                           |
|       |      |                    | 2'b11: Enables bit 0 and bit 1 scale-down timing values      |

## GRF USB2 HOSTO STATUSO

Address: Operational Base + offset (0x048c)

| Bit | Attr | <b>Reset Value</b> | Description                                                  |
|-----|------|--------------------|--------------------------------------------------------------|
| 31  | RO   | 0x0                | reserved                                                     |
|     |      |                    | host0_ehci_power_state_ack                                   |
| 30  | RO   |                    | This signal indicates the power state change acknowledgement |
|     |      |                    | from the EHCI to the PCI for PCI power management.           |
| 20  | RO   |                    | host0_ehci_pme_status                                        |
| 29  |      | 0x0                | This bit displays the PME status.                            |

| Bit   | Attr | <b>Reset Value</b> | Description                                                        |
|-------|------|--------------------|--------------------------------------------------------------------|
|       |      |                    | grf_stat_host0_ehci_bufacc                                         |
| 28    | RO   | 0x0                | EHCI buffer access. This signal asserted whenever the host         |
|       |      |                    | controller does a data read/write transfer.                        |
|       |      |                    | grf_stat_host0_ehci_xfer_prdc                                      |
| 27    | RO   | 0x0                | Indicates that the current transfer of the EHCI master on the AHB  |
|       |      |                    | bus belongs to periodic descriptor/data.                           |
|       |      |                    | grf_stat_host0_ohci_ccs                                            |
| 26    | RO   | 0x0                | Current connect status. When set, this bit indicates that the port |
|       |      |                    | state machine is in a connected state.                             |
|       |      |                    | grf_stat_host0_ohci_rwe                                            |
| 25    | RO   | 0x0                | Remote wake up enable. This signal is brought out as a status      |
|       |      |                    | signal and can be ignored by normal host controller operation.     |
|       |      |                    | grf_stat_host0_ohci_drwe                                           |
| 24    | RO   | 0.40               | Device remote wake-up enable. When active, it causes the host      |
| 24    | ĸŪ   | 0x0                | controller to treat a connect or disconnect event as a remote      |
|       |      |                    | wake-up.                                                           |
|       |      |                    | grf_stat_host0_ohci_globalsuspend                                  |
| 23    | RO   | 0x0                | This signal is asserted 5 ms after the host controller enters the  |
|       |      |                    | USB Suspend state.                                                 |
|       |      |                    | grf_stat_host0_ohci_bufacc                                         |
| 22    | RO   | 0x0                | When active, this signal indicates that the host controller is     |
|       |      |                    | currently accessing the data buffer indicated by the TD.           |
| 21    | RO   | 0.20               | grf_stat_host0_ohci_rmtwkp                                         |
| 21    | кU   | 0x0                | OHCI remote wakeup status.                                         |
|       |      |                    | grf_stat_host0_ehci_lpsmc_state                                    |
| 20:17 | RO   | 0x0                | This signal indicates the state of the LPSMC module and used       |
|       |      |                    | only for debugging.                                                |
|       |      |                    | grf_stat_host0_ehci_usbsts                                         |
| 16:11 |      | 0x00               | This signal indicates pending interrupts and various host          |
| 10:11 | кU   | 0,000              | controller statuses. These 6 bits reflect the value in USBSTS[5:0] |
|       |      |                    | register.                                                          |
|       |      |                    | grf_stat_host0_ehci_xfer_cnt                                       |
| 10.0  | RO   | O 0x000            | Transfer byte count from the EHCI master of the current AHB        |
| 10:0  |      |                    | transaction. This is a constant signal and its value is valid when |
|       |      |                    | the EHCI starts its AHB address phase.                             |

# GRF MAC CONO

Address: Operational Base + offset (0x04a0)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                 |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 |      | 0×0000      | write_enable<br>When bit 16=1, bit 0 can be written by software.<br>When bit 16=0, bit 0 can not be written by software.<br>When bit 17=1, bit 1 can be written by software.<br>When bit 17=0, bit 1 can not be written by software.                        |
|       |      |             | When bit $31=1$ , bit 15 can be written by software.                                                                                                                                                                                                        |
| 15:5  | RO   | 0x0         | When bit 31=0, bit 15 can not be written by software.                                                                                                                                                                                                       |
| 4:2   | RW   | 0x0         | grf_con_mac2io_phy_intf_sel<br>PHY interface select.<br>3'b001: RGMII<br>3'b100: RMII<br>Others: Reserved                                                                                                                                                   |
| 1     | RW   | 0×0         | grf_con_mac2io_flowctrl<br>MAC transmit flow control.<br>When set high, instructs the MAC to transmit PAUSE Control<br>frame in Full-duplex mode. In Half-duplex mode, the MAC<br>enables the Back-pressure function until this signal is made low<br>again |
| 0     | RW   | 0×0         | grf_mac2io_mac_speed<br>MAC speed selection.<br>1'b1:100-Mbps<br>1'b0:10-Mbps                                                                                                                                                                               |

**<u>GRF\_UPCTL\_CON0</u>** Address: Operational Base + offset (0x04a4)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:9  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8     | RW   | 0×0                | dfi_init_start_sel<br>DDR phy dfi_init_start source selection.<br>1'b0: upctl controls dfi_init_start<br>1'b1: grf dfi_init_start controls DDR phy dfi_init_start                                                                                                                                                                                                                                          |
| 7     | RW   | 0x0                | grf_dfi_init_start<br>Software control dfi_init_start bit                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | RW   | 0×0                | csysreq_upctl_pmu<br>PMU control upctl csysreq_ddrc enable.<br>1'b0: disable pmu controls upctl csysreq_ddrc<br>1'b1: enable pmu controls upctl csysreq_ddrc                                                                                                                                                                                                            |
| 5   | RW   | 0x0                | csysreq_upctl_ddrstdby<br>Standby control upctl csysreq_ddrc enable.<br>1'b0: disable standby controls upctl csysreq_ddrc<br>1'b1: enable standby controls upctl csysreq_ddrc                                                                                                                                                                                           |
| 4   | RW   | 0x0                | upctl_c_active_in<br>System low-power active_in                                                                                                                                                                                                                                                                                                                         |
| 3   | RW   | 0×0                | upctl_anfifo<br>Use NFIFO logic. Used to tell uPCTL to use NFIFO module or not.<br>Only useful if NFIFO module is included                                                                                                                                                                                                                                              |
| 2   | RW   | 0×0                | upctl_aburstint<br>Burst Interrupt opportunity, rather than Burst terminate(BST).<br>Used to tell uPCTL not to schedule a BST. Only useful in mDDR or<br>LPDDR2                                                                                                                                                                                                         |
| 1   | RW   | 0×0                | upctl_lp_reset_mode<br>UPCTL low power reset mode.<br>Select between which uPCTL Operational State to reset to:<br>1'b0: Init_mem<br>1'b1: Low_power<br>Related output signals and assumed defaults of input signals will<br>differ depending on which state uPCTL is reset to. This signal<br>should only change during system reset (both n_rst_n=0 and<br>p_rst_n=0) |
| 0   | RW   | 0x1                | ddr_16bit_en<br>DDR 16 bit enable control.<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                                                                                                             |

# **GRF\_UPCTL\_STATUS0**

Address: Operational Base + offset (0x04a8)

| Bit | Attr | <b>Reset Value</b> | Description                                              |
|-----|------|--------------------|----------------------------------------------------------|
| 31  | RO   | 0x0                | reserved                                                 |
|     |      |                    | fw_req_pwrDiscTarg_pwrActive                             |
| 30  | RW   | 0x0                | 1'b0: fw request transmission is idle                    |
|     |      |                    | 1'b1: fw request transmission is active                  |
|     |      |                    | cpu2servicevoiceslv_req_pwrDiscTarg_pwrActive            |
| 29  | RO   | 0x0                | 1'b0: cpu2servicevoiceslv request transmission is idle   |
|     |      |                    | 1'b1: cpu2servicevoiceslv request transmission is active |
|     |      |                    | bus2voiceslv_req_pwrDiscTarg_pwrActive                   |
| 28  | RO   | 0x0                | 1'b0: bus2voiceslv request transmission is idle          |
|     |      |                    | 1'b1: bus2voiceslv request transmission is active        |

| Bit   | Attr | Reset Value | Description                                                         |
|-------|------|-------------|---------------------------------------------------------------------|
|       |      |             | bus2peri_req_pwrDiscTarg_pwrActive                                  |
| 27    | RO   | 0x0         | 1'b0: bus2peri request transmission is idle                         |
|       |      |             | 1'b1: bus2peri request transmission is active                       |
|       |      |             | cpu2bus_req_pwrDiscTarg_pwrActive                                   |
| 26    | RO   | 0x0         | 1'b0: cpu2bus request transmission is idle                          |
|       |      |             | 1'b1: cpu2bus request transmission is active                        |
|       |      |             | cpu2srvmsch_req_pwrDiscTarg_pwrActive                               |
| 25    | RO   | 0x0         | 1'b0: cpu2srvmsch request transmission is idle                      |
|       |      |             | 1'b1: cpu2srvmsch request transmission is active                    |
|       |      |             | bus2msch_req_pwrDiscTarg_pwrActive                                  |
| 24    | RO   | 0x0         | 1'b0: bus2msch request transmission is idle                         |
|       |      |             | 1'b1: bus2msch request transmission is active                       |
|       |      |             | peri2msch_req_pwrDiscTarg_pwrActive                                 |
| 23    | RO   | 0x0         | 1'b0: peri2msch request transmission is idle                        |
|       |      |             | 1'b1: peri2msch request transmission is active                      |
|       |      |             | cpu2msch_req_pwrDiscTarg_pwrActive                                  |
| 22    | RO   | 0x0         | 1'b0: cpu2msch request transmission is idle                         |
|       |      |             | 1'b1: cpu2msch request transmission is active                       |
| 21    | RO   | 0x0         | dfi_scramble_key_ready                                              |
| 21    | κυ   | 0.00        | High indicates scramble key is ready                                |
| 20    | RO   | .O 0x0      | upctrl_c_active                                                     |
| 20    | κυ   | 0.00        | Clock active. Active state is High                                  |
| 19    | RO   | 0x0         | upctrl_c_sysack                                                     |
| 19    | κυ   | UXU         | Low-power request acknowledgement. Active state is Low              |
|       |      |             | grf_ddrupctl_stat                                                   |
| 18:16 | RO   | 0x0         | Current state of the uPCTL. Value of the STAT.ctl_stat register bit |
|       |      |             | field is driven on this signal                                      |
|       |      |             | ddrupctl_bbflags                                                    |
| 15:0  | RO   | 0x0000      | Bank busy indication.                                               |
| 12.0  | RÜ   |             | 1'b0: idle                                                          |
|       |      |             | 1'b1: busy                                                          |

## GRF OS REGO

Address: Operational Base + offset (0x0500)

| Bit  | Attr | <b>Reset Value</b> | Description                          |
|------|------|--------------------|--------------------------------------|
| 31:0 | RW   | 07000000000        | grf_os_reg0                          |
|      |      |                    | OS register 0, reset only by pmurstn |

# GRF OS REG1

## Address: Operational Base + offset (0x0504)

| Bit  | Attr | <b>Reset Value</b> | Description                                         |
|------|------|--------------------|-----------------------------------------------------|
| 31:0 | RW   | 02000000000        | grf_os_reg1<br>OS register 1, reset only by pmurstn |

#### GRF\_OS\_REG2

Address: Operational Base + offset (0x0508)

| Bit  | Attr | <b>Reset Value</b> | Description                                         |
|------|------|--------------------|-----------------------------------------------------|
| 31:0 | RW   | 02000000000        | grf_os_reg2<br>OS register 2, reset only by pmurstn |

## GRF OS REG3

Address: Operational Base + offset (0x050c)

| Bit  | Attr | <b>Reset Value</b> | Description                                         |
|------|------|--------------------|-----------------------------------------------------|
| 31:0 | RW   | 0,000000000        | grf_os_reg3<br>OS register 3, reset only by pmurstn |

#### **GRF OS REG4**

Address: Operational Base + offset (0x0510)

| Bit  | Attr | <b>Reset Value</b> | Description                                         |
|------|------|--------------------|-----------------------------------------------------|
| 31:0 | RW   | 0×00000000         | grf_os_reg4<br>OS register 4, reset only by pmurstn |

#### GRF\_OS\_REG5

Address: Operational Base + offset (0x0514)

| Bit  | Attr | <b>Reset Value</b> | Description                          |
|------|------|--------------------|--------------------------------------|
| 31:0 | RW   | 0x00000000         | grf_os_reg5                          |
|      |      |                    | OS register 5, reset only by pmurstn |

#### **GRF\_OS\_REG6**

Address: Operational Base + offset (0x0518)

| Bit  | Attr | <b>Reset Value</b> | Description                                         |
|------|------|--------------------|-----------------------------------------------------|
| 31:0 | RW   | 02000000000        | grf_os_reg6<br>OS register 6, reset only by pmurstn |

#### GRF\_OS\_REG7

Address: Operational Base + offset (0x051c)

| Bit  | Attr | <b>Reset Value</b> | Description                          |
|------|------|--------------------|--------------------------------------|
| 31:0 | RW   | 0x00000000         | grf_os_reg7                          |
| 51.0 |      | 0.00000000         | OS register 7, reset only by pmurstn |

#### **GRF OS REG8**

Address: Operational Base + offset (0x0520)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                    |
|------|------|--------------------|--------------------------------------------------------------------------------|
| 31:0 | RW   | 0×00000000         | grf_os_reg8<br>OS register 8, once these bits are written, they can't be reset |

#### GRF\_OS\_REG9

## RK3308 TRM-Part1

#### Address: Operational Base + offset (0x0524)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                    |
|------|------|--------------------|--------------------------------------------------------------------------------|
| 31:0 | RW   | 02000000000        | grf_os_reg9<br>OS register 9, once these bits are written, they can't be reset |

### GRF\_OS\_REG10

Address: Operational Base + offset (0x0528)

| Bit  | Attr | <b>Reset Value</b>                      | Description                                                      |
|------|------|-----------------------------------------|------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000                              | grf_os_reg10                                                     |
| 51.0 |      | 0,0000000000000000000000000000000000000 | OS register 10, once these bits are written, they can't be reset |

### GRF OS REG11

Address: Operational Base + offset (0x052c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                      |
|------|------|--------------------|----------------------------------------------------------------------------------|
| 31:0 | RW   | 020000000000       | orf_os_reg11<br>OS register 11, once these bits are written, they can't be reset |

## GRF\_SOC\_CON12

Address: Operational Base + offset (0x0600)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |
| 15:3  | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2     | RW   | 0×0                | grf_gpio2a4_pad_out_src_sel<br>This bit is multiplex IO control for the output of the gpio2_a4<br>after IOMUX function to provide another same pdm_clk source<br>with gpio2_a6.<br>1'b0: normal gpio2_a4 function<br>1'b1: gpio2_a4 output the same clock source from gpio2_a6<br>IOMUX, and the output enable is controlled by gpio0_b1<br>pmic_sleep function output                                     |
| 1     | RW   | 0x0                | grf_noc_msch_main_partialpop<br>The value is corresponding to DDR config. High indicates 16bit                                                                                                                                                                                                                                                                                                             |
| 0     | RW   | 0×0                | grf_noc_msch_mainddr3<br>The value is corresponding to DDR config, if external memory<br>type is DDR3, should set this bit high                                                                                                                                                                                                                                                                            |

## **GRF\_CHIP\_ID**

Address: Operational Base + offset (0x0800)

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

| Bit   | Attr | <b>Reset Value</b> | Description                                               |
|-------|------|--------------------|-----------------------------------------------------------|
| 31:16 | RO   | 0x0                | reserved                                                  |
|       |      |                    | chip_id                                                   |
| 15:0  | RO   | 0x0cea             | Chip ID is 32'h3306, but chip mark as 32'h3308.           |
|       |      |                    | Errata: The read only chip id value is 32'h0cea(32'd3306) |

# 30.4.4 USB PHY GRF Registers Summary

| Name                   | Offset | Size | Reset<br>Value | Description               |
|------------------------|--------|------|----------------|---------------------------|
| USBPHY_GRF_REG0        | 0x0000 | W    | 0x00008518     | USB PHY Register0         |
| USBPHY_GRF_REG1        | 0x0004 | W    | 0x0000e007     | USB PHY Register1         |
| USBPHY GRF REG2        | 0x0008 | W    | 0x000002e7     | USB PHY Register2         |
| USBPHY_GRF_REG3        | 0x000c | W    | 0x0000200      | USB PHY Register3         |
| USBPHY GRF REG4        | 0x0010 | W    | 0x00005556     | USB PHY Register4         |
| <u>USBPHY GRF REG5</u> | 0x0014 | W    | 0x00004555     | USB PHY Register5         |
| USBPHY_GRF_REG6        | 0x0018 | W    | 0x0000005      | USB PHY Register6         |
| USBPHY GRF REG7        | 0x001c | W    | 0x000068c0     | USB PHY Register7         |
| USBPHY_GRF_REG8        | 0x0020 | W    | 0x00000000     | USB PHY Register8         |
| USBPHY_GRF_REG9        | 0x0024 | W    | 0x00000000     | USB PHY Register9         |
| USBPHY GRF REG10       | 0x0028 | W    | 0x00000000     | USB PHY Register10        |
| USBPHY_GRF_REG11       | 0x002c | W    | 0x00000000     | USB PHY Register11        |
| USBPHY GRF REG12       | 0x0030 | W    | 0x00008518     | USB PHY Register12        |
| USBPHY GRF REG13       | 0x0034 | W    | 0x0000e007     | USB PHY Register13        |
| USBPHY_GRF_REG14       | 0x0038 | W    | 0x000002e7     | USB PHY Register14        |
| USBPHY GRF REG15       | 0x003c | W    | 0x00000200     | USB PHY Register15        |
| USBPHY_GRF_REG16       | 0x0040 | W    | 0x00005556     | USB PHY Register16        |
| USBPHY GRF REG17       | 0x0044 | W    | 0x00004555     | USB PHY Register17        |
| USBPHY GRF REG18       | 0x0048 | W    | 0x0000005      | USB PHY Register18        |
| USBPHY_GRF_REG19       | 0x004c | W    | 0x000068c0     | USB PHY Register19        |
| USBPHY GRF REG20       | 0x0050 | W    | 0x00000000     | USB PHY Register20        |
| USBPHY_GRF_REG21       | 0x0054 | W    | 0x00000000     | USB PHY Register21        |
| USBPHY_GRF_REG22       | 0x0058 | W    | 0x00000000     | USB PHY Register22        |
| USBPHY GRF REG23       | 0x005c | W    | 0x00000000     | USB PHY Register23        |
| USBPHY_GRF_CON0        | 0x0100 | W    | 0x00000452     | USB PHY control register0 |
| USBPHY GRF CON1        | 0x0104 | W    | 0x000001d2     | USB PHY control register1 |
| USBPHY GRF CON2        | 0x0108 | W    | 0x00000000     | USB PHY control register2 |
| USBPHY_GRF_CON3        | 0x010c | W    | 0x00000019     | USB PHY control register3 |
| USBPHY GRF STATUS      | 0x0120 | W    |                | USB PHY status register   |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

# 30.4.5 USB PHY GRF Detail Register Description

## USBPHY GRF REGO

Address: Operational Base + offset (0x0000)

| Bit   | Attr | <b>Reset Value</b> | Description                                        |  |
|-------|------|--------------------|----------------------------------------------------|--|
| 31:16 | RW   | 0x0000             | write_enable<br>Bit0~15 write enable               |  |
| 15:0  | RW   | 0x8518             | usbphy_reg0<br>usbcomb phy control reg. BIT15 to 0 |  |

## USBPHY\_GRF\_REG1

Address: Operational Base + offset (0x0004)

| Bit      | Attr    | <b>Reset Value</b>   | Description                          |  |
|----------|---------|----------------------|--------------------------------------|--|
| 31:16 RW | 10x0000 | write_enable         |                                      |  |
|          |         | Bit0~15 write enable |                                      |  |
| 15:0 RW  |         | W 0xe007             | usbphy_reg1                          |  |
|          | RVV     | UXEUU/               | usbcomb phy control reg. BIT31 to 16 |  |

## USBPHY\_GRF\_REG2

Address: Operational Base + offset (0x0008)

| Bit      | Attr | <b>Reset Value</b> | Description                          |  |
|----------|------|--------------------|--------------------------------------|--|
| 31:16 RW | DW   | 10x0000            | write_enable                         |  |
|          | ĸw   |                    | Bit0~15 write enable                 |  |
| 15:0 RW  |      | RW 0x02e7          | usbphy_reg2                          |  |
|          | RW   | 0x02e7             | usbcomb phy control reg. BIT47 to 32 |  |

## **USBPHY GRF REG3**

Address: Operational Base + offset (0x000c)

| Bit      | Attr   | <b>Reset Value</b> | Description                          |  |
|----------|--------|--------------------|--------------------------------------|--|
| 31:16 RW | 0x0000 | write_enable       |                                      |  |
|          | K VV   | 0x0000             | Bit0~15 write enable                 |  |
| 15:0 RW  |        | RW 0x0200          | usbphy_reg3                          |  |
|          | ĸw     |                    | usbcomb phy control reg. BIT63 to 48 |  |

## **USBPHY GRF REG4**

Address: Operational Base + offset (0x0010)

| Bit      | Attr   | <b>Reset Value</b> | Description                          |
|----------|--------|--------------------|--------------------------------------|
| 31:16 RW | 0×0000 | write_enable       |                                      |
|          | RVV    | 0x0000             | Bit0~15 write enable                 |
| 15:0 R   |        | 0x5556             | usbphy_reg4                          |
|          | r vv   | 02000              | usbcomb phy control reg. BIT79 to 64 |

## USBPHY GRF REG5

Address: Operational Base + offset (0x0014)

| Bit   | Attr | <b>Reset Value</b> | Description                                         |
|-------|------|--------------------|-----------------------------------------------------|
| 31:16 | RW   | 0x0000             | write_enable<br>Bit0~15 write enable                |
| 15:0  | RW   | 0x4555             | usbphy_reg5<br>usbcomb phy control reg. BIT95 to 80 |

## USBPHY\_GRF\_REG6

Address: Operational Base + offset (0x0018)

| Bit   | Attr | <b>Reset Value</b> | Description                           |
|-------|------|--------------------|---------------------------------------|
| 21.10 |      | 0x0000             | write_enable                          |
| 31:16 | RVV  |                    | Bit0~15 write enable                  |
| 15.0  | RW   | V 10x0005          | usbphy_reg6                           |
| 15:0  |      |                    | usbcomb phy control reg. BIT111 to 96 |

## USBPHY GRF REG7

Address: Operational Base + offset (0x001c)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.10 |      | 0x0000             | write_enable                           |
| 31:16 | RVV  |                    | Bit0~15 write enable                   |
| 15:0  |      | 0x68c0             | usbphy_reg7                            |
| 15:0  | RW   |                    | usbcomb phy control reg. BIT127 to 112 |

## **USBPHY GRF REG8**

Address: Operational Base + offset (0x0020)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 31:16 | RW   | 0x0000             | write_enable                           |
|       |      |                    | Bit0~15 write enable                   |
| 15:0  | RW   | 0x0000             | usbphy_reg8                            |
| 13.0  | 1    |                    | usbcomb phy control reg. BIT143 to 128 |

## **USBPHY GRF REG9**

Address: Operational Base + offset (0x0024)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 31:16 |      | 0x0000             | write_enable                           |
| 51.10 | RW   |                    | Bit0~15 write enable                   |
| 15.0  | RW   | 0x0000             | usbphy_reg9                            |
| 15:0  |      |                    | usbcomb phy control reg. BIT159 to 144 |

## **USBPHY GRF REG10**

Address: Operational Base + offset (0x0028)

| Bit   | Attr | <b>Reset Value</b> | Description                                            |
|-------|------|--------------------|--------------------------------------------------------|
| 31:16 | RW   | 0x0000             | write_enable<br>Bit0~15 write enable                   |
| 15:0  | RW   | 0x0000             | usbphy_reg10<br>usbcomb phy control reg. BIT175 to 160 |

## **USBPHY GRF REG11**

Address: Operational Base + offset (0x002c)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.10 | RW   | 0x0000             | write_enable                           |
| 51:10 |      |                    | Bit0~15 write enable                   |
| 15.0  | RW   | 0x0000             | usbphy_reg11                           |
| 15:0  |      |                    | usbcomb phy control reg. BIT191 to 176 |

## **USBPHY GRF REG12**

Address: Operational Base + offset (0x0030)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.10 |      | 0x0000             | write_enable                           |
| 31:16 | RVV  |                    | Bit0~15 write enable                   |
| 15:0  | RW   | 10x8518            | usbphy_reg12                           |
| 15:0  |      |                    | usbcomb phy control reg. BIT207 to 192 |

## **USBPHY GRF REG13**

Address: Operational Base + offset (0x0034)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 31:16 |      | 0x0000             | write_enable                           |
|       | RVV  |                    | Bit0~15 write enable                   |
| 15.0  | RW   | W  0xe00/          | usbphy_reg13                           |
| 15:0  | RW   |                    | usbcomb phy control reg. BIT223 to 208 |

## **USBPHY GRF REG14**

Address: Operational Base + offset (0x0038)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.10 | RW   | 0x0000             | write_enable                           |
| 51:10 |      |                    | Bit0~15 write enable                   |
| 15.0  | RW   | W 10x02e7 1        | usbphy_reg14                           |
| 15.0  |      |                    | usbcomb phy control reg. BIT239 to 224 |

## **USBPHY GRF REG15**

Address: Operational Base + offset (0x003c)

| Bit   | Attr | <b>Reset Value</b> | Description                                            |
|-------|------|--------------------|--------------------------------------------------------|
| 31:16 | RW   | 0x0000             | write_enable<br>Bit0~15 write enable                   |
| 15:0  | RW   | 0x0200             | usbphy_reg15<br>usbcomb phy control reg. BIT255 to 240 |

## **USBPHY GRF REG16**

Address: Operational Base + offset (0x0040)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.10 |      | 0x0000             | write_enable                           |
| 31:16 | RW   |                    | Bit0~15 write enable                   |
| 15.0  | RW   | V 10x5556          | usbphy_reg16                           |
| 15:0  |      |                    | usbcomb phy control reg. BIT271 to 256 |

## **USBPHY GRF REG17**

Address: Operational Base + offset (0x0044)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.16 | RW   | 0x0000             | write_enable                           |
| 51.10 |      |                    | Bit0~15 write enable                   |
| 15.0  | RW   | / 10x4555          | usbphy_reg17                           |
| 15:0  |      |                    | usbcomb phy control reg. BIT287 to 272 |

## **USBPHY GRF REG18**

Address: Operational Base + offset (0x0048)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.16 | RW   | 0x0000             | write_enable                           |
| 51.10 |      |                    | Bit0~15 write enable                   |
| 15.0  | RW   | W 10x0005          | usbphy_reg18                           |
| 15:0  |      |                    | usbcomb phy control reg. BIT303 to 288 |

## **USBPHY GRF REG19**

Address: Operational Base + offset (0x004c)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.16 | RW   | 0x0000             | write_enable                           |
| 51.10 |      |                    | Bit0~15 write enable                   |
| 15:0  | RW   | 0x68c0             | usbphy_reg19                           |
| 15:0  |      |                    | usbcomb phy control reg. BIT319 to 304 |

## **USBPHY GRF REG20**

Address: Operational Base + offset (0x0050)

| Bit   | Attr | <b>Reset Value</b> | Description                                            |
|-------|------|--------------------|--------------------------------------------------------|
| 31:16 | RW   | 0x0000             | write_enable<br>Bit0~15 write enable                   |
| 15:0  | RW   | 020000             | usbphy_reg20<br>usbcomb phy control reg. BIT335 to 320 |

## **USBPHY GRF REG21**

Address: Operational Base + offset (0x0054)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.16 | RW   | 0x0000             | write_enable                           |
| 51:10 |      |                    | Bit0~15 write enable                   |
| 15.0  | RW   | W 10x0000          | usbphy_reg21                           |
| 15:0  |      |                    | usbcomb phy control reg. BIT351 to 336 |

## **USBPHY GRF REG22**

Address: Operational Base + offset (0x0058)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 21.16 | RW   | 0x0000             | write_enable                           |
| 51.10 |      |                    | Bit0~15 write enable                   |
| 15.0  | RW   | 0x0000             | usbphy_reg22                           |
| 15:0  |      |                    | usbcomb phy control reg. BIT367 to 352 |

## **USBPHY GRF REG23**

Address: Operational Base + offset (0x005c)

| Bit   | Attr | <b>Reset Value</b> | Description                            |
|-------|------|--------------------|----------------------------------------|
| 31:16 |      |                    | write_enable                           |
| 51.10 | RW   | 00000              | Bit0~15 write enable                   |
| 15:0  | RW   | W 10x0000          | usbphy_reg23                           |
| 15.0  |      |                    | usbcomb phy control reg. BIT383 to 368 |

## USBPHY\_GRF\_CON0

Address: Operational Base + offset (0x0100)

| Bit   | Attr | Reset Value | Description                                         |
|-------|------|-------------|-----------------------------------------------------|
| 31:16 |      | 0.0000      | write_enable                                        |
| 51:10 | RVV  | 0x0000      | Bit0~15 write enable                                |
| 15:11 | RO   | 0x0         | reserved                                            |
| 10    |      | 0x1         | usbotg_utmi_iddig                                   |
| 10    | RW   |             | GRF USB otg Plug iddig Indicator                    |
|       |      | V 0×0       | usbotg_utmi_iddig_sel                               |
| 9     |      |             | USB otg plug indicator output selection             |
| 9     | RW   |             | 1'b0:select phy iddig status to controller          |
|       |      |             | 1'b1: select grf plug iddig indicator to controller |
| 0     |      | 0.40        | usbotg_utmi_dmpulldown                              |
| 8     | RW   | W 0x0       | GRF otg DM pulldown resistor                        |

| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
| 7   | RW   | 0x0         | usbotg_utmi_dppulldown                            |
| /   | r vv | 0.00        | GRF otg DP pulldown resistor                      |
| 6   |      | 0.41        | usbotg_utmi_termselect                            |
| 0   | RW   | 0x1         | GRF otg termination select between FS/LS/HS speed |
| 5:4 | RW   | 0x1         | usbotg_utmi_xcvrselect                            |
| 5:4 | RW   | UXI         | GRF otg transceiver select between FS/LS/HS speed |
| 3:2 | RW   | 0×0         | usbotg_utmi_opmode                                |
| 5.2 | ĸw   |             | GRF otg operational mode selection                |
|     |      | N 0.1       | usbotg_utmi_suspend_n                             |
| 1   | RW   |             | GRF otg suspend mode                              |
| L . | K VV | 0x1         | 1'b0:suspend                                      |
|     |      |             | 1'b1:normal                                       |
|     |      |             | usbotg_utmi_sel                                   |
| 0   | RW   | / 0x0       | 1'b0:select otg controller utmi interface to phy  |
|     |      |             | 1'b1:select GRF utmi interface to phy             |

## USBPHY GRF CON1

Address: Operational Base + offset (0x0104)

| Bit             | Attr | <b>Reset Value</b> | Description                                        |
|-----------------|------|--------------------|----------------------------------------------------|
| 31:16           | DW/  | 0x0000             | write_enable                                       |
| 51.10           |      | 0,0000             | Bit0~15 write enable                               |
| 15:9            | RO   | 0x0                | reserved                                           |
| 8               | RW   | 0x1                | usbhost_utmi_dmpulldown                            |
| 0               |      |                    | GRF host DM pulldown resistor                      |
| 7               | RW   | 0x1                | usbhost_utmi_dppulldown                            |
| /               |      | 0.01               | GRF host DP pulldown resistor                      |
| 6               | RW   | 0x1                | usbhost_utmi_termselect                            |
| 0               |      |                    | GRF host termination select between FS/LS/HS speed |
| 5:4             | RW   | 0×1                | usbhost_utmi_xcvrselect                            |
| J. <del>4</del> |      |                    | GRF host transceiver select between FS/LS/HS speed |
| 3:2             | RW   | 0x0                | usbhost_utmi_opmode                                |
| J.Z             | 1    | 0.00               | GRF host operational mode selection                |
|                 |      |                    | usbhost_utmi_suspend_n                             |
| 1               | RW   | W 0×1              | GRF host suspend mode                              |
| Ŧ               | 1    |                    | 1'b0: suspend                                      |
|                 |      |                    | 1'b1: normal                                       |
|                 |      |                    | usbhost_utmi_sel                                   |
| 0               | RW   | W 0×0              | 1'b0: select host controller utmi interface to phy |
|                 |      |                    | 1'b1: select grf utmi interface to phy             |

## USBPHY GRF CON2

Address: Operational Base + offset (0x0108)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                              |
|-------|------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0×0000             | write_enable<br>Bit0~15 write enable                                                                                                                                                                                                                     |
| 15:13 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                 |
| 12    | RW   | 0x0                | vdm_src_en_usbotg<br>open dm voltage source                                                                                                                                                                                                              |
| 11    | RW   | 0x0                | vdp_src_en_usbotg<br>open dp voltage source                                                                                                                                                                                                              |
| 10    | RW   | 0x0                | rdm_pdwn_en_usbotg<br>open dm pull down resistor                                                                                                                                                                                                         |
| 9     | RW   | 0x0                | idp_src_en_usbotg<br>open dm source current                                                                                                                                                                                                              |
| 8     | RW   | 0x0                | idm_sink_en_usbotg<br>open dm sink current                                                                                                                                                                                                               |
| 7     | RW   | 0x0                | idp_sink_en_usbotg<br>open dp sink current                                                                                                                                                                                                               |
| 6:5   | RO   | 0x0                | reserved                                                                                                                                                                                                                                                 |
| 4     | RW   | 0x0                | usbphy_commononn<br>configure PLL clock output in suspend mode<br>0: 480MHz clock always on<br>1: 480MHz clock will turn off when both ports suspend asserted.<br>If the suspend of any port de-assert, it will wait 1ms to make<br>480MHz clock stable. |
| 3     | RW   | 0x0                | bypasssel_usbotg<br>bypass select                                                                                                                                                                                                                        |
| 2     | RW   | 0x0                | bypassdmen_usbotg<br>bypass dm enable                                                                                                                                                                                                                    |
| 1     | RW   | 0x0                | usbotg_disable_1<br>bypass OTG function                                                                                                                                                                                                                  |
| 0     | RW   | 0x0                | usbotg_disable_0<br>bypass OTG function                                                                                                                                                                                                                  |

## USBPHY\_GRF\_CON3

Address: Operational Base + offset (0x010c)

| Bit   | Attr | Reset Value | Description                            |
|-------|------|-------------|----------------------------------------|
| 31:16 |      | 0x0000      | write_enable                           |
| 51.10 | K VV |             | Bit0~15 write enable                   |
| 15:12 | RO   | 0x0         | reserved                               |
| 1 1   |      | 0x0         | usbotg_utmi_drvvbus                    |
| 11    | RW   |             | USB OTG grf utmi_drvvbus               |
|       |      | W 0x0       | usbotg_utmi_drvvbus_sel                |
| 10    | RW   |             | USB OTG utmi_drvvbus_sel bit control   |
| 10    | K VV |             | 0:select otg controller drvvbus to phy |
|       |      |             | 1:select otg grf utmidrvvbus to phy    |

| Bit | Attr | <b>Reset Value</b> | Description                           |
|-----|------|--------------------|---------------------------------------|
| 9   | RW   | 0x0                | usbotg_utmi_fs_se0                    |
| 9   | K VV | 0.00               | USB OTG utmi_fs_se0 bit control       |
| 8   | RW   | 0x0                | usbotg_utmi_fs_data                   |
| 0   | R VV | 0.00               | USB OTG utmi_fs_data bit control      |
| 7   | RW   | 0x0                | usbotg_utmi_fs_oe                     |
| /   | r vv | 0.00               | USB OTG utmi_fs_oe bit control        |
| 6   | RW   | 0.20               | usbotg_utmi_fs_xver_own               |
| 0   | r vv | 0x0                | USB OTG utmi_fs_xver_own bit control  |
| 5   | RW   | 0×0                | usbhost_utmi_idpullup                 |
| 5   |      |                    | USB HOST utmi_idpullup bit control    |
| 4   | RW   | V 0x1              | usbhost_utmi_dmpulldown               |
| 4   |      |                    | Enable DMINUS Pull Down resistor      |
| 3   | RW   | W 0x1              | usbhost_utmi_dppulldown               |
| 3   | R VV | 0.01               | Enable DPLUS Pull Down resistor       |
| 2   | RW   | 0x0                | usbhost_utmi_dischrgvbus              |
| 2   | R VV |                    | USB HOST utmi_dischrgvbus bit control |
| 1   | RW   | 0x0                | usbhost_utmi_chrgvbus                 |
| Ŧ   | R VV | 0.00               | USB HOST utmi_chrgvbus bit control    |
| 0   | RW   | 0x1                | usbhost_utmi_drvvbus                  |
| 0   |      |                    | USB HOST utmi_drvvbus bit control     |

USBPHY GRF\_STATUS Address: Operational Base + offset (0x0120)

| Bit   | Attr | <b>Reset Value</b> | Description                             |      |                         |
|-------|------|--------------------|-----------------------------------------|------|-------------------------|
| 31:26 | RO   | 0x0                | reserved                                |      |                         |
| 25    | RO   | 0x0                | grf_stat_usbphy_dp_detected             |      |                         |
| 25    | NO   | 0.00               | grf_stat_usbphy_dp_detected bit status  |      |                         |
| 24    | RO   | 0x0                | grf_stat_usbphy_cp_detected             |      |                         |
| 27    | NO   | 0.00               | grf_stat_usbphy_cp_detected bit status  |      |                         |
| 23    | RO   | 0x0                | grf_stat_usbphy_dcp_detected            |      |                         |
| 25    | ĸo   | 0.00               | grf_stat_usbphy_dcp_detected bit status |      |                         |
| 22    | RO   | 0×0                | usbhost_phy_ls_fs_rcv                   |      |                         |
| 22    | ĸo   |                    | host_phy_ls_fs_rcv status               |      |                         |
| 21    | RO   | O 0x0              | usbhost_utmi_avalid                     |      |                         |
| 21    | ĸo   |                    | host_utmi_avalid status                 |      |                         |
| 20    | RO   | 0x0                | usbhost_utmi_bvalid                     |      |                         |
| 20    | κυ   | κυ                 | ĸo                                      | 0.00 | host_utmi_bvalid status |
| 19    | RO   | 0x0                | usbhost_utmi_hostdisconnect             |      |                         |
| 19    | ĸo   | 0.00               | host_utmi_hostdisconnect status         |      |                         |
| 18    | RO   | RO 0x0             | usbhost_utmi_iddig_o                    |      |                         |
| 10    | ĸo   | 0.00               | host_utmi_iddig status                  |      |                         |
| 17:16 | RO   | 0x0                | usbhost_utmi_linestate                  |      |                         |
| 17.10 | Ň    | 0.0                | host_utmi_linestate status              |      |                         |

| Bit | Attr | Reset Value | Description                                                  |
|-----|------|-------------|--------------------------------------------------------------|
| 15  | RO   | 0x0         | usbhost_utmi_sessend<br>host_utmi_sessend status             |
| 14  | RO   | 0x0         | usbhost_utmi_vbusvalid<br>host_utmi_vbusvalid status         |
| 13  | RO   | 0x0         | usbhost_utmi_vmi<br>host_utmi_vmi status                     |
| 12  | RO   | 0x0         | usbhost_utmi_vpi<br>host_utmi_vpi status                     |
| 11  | RO   | 0x0         | usbotg_phy_ls_fs_rcv<br>utmi_phy_ls_fs_rcv_out status        |
| 10  | RO   | 0x0         | usbotg_utmi_avalid<br>otg_utmi avalid bit status             |
| 9   | RO   | 0x0         | usbotg_utmi_bvalid<br>otg_utmi bvalid bit status             |
| 8   | RO   | 0x0         | usbotg_utmi_fs_xver_own<br>OTG utmi_fs_xver_own status       |
| 7   | RO   | 0x0         | usbotg_utmi_hostdisconnect<br>otg_utmi_hostdisconnect status |
| 6   | RO   | 0x0         | usbotg_utmi_iddig<br>usbotg_utmi_iddig status                |
| 5:4 | RO   | 0x0         | usbotg_utmi_linestate<br>otg_utmi_linestate status           |
| 3   | RO   | 0x0         | usbotg_utmi_sessend<br>otg_utmi_sessend bit status           |
| 2   | RO   | 0x0         | usbotg_utmi_vbusvalid<br>otg_utmi_vbusvalid bit status       |
| 1   | RO   | 0x0         | usbotg_utmi_vmi<br>otg_utmi_vmi bit status                   |
| 0   | RO   | 0x0         | usbotg_utmi_vpi<br>otg_utmi_vpi bit status                   |

## 30.4.6 DETECT GRF Registers Summary

| Name                   | Offset  | Size | Reset<br>Value | Description                    |
|------------------------|---------|------|----------------|--------------------------------|
| DETECT GRF SDMMC DE    | 0x0000  | w    | 0~00030440     | SDMMC detect counter           |
| TECT_COUNTER           | 0x0000  | vv   | 0x00030040     |                                |
| DETECT GRF SDMMC DE    | 0x0004  | w    | 0x00000000     | SDMMC detect control           |
| TECT CON               |         |      |                |                                |
| DETECT_GRF_SDMMC_DE    | 0000    | \A/  | 000000000      | CDMMC data at intermunt status |
| TECT STATUS            | 0x0008  | W    | 0x00000000     | SDMMC detect interrupt status  |
| DETECT_GRF_SDMMC_DE    | 0,000 a | W    | 0x00000000     | SDMMC detect interrupt status  |
| <u>TECT STATUS CLR</u> | 0x000c  |      |                | clear.                         |

| Name                 | Offset  | Size | Reset<br>Value | Description                       |
|----------------------|---------|------|----------------|-----------------------------------|
| DETECT_GRF_USB2_DISC | 0x0010  | w    | 0x00030d40     | USB 2.0 PHY disconnect filter     |
| ONNECT CON           | 0X0010  | vv   | 0x00030040     | counter control                   |
| DETECT_GRF_USB2_LINE | 0x0014  | \\/  | 0x00030d40     | USB 2.0 PHY linestate filter      |
| STATE CON            | 0X0014  | W    | 0x00030040     | counter control                   |
| DETECT GRF USB2 BVAL | 0,0010  | 14/  | 0,00000440     | USB 2.0 PHY bvalid filter counter |
| ID_CON               | 0x0018  | W    | 0x00030d40     | control                           |
| DETECT GRF USB2 ID C | 0,001 a | 14/  | 0,00020440     | USB 2.0 PHY id filter counter     |
| ON                   | 0x001c  | W    | 0x00030d40     | control                           |
| DETECT GRF USB2 DETE | 0x0020  | w    | 0x00000000     | USB 2.0 PHY connect detection     |
| CT IRQ ENABLE        | 0X0020  | vv   | 0x00000000     | interrupt request enable control  |
| DETECT_GRF_USB2_DETE | 0,0024  | 14/  | 0,00000000     | USB 2.0 PHY connect detection     |
| <u>CT IRQ STATUS</u> | 0x0024  | W    | 0x00000000     | interrupt status                  |
| DETECT GRF USB2 DETE | 0,0020  | 14/  | 0,000,000,000  | USB 2.0 PHY connect detection     |
| CT_IRQ_STATUS_CLR    | 0x0028  | W    | 0x0000000      | interrupt status clear            |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

## **30.4.7 DETECT GRF Detail Register Description**

## DETECT GRF SDMMC DETECT COUNTER

Address: Operational Base + offset (0x0000)

| Bit  | Attr | <b>Reset Value</b> | Description                                                   |
|------|------|--------------------|---------------------------------------------------------------|
|      |      |                    | sdmmc_detectn_count                                           |
| 31:0 | RW   | 0x00030d40         | SDMMC detect filter counter time control, used for sdmmc card |
|      |      |                    | detecting, counter clock source is detect_grf pclk.           |

## DETECT GRF SDMMC DETECT CON

Address: Operational Base + offset (0x0004)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 can not be written by software.</pre> |
| 15:2  | RO   | 0x0                | Reserved                                                                                                                                                                                                                                                                                                                                   |
| 1     | RW   | 0x0                | sdmmc_detectn_neg_irq_enable<br>Enable sdmmc detectn negedge irq.<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                                                         |
| 0     | RW   | 0x0                | sdmmc_detectn_pos_irq_enable<br>Enable sdmmc detectn posedge irq.<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                                                         |

## DETECT GRF SDMMC DETECT STATUS

Address: Operational Base + offset (0x0008)

| Bit  | Attr | <b>Reset Value</b> | Description                     |
|------|------|--------------------|---------------------------------|
| 31:2 | RO   | 0x0                | Reserved                        |
|      |      |                    | sdmmc_detectn_neg_irq           |
| 1    | RO   | 0×0                | SDMMC detectn interrupt status. |
| 1    | RU   | 0.00               | 1'b0: no interrupt              |
|      |      |                    | 1'b1: card plug in irq          |
|      |      | 0x0                | sdmmc_detectn_pos_irq           |
| 0    | RO   |                    | SDMMC detectn interrupt status. |
| 0    | RU   |                    | 1'b0: no interrupt              |
|      |      |                    | 1'b1: card plug out irq         |

## DETECT GRF SDMMC DETECT STATUS CLR

Address: Operational Base + offset (0x000c)

| Bit  | Attr | <b>Reset Value</b> | Description                  |
|------|------|--------------------|------------------------------|
| 31:2 | RO   | 0x0                | Reserved                     |
|      |      |                    | sdmmc_detectn_neg_irq_clr    |
| 1    | wo   | 0.20               | Interrupt status clear.      |
| L L  | WO   | 0×0                | 1'b0: hold status, no action |
|      |      |                    | 1'b1: clear interrupt status |
|      |      |                    | sdmmc_detectn_pos_irq_clr    |
| 0    | wo   | 0×0                | Interrupt status clear.      |
| 0    | WO   | 0.00               | 1'b0: hold status, no action |
|      |      |                    | 1'b1: clear interrupt status |

## DETECT\_GRF\_USB2\_DISCONNECT\_CON

Address: Operational Base + offset (0x0010)

| Bit  | Attr | <b>Reset Value</b> | Description                                                    |
|------|------|--------------------|----------------------------------------------------------------|
|      |      |                    | disconnect_filter_con                                          |
| 31:0 | RW   | 0x00030d40         | USB 2.0 host and OTG port host disconnect filter time control, |
|      |      |                    | counter clock source is detect_grf pclk.                       |

## DETECT GRF USB2 LINESTATE CON

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description                                                       |
|------|------|--------------------|-------------------------------------------------------------------|
|      |      |                    | linestate_filter_con                                              |
| 31:0 | RW   | 0x00030d40         | USB 2.0 host and OTG port linestate filter time control register, |
|      |      |                    | counter clock source is detect_grf pclk.                          |

### **DETECT GRF USB2 BVALID CON** Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                            |
|------|------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00030d40         | bvalid_filter_con<br>USB 2.0 OTG port bvalid filter time control register, counter clock<br>source is detect_grf pclk. |

**DETECT GRF USB2 ID CON** Address: Operational Base + offset (0x001c)

| Bit  | Attr | <b>Reset Value</b> | Description                                                                                                   |  |  |  |  |  |
|------|------|--------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31:0 | RW   | 0x00030d40         | id_filter_con<br>USB2.0 OTG port id filter time control register, counter clock<br>source is detect_grf pclk. |  |  |  |  |  |

## DETECT GRF USB2 DETECT IRQ ENABLE

Address: Operational Base + offset (0x0020)

| Bit   |    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                |  |  |  |
|-------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 31:16 | WO | 0×0000      | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 can not be written by software.</pre> |  |  |  |
| 15:10 | RO | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 9     | RW | 0×0         | host0_disconnect_neg_irq_en<br>Enable host 0 disconnect negedge detect interrupt.<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                                         |  |  |  |
| 8     | RW | 0×0         | host0_disconnect_pos_irq_en<br>Enable host 0 disconnect posedge detect interrupt.<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                                         |  |  |  |
| 7     | RW | 0×0         | otg0_disconnect_neg_irq_en<br>Enable OTG 0 disconnect negedge detect interrupt.<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                                           |  |  |  |
| 6     | RW | 0x0         | otg0_disconnect_pos_irq_en<br>Enable OTG 0 disconnect posedge detect interrupt.<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                                           |  |  |  |
| 5     | RW | 0×0         | otg0_id_neg_irq_en<br>Enable OTG 0 id negedge detect interrupt.<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                                                           |  |  |  |
| 4     | RW | 0x0         | otg0_id_pos_irq_en<br>Enable OTG 0 id posedge detect interrupt.<br>1'b0: disable<br>1'b1: enable                                                                                                                                                                                                                                           |  |  |  |

| Bit | Attr | <b>Reset Value</b> | Description                                   |
|-----|------|--------------------|-----------------------------------------------|
|     |      |                    | otg0_bvalid_neg_irq_en                        |
| 3   | RW   | 0x0                | Enable OTG 0 bvalid negedge detect interrupt. |
| 5   | ĸw   | 0.00               | 1'b0: disable                                 |
|     |      |                    | 1'b1: enable                                  |
|     |      |                    | otg0_bvalid_pos_irq_en                        |
| 2   | RW   | 0x0                | Enable OTG 0 bvalid posedge detect interrupt. |
| 2   | ĸvv  |                    | 1'b0: disable                                 |
|     |      |                    | 1'b1: enable                                  |
|     |      | W 0x0              | host0_linestate_irq_en                        |
| 1   |      |                    | Enable host 0 linesate detect interrupt.      |
| L   | RW   |                    | 1'b0: disable                                 |
|     |      |                    | 1'b1: enable                                  |
|     |      |                    | otg0_linestate_irq_en                         |
| 0   | DW   | W 0×0              | Enable OTG 0 linesate detect interrupt.       |
| 0   | K VV |                    | 1'b0: disable                                 |
|     |      |                    | 1'b1: enable                                  |

# **DETECT\_GRF\_USB2\_DETECT\_IRQ\_STATUS** Address: Operational Base + offset (0x0024)

| Bit   | Attr | <b>Reset Value</b> | Description                                 |
|-------|------|--------------------|---------------------------------------------|
| 31:10 | RO   | 0x0                | reserved                                    |
|       |      |                    | host0_disconnect_neg_irq                    |
| 9     | RO   | 0x0                | Host 0 disconnect negedge interrupt status. |
| 9     | кU   | 0.00               | 1'b0: no irq                                |
|       |      |                    | 1'b1: irq asserted                          |
|       |      |                    | host0_disconnect_pos_irq                    |
| 8     | RO   | 0x0                | Host 0 disconnect posedge interrupt status. |
| 0     | кU   | UXU                | 1'b0: no irq                                |
|       |      |                    | 1'b1: irq asserted                          |
|       |      |                    | otg0_disconnect_neg_irq                     |
| 7     | RO   | 0×0                | OTG 0 disconnect negedge interrupt status.  |
| /     | кU   |                    | 1'b0: no irq                                |
|       |      |                    | 1'b1: irq asserted                          |
|       |      |                    | otg0_disconnect_pos_irq                     |
| 6     | RO   | 0x0                | OTG 0 disconnect posedge interrupt status.  |
| 0     | κυ   |                    | 1'b0: no irq                                |
|       |      |                    | 1'b1: irq asserted                          |
|       |      |                    | otg0_id_neg_irq                             |
| 5     | RO   | 0x0                | OTG 0 id negedge interrupt status.          |
| J     | κυ   |                    | 1'b0: no irq                                |
|       |      |                    | 1'b1: irq asserted                          |
|       |      |                    | otg0_id_pos_irq                             |
| 4     | RO   | 0×0                | OTG 0 id posedge interrupt status.          |
| 4     | ĸu   |                    | 1'b0: no irq                                |
|       |      |                    | 1'b1: irq asserted                          |

| Bit | Attr | <b>Reset Value</b> | Description                               |
|-----|------|--------------------|-------------------------------------------|
|     |      |                    | otg0_bvalid_neg_irq                       |
| 3   | RO   | 0x0                | OTG 0 bvalid negedge interrupt status.    |
| 5   | RU   | 0.00               | 1'b0: no irq                              |
|     |      |                    | 1'b1: irq asserted                        |
|     |      |                    | otg0_bvalid_pos_irq                       |
| 2   | RO   | Ox0                | OTG 0 bvalid posedge interrupt status.    |
| 2   | RU   |                    | 1'b0: no irq                              |
|     |      |                    | 1'b1: irq asserted                        |
|     |      | 0x0                | host0_linestate_irq                       |
| 1   | RO   |                    | Host 0 linestate change interrupt status. |
|     | RU   |                    | 1'b0: no irq                              |
|     |      |                    | 1'b1: irq asserted                        |
|     |      |                    | otg0_linestate_irq                        |
| 0   | DO   | 0×0                | OTG 0 linestate change interrupt status.  |
|     | RU   |                    | 1'b0: no irq                              |
|     |      |                    | 1'b1: irq asserted                        |

# **DETECT GRF\_USB2\_DETECT\_IRQ\_STATUS\_CLR** Address: Operational Base + offset (0x0028)

| Bit   | Attr | <b>Reset Value</b> | Description                  |
|-------|------|--------------------|------------------------------|
| 31:10 | RO   | 0x0                | reserved                     |
|       |      |                    | host0_disconnect_neg_irq_clr |
| 9     | wo   | 0x0                | Interrupt status clear.      |
| 9     | **0  | 0.00               | 1'b0: hold status, no action |
|       |      |                    | 1'b1: clear interrupt status |
|       |      |                    | host0_disconnect_pos_irq_clr |
| 8     | wo   | 0x0                | Interrupt status clear.      |
| 0     | **0  | 0.00               | 1'b0: hold status, no action |
|       |      |                    | 1'b1: clear interrupt status |
|       |      |                    | otg0_disconnect_neg_irq_clr  |
| 7     | wo   | 0×0                | Interrupt status clear.      |
| /     | 000  |                    | 1'b0: hold status, no action |
|       |      |                    | 1'b1: clear interrupt status |
|       |      | O 0x0              | otg0_disconnect_pos_irq_clr  |
| 6     | wo   |                    | Interrupt status clear.      |
| 0     | ***  |                    | 1'b0: hold status, no action |
|       |      |                    | 1'b1: clear interrupt status |
|       |      |                    | otg0_id_neg_irq_clr          |
| 5     | wo   | 0x0                | Interrupt status clear.      |
| 5     | ***  | 0.00               | 1'b0: hold status, no action |
|       |      |                    | 1'b1: clear interrupt status |
|       |      |                    | otg0_id_pos_irq_clr          |
| 4     | wo   | 0x0                | Interrupt status clear.      |
| -     | **0  | 0.0                | 1'b0: hold status, no action |
|       |      |                    | 1'b1: clear interrupt status |

| Bit | Attr | <b>Reset Value</b> | Description                  |
|-----|------|--------------------|------------------------------|
|     |      |                    | otg0_bvalid_neg_irq_clr      |
| 3   | wo   | 0x0                | Interrupt status clear.      |
| 5   | 000  | 0.00               | 1'b0: hold status, no action |
|     |      |                    | 1'b1: clear interrupt status |
|     |      |                    | otg0_bvalid_pos_irq_clr      |
| 2   | wo   | 0x0                | Interrupt status clear.      |
| 2   | 000  |                    | 1'b0: hold status, no action |
|     |      |                    | 1'b1: clear interrupt status |
|     |      | /O 0x0             | host0_linestate_irq_clr      |
| 1   | wo   |                    | Interrupt status clear.      |
| 1   | 000  |                    | 1'b0: hold status, no action |
|     |      |                    | 1'b1: clear interrupt status |
|     |      |                    | otg0_linestate_irq_clr       |
| 0   | wo   | /O 0x0             | Interrupt status clear.      |
|     | 100  |                    | 1'b0: hold status, no action |
|     |      |                    | 1'b1: clear interrupt status |

## 30.4.8 CORE GRF Registers Summary

| Name                 | Offset   | Size | Reset<br>Value                          | Description                     |
|----------------------|----------|------|-----------------------------------------|---------------------------------|
| CORE GRF CA35 PEFF C | 0x0000   | w    | 0x00000000                              | CA35 performance monitor        |
| <u>ON0</u>           | 00000    | vv   | 0x00000000                              | control register0               |
| CORE_GRF_CA35_PEFF_C | 0x0004   | w    | 0x00000000                              | CA35 performance monitor        |
| <u>ON1</u>           | 0X0004   | vv   | 0x00000000                              | control register1               |
| CORE_GRF_CA35_PEFF_C | 0x0008   | w    | 0x00000000                              | CA35 performance monitor        |
| <u>ON2</u>           | 0X0008   | vv   | 0x00000000                              | control register2               |
| CORE GRF CA35 PEFF C | 0x000c   | w    | 0x00000000                              | CA35 performance monitor        |
| <u>ON3</u>           | 00000    | vv   | 0x00000000                              | control register3               |
| CORE GRF CA35 PEFF C | 0x0010   | w    | 0x00000000                              | CA35 performance monitor        |
| <u>ON4</u>           | 0X0010   | vv   | 0x00000000                              | control register4               |
| CORE_GRF_CA35_PEFF_C | 0x0014   | w    | 0x00000000                              | CA35 performance monitor        |
| <u>ON5</u>           | 0X0014   | vv   | 0x00000000                              | control register5               |
| CORE_GRF_CA35_PEFF_C | 0x0018   | w    | 0x00000000                              | CA35 performance monitor        |
| <u>ON6</u>           | 0X0010   | vv   | 0,00000000                              | control register6               |
| CORE GRF CA35 PEFF C | 0x001c   | w    | 0x00000000                              | CA35 performance monitor        |
| <u>ON7</u>           | 0,0010   | vv   | 0.00000000                              | control register7               |
| CORE GRF CA35 PEFF C | 0x0020   | w    | 0x00000000                              | CA35 performance monitor        |
| <u>ON8</u>           | 0X0020   | vv   | 0x00000000                              | control register8               |
| CORE_GRF_CA35_PERF_R | 0x0030   | w    | 0x00000000                              | CA35 performance monitor status |
| D MAX LATENCY NUM    | 070030   | vv   | 0.00000000                              | register                        |
| CORE_GRF_CA35_PERF_R | 0x0034   | w    | 0x00000000                              | CA35 performance monitor status |
| D LATENCY SAMP NUM   | 0,000,04 | vv   | 0,0000000000000000000000000000000000000 | register                        |

| Name                    | Offset | Size | Reset<br>Value | Description                     |
|-------------------------|--------|------|----------------|---------------------------------|
| CORE_GRF_CA35_PERF_R    | 0x0038 | w    | 0x00000000     | CA35 performance monitor status |
| D LATENCY ACC NUM       | 0X0038 | vv   | 0x00000000     | register                        |
| CORE_GRF_CA35_PERF_R    | 0x003c | w    | 0x00000000     | CA35 performance monitor status |
| <u>D AXI TOTAL BYTE</u> | 0X003C | vv   | 0x00000000     | register                        |
| CORE GRF CA35 PERF      | 0x0040 | \\/  | 0,00000000     | CA35 performance monitor status |
| WR_AXI_TOTAL_BYTE       | 0X0040 | W    | 0x00000000     | register                        |
| CORE GRF CA35 PERF      | 0x0044 | W    | 0x00000000     | CA35 performance monitor status |
| WORKING CNT             |        |      |                | register                        |
| CORE GRF CA35 PERF I    | 0,0049 | \\/  | 0,00000000     | CA35 performance monitor status |
| <u>NT_STATUS</u>        | 0x0048 | W    | 0x00000000     | register                        |
| CORE GRF COREPVTM C     | 0x0080 | 14/  | 000000000      | CODE DVTM control register0     |
| <u>ON0</u>              | 00000  | W    | 0x00000000     | CORE PVTM control register0     |
| CORE GRF COREPVTM C     | 0,0004 | 14/  | 0,00000000     | CODE DUTIL control register1    |
| ON1                     | 0x0084 | W    | 0x00000000     | CORE PVTM control register1     |
| CORE GRF COREPVTM S     | 0,0000 | \\/  | 0,0000000      |                                 |
| TATUS0                  | 0x0088 | W    | 0x00000000     | CORE PVTM status register0      |
| CORE_GRF_COREPVTM_S     | 0,0000 | \\/  | 0,0000000      |                                 |
| TATUS1                  | 0x008c | W    | 0x00000000     | CORE PVTM status register1      |

Notes: <u>Size</u>: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

## 30.4.9 CORE GRF Detail Register Description

## CORE GRF CA35 PEFF CONO

Address: Operational Base + offset (0x0000)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |  |  |
|-------|------|--------------------|-------------------------------------------------------|--|--|
|       |      |                    | write_enable                                          |  |  |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |  |  |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |  |  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |  |  |
| 51.10 | WU   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |  |  |
|       |      |                    |                                                       |  |  |
|       |      |                    | When bit 31=1, bit 15 can be written by software.     |  |  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |  |  |
| 15    | RW   | N 0x0              | ca35_sw_rd_latency_id_range_e                         |  |  |
| 15    |      |                    | AXI read channel id for latency AXI_PERFormance test. |  |  |
| 14    | RO   | 0x0                | reserved                                              |  |  |
|       |      |                    | ca35_sw_rd_latency_id                                 |  |  |
|       |      |                    | 6'h0: 16-Byte align                                   |  |  |
| 13:8  | RW   | W 0×00             | 6'h1: 32-Byte align                                   |  |  |
|       |      |                    | 6'h2: 64-Byte align                                   |  |  |
|       |      |                    | 6'h3: 128-Byte align                                  |  |  |

| Bit | Attr  | Reset Value | Description                                   |
|-----|-------|-------------|-----------------------------------------------|
|     |       |             | ca35_sw_ddr_align_type                        |
| 7:6 | RW    | 0x0         | axi_perf counter id control.                  |
| 7.0 | K VV  | 0.00        | 2'b0: count all write channel id              |
|     |       |             | 2'b1: count sw_ar_count_id write channel only |
|     |       |             | ca35_sw_aw_cnt_id_type                        |
| 5   | RW    | 0x0         | axi_perf counter id control.                  |
| 5   | L A A | 0.00        | 1'b0: count all write channel id              |
|     |       |             | 1'b1: count sw_aw_count_id read channel only  |
|     |       |             | ca35_sw_ar_cnt_id_type                        |
| 4   | RW    | 0×0         | axi_perf counter id control.                  |
| 4   | r vv  | UXU         | 1'b0: count all read channel id               |
|     |       |             | 1'b1: count sw_ar_count_id read channel only  |
|     |       | 0×0         | ca35_sw_axi_cnt_type_wrap                     |
| 3   | RW    |             | axi_perf counter type wrap.                   |
| 5   | r vv  |             | 1'b0: no wrap test                            |
|     |       |             | 1'b1: wrap test                               |
|     |       | 0×0         | ca35_sw_axi_cnt_type                          |
| 2   | RW    |             | axi_perf counter type.                        |
| 2   | L AN  |             | 1'b0: axi transfer test                       |
|     |       |             | 1'b1: ddr align transfer test                 |
|     |       |             | ca35_sw_axi_perf_clr                          |
| 1   | RW    | 0x0         | axi_perf clear bit.                           |
| 1   | L AN  | 0.00        | 1'b0: disable                                 |
|     |       |             | 1'b1: enable                                  |
|     |       |             | ca35_sw_axi_perf_work                         |
| 0   | RW    | / 0x0       | axi_perf enable bit.                          |
| 0   | r. vv |             | 1'b0: disable                                 |
|     |       |             | 1'b1: enable                                  |

Address: Operational Base + offset (0x0004)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|-------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 31:16 | WO   | 0×0000             | <ul> <li>write_enable</li> <li>When bit 16=1, bit 0 can be written by software.</li> <li>When bit 16=0, bit 0 can not be written by software.</li> <li>When bit 17=1, bit 1 can be written by software.</li> <li>When bit 17=0, bit 1 can not be written by software.</li> <li>When bit 31=1, bit 15 can be written by software.</li> <li>When bit 31=0, bit 15 can not be written by software.</li> </ul> |  |  |  |  |  |
| 15:12 | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| 11:0  | RW   | 0×000              | ca35_sw_rd_latency_thr<br>AXI read channel id for latency AXI_PERFormance test.                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |

Address: Operational Base + offset (0x0008)

| Bit   |    | Reset Value | Description                                             |
|-------|----|-------------|---------------------------------------------------------|
|       | /  |             | write_enable                                            |
|       |    |             | When bit $16=1$ , bit 0 can be written by software.     |
|       |    |             |                                                         |
|       |    |             | When bit 16=0, bit 0 can not be written by software.    |
| 31:16 | WO | 0x0000      | When bit 17=1, bit 1 can be written by software.        |
|       |    |             | When bit 17=0, bit 1 can not be written by software.    |
|       |    |             |                                                         |
|       |    |             | When bit $31=1$ , bit 15 can be written by software.    |
|       |    |             | When bit 31=0, bit 15 can not be written by software.   |
|       |    |             | ca35_sw_axi_perf_int_clr                                |
| 15    | RW | 0x0         | Interrupt clear.                                        |
| 15    |    |             | 1'b1: clear                                             |
|       |    |             | 1'b0: no op                                             |
|       |    |             | ca35_sw_axi_perf_int_e                                  |
| 1.4   |    | 0.40        | Interrupt enable.                                       |
| 14    | RW | / 0x0       | 1'b1: enable                                            |
|       |    |             | 1'b0: disable                                           |
| 13    | RO | 0x0         | reserved                                                |
|       |    |             | ca35_sw_aw_count_id                                     |
| 12:8  | RW | 0x00        | When sw_aw_cnt_id_type=1, only count the sw_aw_count_id |
|       |    |             | channel.                                                |
| 7:6   | RO | 0x0         | reserved                                                |
|       |    |             | ca35_sw_ar_count_id                                     |
| 5:0   | RW | 0x00        | When sw_ar_cnt_id_type=1, only count the sw_ar_count_id |
|       |    |             | channel.                                                |

## CORE GRF CA35 PEFF CON3

Address: Operational Base + offset (0x000c)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                                                                |
|-------|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | wo   | 0×0000             | <pre>write_enable When bit 16=1, bit 0 can be written by software. When bit 16=0, bit 0 can not be written by software. When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 can not be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 can not be written by software.</pre> |
| 15    | RW   | 0×0                | ca35_sw_ar_mon_id<br>mon_id_bmsk bit control.                                                                                                                                                                                                                                                                                              |
| 14    | RW   | 0x0                | ca35_sw_ar_mon_id_bmsk<br>mon_id_bmsk bit control.                                                                                                                                                                                                                                                                                         |
| 13    | RO   | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                   |
| 12:8  | RW   | 0×00               | ca35_sw_ar_mon_id_type<br>mon_id_type bit control.                                                                                                                                                                                                                                                                                         |

| Bit | Attr | <b>Reset Value</b> | Description             |
|-----|------|--------------------|-------------------------|
| 7:6 | RO   | 0x0                | reserved                |
| 5:0 | RW   | SW 10x00           | ca35_sw_ar_mon_id_msk   |
| 5.0 |      |                    | mon_id_msk bit control. |

Address: Operational Base + offset (0x0010)

| Bit   | Attr | <b>Reset Value</b> | Description                                           |
|-------|------|--------------------|-------------------------------------------------------|
|       |      |                    | write_enable                                          |
|       |      |                    | When bit 16=1, bit 0 can be written by software.      |
|       |      |                    | When bit 16=0, bit 0 can not be written by software.  |
| 31:16 | wo   | 0x0000             | When bit 17=1, bit 1 can be written by software.      |
| 51.10 | WU   | 0x0000             | When bit 17=0, bit 1 can not be written by software.  |
|       |      |                    |                                                       |
|       |      |                    | When bit $31=1$ , bit 15 can be written by software.  |
|       |      |                    | When bit 31=0, bit 15 can not be written by software. |
| 15    | RW   | 0x0                | ca35_sw_aw_mon_id                                     |
| 13    | ĸvv  |                    | mon_id_bmsk bit control.                              |
| 14    | RW   | W 0×0              | ca35_sw_aw_mon_id_bmsk                                |
| 14    |      |                    | mon_id_bmsk bit control.                              |
| 13    | RO   | 0x0                | reserved                                              |
| 12:8  | RW   |                    | ca35_sw_aw_mon_id_type                                |
| 12.0  | RVV  | 0x00               | mon_id_type bit control.                              |
| 7:6   | RO   | 0x0                | reserved                                              |
| 5:0   | DW   | 0x00               | ca35_sw_aw_mon_id_msk                                 |
| 5.0   | RW   | 0,00               | mon_id_msk bit control.                               |

## CORE GRF CA35 PEFF CON5

Address: Operational Base + offset (0x0014)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:0 | RW   | 0x000000000        | ca35_sw_araddr_mon_st<br>Monitor read start address. |

## CORE\_GRF\_CA35\_PEFF\_CON6

Address: Operational Base + offset (0x0018)

| Bit  | Attr | <b>Reset Value</b> | Description               |  |
|------|------|--------------------|---------------------------|--|
| 21.0 | RW   | 10x00000000        | a35_sw_araddr_mon_end     |  |
| 31:0 |      |                    | lonitor read end address. |  |

## CORE GRF CA35 PEFF CON7

Address: Operational Base + offset (0x001c)

| Bit  | Attr | <b>Reset Value</b> | Description                  |
|------|------|--------------------|------------------------------|
| 31.0 | RW   | 10x00000000        | ca35_sw_awaddr_mon_st        |
| 31:0 | RW   |                    | Monitor write start address. |

Address: Operational Base + offset (0x0020)

| Bit  | Attr | <b>Reset Value</b> | Description                                          |
|------|------|--------------------|------------------------------------------------------|
| 31:0 | RW   | 0_00000000         | ca35_sw_awaddr_mon_end<br>Monitor write end address. |

## CORE GRF CA35 PERF RD MAX LATENCY NUM

Address: Operational Base + offset (0x0030)

| Bit   | Attr | <b>Reset Value</b> | Description                                      |
|-------|------|--------------------|--------------------------------------------------|
| 31:13 | RO   | 0x0                | reserved                                         |
| 12:0  | RO   | UX0000             | rd_max_latency_r<br>AXI read max latency output. |

## CORE GRF CA35 PERF RD LATENCY SAMP NUM

Address: Operational Base + offset (0x0034)

| Bit   | Attr | <b>Reset Value</b> | Description                           |
|-------|------|--------------------|---------------------------------------|
| 31:27 | RO   | 0x0                | reserved                              |
| 26:0  | PO   | )  0x0000000       | rd_latency_samp_r                     |
| 26:0  | RO   |                    | AXI read latency total sample number. |

### CORE GRF CA35 PERF RD LATENCY ACC NUM

Address: Operational Base + offset (0x0038)

| Bit  | Attr | <b>Reset Value</b> | Description                                         |
|------|------|--------------------|-----------------------------------------------------|
| 21.0 | RO   | 0x00000000         | rd_latency_acc_cnt_r                                |
| 31:0 |      |                    | AXI read latency (>sw_rd_latency_thr) total number. |

## CORE GRF CA35 PERF RD AXI TOTAL BYTE

 

 Address: Operational Base + offset (0x003c)

 Bit
 Attr
 Reset Value
 Description

 31:0
 RO
 0x00000000
 rd\_axi\_total\_byte AXI active total read bytes/ddr align read bytes.

## CORE GRF CA35 PERF WR AXI TOTAL BYTE

Address: Operational Base + offset (0x0040)

| Bit  | Attr | <b>Reset Value</b> | Description                                                              |
|------|------|--------------------|--------------------------------------------------------------------------|
| 31:0 | RO   | 02000000000        | wr_axi_total_byte<br>AXI active total write bytes/ddr align write bytes. |

### CORE GRF CA35 PERF WORKING CNT Address: Operational Base + offset (0x0044)

|      |    | Reset Value | Description                       |
|------|----|-------------|-----------------------------------|
| 31:0 | RO | 0x000000000 | working_cnt_r<br>Working counter. |

## CORE GRF CA35 PERF INT STATUS

Address: Operational Base + offset (0x0048)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                          |
|-------|------|--------------------|--------------------------------------------------------------------------------------|
| 31    | RO   | 0x0                | reserved                                                                             |
| 30:24 | RO   | 0×00               | a35_aw_mon_axi_id_status<br>The ID be monitored read from the specific address area. |
| 23:17 | RO   | 0x0                | reserved                                                                             |
| 16    | RO   | 0x0                | a35_aw_mon_axi_hit_flag<br>Write from the specific address area interrupt status.    |
| 15    | RO   | 0x0                | reserved                                                                             |
| 14:8  | RO   | 0×00               | a35_ar_mon_axi_id_status<br>The ID be monitored read from the specific address area. |
| 7:1   | RO   | 0x0                | reserved                                                                             |
| 0     | RO   | 0×0                | a35_ar_mon_axi_hit_flag<br>Read from the specific address area interrupt status.     |

### CORE GRF COREPVTM CONO

Address: Operational Base + offset (0x0080)

| Bit   | Attr | <b>Reset Value</b> | Description                                                                                                                                                                                                                                                                                   |
|-------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 |      | 0×0000             | write_enable<br>When bit 16=1, bit 0 can be written by software.<br>When bit 16=0, bit 0 can not be written by software.<br>When bit 17=1, bit 1 can be written by software.<br>When bit 17=0, bit 1 can not be written by software.<br><br>When bit 31=1, bit 15 can be written by software. |
| 15:4  | RO   | 0x0                | When bit 31=0, bit 15 can not be written by software. reserved                                                                                                                                                                                                                                |
| 3:2   | RW   | 0×0                | corepvtm_osc_sel<br>osc_ring selection.<br>2'b00: osc_ring 0<br>2'b01: osc_ring 1<br>2'b10: osc_ring 2<br>Others: reserved                                                                                                                                                                    |
| 1     | RW   | 0x0                | corepvtm_osc_en<br>Set high to enable the osc_ring in the PVTM.                                                                                                                                                                                                                               |
| 0     | RW   | 0x0                | corepvtm_start<br>Set high to start pmu PVTM.                                                                                                                                                                                                                                                 |

### **<u>CORE GRF COREPVTM CON1</u>** Address: Operational Base + offset (0x0084)

| Addres | Address: Operational Base + offset (0x0084) |                    |                               |  |
|--------|---------------------------------------------|--------------------|-------------------------------|--|
| Bit    | Attr                                        | <b>Reset Value</b> | Description                   |  |
| 31:0   | RW                                          | 10x000000000       | corepvtm_cal_cnt              |  |
| 51.0   |                                             |                    | PMU pvtm calculation counter. |  |

## CORE GRF COREPVTM STATUSO

Address: Operational Base + offset (0x0088)

| Bit  | Attr | <b>Reset Value</b> | Description                                                         |
|------|------|--------------------|---------------------------------------------------------------------|
| 31:1 | RO   | 0x0                | reserved                                                            |
| 0    | RW   | ()X()              | corepvtm_freq_done<br>High indicates pmu pvtm frequency count done. |

## CORE GRF COREPVTM STATUS1

Address: Operational Base + offset (0x008c)

| Bit  | Attr | <b>Reset Value</b>                           | Description                                                            |
|------|------|----------------------------------------------|------------------------------------------------------------------------|
| 31:0 | RW   | $() \vee () \cap () \cap () \cap () \cap ()$ | corepvtm_freq_cnt<br>Indicates the cycle counts of the osc ring clock. |

## **30.5 Interface Description**

NA

## **30.6 Application Notes**

NA