

***Rockchip*  
*RV1106***  
***Technical Reference Manual***

**Revision History**

| Date       | Revision | Description                                      |
|------------|----------|--------------------------------------------------|
| 2022-03-24 | 0.3      | Update Chapter CRU, GRF, MCU Subsystem and TSADC |
| 2022-02-18 | 0.2      | Update Chapter 4 General Register Files          |
| 2022-01-27 | 0.1      | Initial Release                                  |

## Table of Content

|                                                  |     |
|--------------------------------------------------|-----|
| Table of Content .....                           | 2   |
| Figure Index .....                               | 6   |
| Table Index.....                                 | 9   |
| Warranty Disclaimer.....                         | 11  |
| Chapter 1 System Overview.....                   | 12  |
| 1.1 Address Mapping.....                         | 12  |
| 1.2 System Boot.....                             | 14  |
| 1.3 System Interrupt Connection .....            | 14  |
| 1.4 System DMA Hardware Request Connection ..... | 15  |
| Chapter 2 Clock & Reset Unit (CRU) .....         | 17  |
| 2.1 Overview .....                               | 17  |
| 2.2 Block Diagram .....                          | 17  |
| 2.3 Function Description .....                   | 17  |
| 2.4 CRU Register Description.....                | 21  |
| 2.5 CORECRU Register Description .....           | 62  |
| 2.6 DDRCRU Register Description.....             | 70  |
| 2.7 SUBDDRCRU Register Description .....         | 73  |
| 2.8 NPUCRU Register Description .....            | 75  |
| 2.9 PERICRU Register Description .....           | 79  |
| 2.10 PMUCRU Register Description .....           | 99  |
| 2.11 VEPUCRU Register Description .....          | 106 |
| 2.12 VICRU Register Description .....            | 113 |
| 2.13 VOCRU Register Description .....            | 122 |
| 2.14 Application Notes.....                      | 131 |
| Chapter 3 System Debug .....                     | 137 |
| 3.1 Overview .....                               | 137 |
| 3.2 Block Diagram .....                          | 137 |
| 3.3 Function Description .....                   | 137 |
| 3.4 Register Description.....                    | 137 |
| 3.5 Interface Description .....                  | 137 |
| Chapter 4 General Register Files (GRF) .....     | 139 |
| 4.1 Overview .....                               | 139 |
| 4.2 Function Description .....                   | 139 |
| 4.3 PERI_GRF Register Description .....          | 139 |
| 4.4 VENC_GRF Register Description.....           | 157 |
| 4.5 NPU_GRF Register Description.....            | 159 |
| 4.6 PMU_GRF Register Description .....           | 160 |
| 4.7 DDR_GRF Register Description .....           | 169 |
| 4.8 CORE_GRF Register Description.....           | 174 |
| 4.9 VI_GRF Register Description .....            | 178 |
| 4.10 VO_GRF Register Description .....           | 184 |
| 4.11 GPIO0_IOC Register Description .....        | 190 |
| 4.12 GPIO1_IOC Register Description .....        | 197 |
| 4.13 GPIO2_IOC Register Description .....        | 217 |
| 4.14 GPIO3_IOC Register Description .....        | 227 |
| 4.15 GPIO4_IOC Register Description .....        | 242 |
| Chapter 5 Cortex-A7.....                         | 256 |
| 5.1 Overview .....                               | 256 |
| 5.2 Block Diagram .....                          | 256 |
| 5.3 Function Description .....                   | 256 |
| 5.4 Register Description.....                    | 256 |

|                                                  |     |
|--------------------------------------------------|-----|
| Chapter 6 Embedded SRAM .....                    | 257 |
| 6.1 Overview .....                               | 257 |
| 6.2 Block Diagram .....                          | 257 |
| 6.3 Function Description .....                   | 257 |
| Chapter 7 PMU .....                              | 258 |
| 7.1 Overview .....                               | 258 |
| 7.2 Block Diagram .....                          | 258 |
| 7.3 Function Description .....                   | 258 |
| 7.4 Register Description.....                    | 261 |
| 7.5 Interface Description .....                  | 279 |
| 7.6 Application Notes .....                      | 279 |
| Chapter 8 MCU Subsystem .....                    | 281 |
| 8.1 Overview .....                               | 281 |
| 8.2 Block Diagram .....                          | 281 |
| 8.3 Register Description.....                    | 282 |
| 8.4 Interface Description .....                  | 296 |
| 8.5 Application Notes .....                      | 296 |
| 8.6 Application Notes .....                      | 298 |
| Chapter 9 Timer.....                             | 299 |
| 9.1 Overview .....                               | 299 |
| 9.2 Block Diagram .....                          | 299 |
| 9.3 Function Description .....                   | 300 |
| 9.4 Register Description.....                    | 303 |
| 9.5 Application Notes .....                      | 309 |
| Chapter 10 DMA Controller (DMAC).....            | 310 |
| 10.1 Overview.....                               | 310 |
| 10.2 Block Diagram .....                         | 310 |
| 10.3 Function Description .....                  | 311 |
| 10.4 Register Description.....                   | 312 |
| 10.5 Timing Diagram.....                         | 359 |
| 10.6 Application Notes.....                      | 359 |
| Chapter 11 Temperature-Sensor ADC (TS-ADC) ..... | 366 |
| 11.1 Overview.....                               | 366 |
| 11.2 Block Diagram .....                         | 366 |
| 11.3 Function Description .....                  | 366 |
| 11.4 Register Description.....                   | 366 |
| 11.5 Application Notes.....                      | 373 |
| Chapter 12 Pulse Width Modulation (PWM) .....    | 375 |
| 12.1 Overview.....                               | 375 |
| 12.2 Block Diagram .....                         | 375 |
| 12.3 Function Description .....                  | 376 |
| 12.4 Register Description.....                   | 377 |
| 12.5 Interface Description.....                  | 395 |
| 12.6 Application Notes.....                      | 398 |
| Chapter 13 UART .....                            | 401 |
| 13.1 Overview.....                               | 401 |
| 13.2 Block Diagram .....                         | 401 |
| 13.3 Function Description .....                  | 402 |
| 13.4 Register Description.....                   | 404 |
| 13.5 Interface Description.....                  | 421 |
| 13.6 Application Notes.....                      | 425 |

|                                                              |     |
|--------------------------------------------------------------|-----|
| Chapter 14 GPIO.....                                         | 429 |
| 14.1 Overview.....                                           | 429 |
| 14.2 Block Diagram .....                                     | 429 |
| 14.3 Function Description .....                              | 429 |
| 14.4 Register Description.....                               | 431 |
| 14.5 Interface Description.....                              | 439 |
| 14.6 Application Notes.....                                  | 443 |
| Chapter 15 Inter-Integrated Circuit (I2C).....               | 444 |
| 15.1 Overview.....                                           | 444 |
| 15.2 Block Diagram .....                                     | 444 |
| 15.3 Function Description .....                              | 445 |
| 15.4 Register Description.....                               | 447 |
| 15.5 Interface Description.....                              | 456 |
| 15.6 Application Notes.....                                  | 458 |
| Chapter 16 I2S .....                                         | 461 |
| 16.1 Overview.....                                           | 461 |
| 16.2 Block Diagram .....                                     | 461 |
| 16.3 Function Description .....                              | 462 |
| 16.4 Register Description.....                               | 467 |
| 16.5 Interface Description.....                              | 478 |
| 16.6 Application Notes.....                                  | 480 |
| Chapter 17 Digital Audio Codec .....                         | 481 |
| 17.1 Overview.....                                           | 481 |
| 17.2 Block Diagram .....                                     | 481 |
| 17.3 Function description.....                               | 482 |
| 17.4 Register Description.....                               | 482 |
| 17.5 Interface Description.....                              | 493 |
| 17.6 Application Notes.....                                  | 493 |
| Chapter 18 Flexible Serial Peripheral Interface (FSPI) ..... | 495 |
| 18.1 Overview.....                                           | 495 |
| 18.2 Block Diagram .....                                     | 495 |
| 18.3 Function Description .....                              | 496 |
| 18.4 Register Description.....                               | 496 |
| 18.5 Interface Description.....                              | 514 |
| 18.6 Application Notes.....                                  | 515 |
| Chapter 19 Gigabit Media Access Controller (GMAC) .....      | 519 |
| 19.1 Overview.....                                           | 519 |
| 19.2 Block Diagram .....                                     | 522 |
| 19.3 Function Description .....                              | 523 |
| 19.4 Register Description.....                               | 527 |
| 19.5 Application Note .....                                  | 627 |
| Chapter 20 SAR-ADC .....                                     | 652 |
| 20.1 Overview.....                                           | 652 |
| 20.2 Block Diagram .....                                     | 652 |
| 20.3 Function Description .....                              | 652 |
| 20.4 Register Description.....                               | 652 |
| 20.5 Application Notes.....                                  | 658 |
| Chapter 21 Audio Codec.....                                  | 659 |
| 21.1 Overview.....                                           | 659 |
| 21.2 Block Diagram .....                                     | 659 |
| 21.3 Function Description .....                              | 659 |

|                                                    |     |
|----------------------------------------------------|-----|
| 21.4 Register Description.....                     | 663 |
| 21.5 Interface Description.....                    | 681 |
| 21.6 Application Notes.....                        | 681 |
| Chapter 22 Mobile Storage Host Controller .....    | 685 |
| 22.1 Overview.....                                 | 685 |
| 22.2 Block Diagram .....                           | 685 |
| 22.3 Function Description .....                    | 687 |
| 22.4 Register Description.....                     | 706 |
| 22.5 Interface Description.....                    | 726 |
| 22.6 Application Notes.....                        | 728 |
| Chapter 23 Serial Peripheral Interface (SPI) ..... | 747 |
| 23.1 Overview.....                                 | 747 |
| 23.2 Block Diagram .....                           | 747 |
| 23.3 Function Description .....                    | 749 |
| 23.4 Register Description.....                     | 750 |
| 23.5 Interface Description.....                    | 758 |
| 23.6 Application Notes.....                        | 759 |
| Chapter 24 Real Time Clock (RTC) .....             | 762 |
| 24.1 Overview.....                                 | 762 |
| 24.2 Block Diagram .....                           | 762 |
| 24.3 Function Description .....                    | 762 |
| 24.4 Register Description.....                     | 763 |
| 24.5 Interface Description.....                    | 773 |
| 24.6 Application Notes.....                        | 773 |
| Chapter 25 DECOM.....                              | 775 |
| 25.1 Overview.....                                 | 775 |
| 25.2 Block Diagram .....                           | 775 |
| 25.3 Function Description .....                    | 775 |
| 25.4 Register Description.....                     | 777 |
| 25.5 Application Notes.....                        | 786 |
| Chapter 26 Video Capture (VICAP).....              | 787 |
| 26.1 Overview.....                                 | 787 |
| 26.2 Block Diagram .....                           | 787 |
| 26.3 Function Description .....                    | 788 |
| 26.4 Register Description.....                     | 793 |
| 26.5 Interface Description.....                    | 866 |
| 26.6 Application Notes.....                        | 867 |
| Chapter 27 Mailbox .....                           | 869 |
| 27.1 Overview.....                                 | 869 |
| 27.2 Block Diagram .....                           | 869 |
| 27.3 Function Description .....                    | 869 |
| 27.4 Register Description.....                     | 869 |
| 27.5 Application Notes.....                        | 873 |
| Chapter 28 Watchdog Timer (WDT).....               | 874 |
| 28.1 Overview.....                                 | 874 |
| 28.2 Block Diagram .....                           | 874 |
| 28.3 Function Description .....                    | 874 |
| 28.4 Register Description.....                     | 875 |

## Figure Index

|                                                                   |     |
|-------------------------------------------------------------------|-----|
| Fig. 2-1 CRU Block Diagram .....                                  | 17  |
| Fig. 2-2 Reset Architecture Diagram .....                         | 18  |
| Fig. 2-3 FRACPLL Block Diagram .....                              | 20  |
| Fig. 2-4 INTPLL Block Diagram .....                               | 21  |
| Fig. 2-5 PLL Start-up Operation .....                             | 132 |
| Fig. 2-6 PLL Config Change Operation.....                         | 132 |
| Fig. 2-7 PLL Bypass Operation .....                               | 132 |
| Fig. 3-1 Debug system structure.....                              | 137 |
| Fig. 3-2 DAP SWJ interface .....                                  | 138 |
| Fig. 3-3 SW-DP acknowledgement timing .....                       | 138 |
| Fig. 5-1 Core Subsystem Architecture.....                         | 256 |
| Fig. 6-1 Block Diagram of SRAM .....                              | 257 |
| Fig. 7-1 PMU Bock Diagram.....                                    | 258 |
| Fig. 8-1 Block Diagram of HP_MCU Subsystem.....                   | 282 |
| Fig. 9-1 Normal Timer Block Diagram .....                         | 299 |
| Fig. 9-2 HPTIMER Block Diagram .....                              | 300 |
| Fig. 9-3 Timer Usage Flow .....                                   | 301 |
| Fig. 9-4 Timing between timer_en and timer_clk.....               | 309 |
| Fig. 10-1 DMAC Block Diagram .....                                | 311 |
| Fig. 10-2 DMAC Operation State .....                              | 312 |
| Fig. 10-3 DMAC Request and Acknowledge Timing.....                | 359 |
| Fig. 11-1 TS-ADC Controller Block Diagram .....                   | 366 |
| Fig. 11-2 Timing diagram for TS-ADC .....                         | 373 |
| Fig. 12-1 PWM Block Diagram.....                                  | 375 |
| Fig. 12-2 PWM Capture Mode .....                                  | 376 |
| Fig. 12-3 PWM Continuous Left-aligned Output Mode .....           | 376 |
| Fig. 12-4 PWM Continuous Center-aligned Output Mode .....         | 377 |
| Fig. 12-5 PWM One-shot Center-aligned Output Mode .....           | 377 |
| Fig. 13-1 UART Architecture .....                                 | 401 |
| Fig. 13-2 UART Serial protocol .....                              | 402 |
| Fig. 13-3 UART baud rate.....                                     | 402 |
| Fig. 13-4 UART Auto flow control block diagram .....              | 403 |
| Fig. 13-5 UART AUTO RTS TIMING .....                              | 404 |
| Fig. 13-6 UART AUTO CTS TIMING .....                              | 404 |
| Fig. 13-7 UART none fifo mode .....                               | 425 |
| Fig. 13-8 UART fifo mode.....                                     | 426 |
| Fig. 13-9 UART0-UART2 clock generation .....                      | 427 |
| Fig. 13-10 UART3-UART5 clock generation .....                     | 427 |
| Fig. 14-1 GPIO Block Diagram .....                                | 429 |
| Fig. 15-1 I2C architecture.....                                   | 444 |
| Fig. 15-2 I2C DATA Validity .....                                 | 447 |
| Fig. 15-3 I2C Start and stop conditions.....                      | 447 |
| Fig. 15-4 I2C Acknowledge .....                                   | 447 |
| Fig. 15-5 I2C byte transfer.....                                  | 447 |
| Fig. 15-6 I2C Flow chat for transmit only mode.....               | 458 |
| Fig. 15-7 I2C Flow chat for receive only mode .....               | 459 |
| Fig. 15-8 I2C Flow chat for mix mode.....                         | 460 |
| Fig. 16-1 I2S/PCM/TDM Controller (8-channel) Block Diagram .....  | 461 |
| Fig. 16-2 I2S Transmitter-Master & Receiver-Slave Condition ..... | 462 |
| Fig. 16-3 I2S Transmitter-Slave & Receiver-Master Condition ..... | 462 |
| Fig. 16-4 I2S Normal Mode Timing Format .....                     | 463 |
| Fig. 16-5 I2S Left Justified Mode Timing Format.....              | 463 |
| Fig. 16-6 I2S Right Justified Mode Timing Format.....             | 463 |
| Fig. 16-7 PCM Early Mode Timing Format .....                      | 463 |
| Fig. 16-8 PCM Late1 Mode Timing Format .....                      | 464 |

---

|                                                                      |     |
|----------------------------------------------------------------------|-----|
| Fig. 16-9 PCM Late2 Mode Timing Format .....                         | 464 |
| Fig. 16-10 PCM Late3 Mode Timing Format.....                         | 464 |
| Fig. 16-11 TDM Normal Mode Timing Format (PCM Format) .....          | 465 |
| Fig. 16-12 TDM Left Shift Mode 0 Timing Format (PCM Format) .....    | 465 |
| Fig. 16-13 TDM Left Shift Mode 1 Timing Format (PCM Format) .....    | 465 |
| Fig. 16-14 TDM Left Shift Mode 2 Timing Format (PCM Format) .....    | 466 |
| Fig. 16-15 TDM Left Shift Mode 3 Timing Format (PCM Format) .....    | 466 |
| Fig. 16-16 TDM Normal Mode Timing Format (I2S Format) .....          | 466 |
| Fig. 16-17 TDM Left Justified Mode Timing Format (I2S Format).....   | 467 |
| Fig. 16-18 TDM Right Justified Mode Timing Format (I2S Format) ..... | 467 |
| Fig. 16-19 I2S/PCM/TDM Controller Transmit Operation Flow Chart..... | 480 |
| Fig. 17-1 Digital Audio Codec Block Diagram .....                    | 481 |
| Fig. 18-1 FSPI Architecture .....                                    | 495 |
| Fig. 18-2 Program Flow .....                                         | 515 |
| Fig. 18-3 Read Flow .....                                            | 516 |
| Fig. 18-4 Command with DMA Flow .....                                | 517 |
| Fig. 18-5 SPI mode.....                                              | 518 |
| Fig. 18-6 Idle cycles.....                                           | 518 |
| Fig. 19-1 GMAC Block Diagram .....                                   | 522 |
| Fig. 19-2 GMAC in SOC.....                                           | 522 |
| Fig. 19-3 Frame Format.....                                          | 523 |
| Fig. 19-4 RMII Transmission Bit Ordering .....                       | 523 |
| Fig. 19-5 Start of MII and RMII Transmission in 100-Mbps Mode.....   | 524 |
| Fig. 19-6 End of MII and RMII Transmission in 100-Mbps Mode .....    | 524 |
| Fig. 19-7 Start of MII and RMII Transmission in 10-Mbps Mode .....   | 524 |
| Fig. 19-8 End of MII and RMII Transmission in 10-Mbps Mode .....     | 524 |
| Fig. 19-9 RMII Receive Bit Ordering .....                            | 525 |
| Fig. 19-10 Descriptor Ring Structure .....                           | 627 |
| Fig. 19-11 RMII Clock Architecture When Clock Source From PHY .....  | 651 |
| Fig. 20-1 SAR-ADC Block Diagram.....                                 | 652 |
| Fig. 21-1 Audio Codec Block Diagram .....                            | 659 |
| Fig. 21-2 Left Justified Mode (assuming n-bit word length) .....     | 660 |
| Fig. 21-3 Right Justified Mode (assuming n-bit word length) .....    | 660 |
| Fig. 21-4 I2S Mode (assuming n-bit word length).....                 | 661 |
| Fig. 21-5 DSP/PCM Mode A (assuming n-bit word length) .....          | 661 |
| Fig. 21-6 DSP/PCM Mode B (assuming n-bit word length) .....          | 661 |
| Fig. 21-7 Microphone Input.....                                      | 662 |
| Fig. 22-1 Mobile Storage Host Control Block Diagram.....             | 686 |
| Fig. 22-2 SD/MMC Card-Detect Signal .....                            | 691 |
| Fig. 22-3 Host Controller Command Path State Machine .....           | 692 |
| Fig. 22-4 Host Controller Data Transmit State Machine.....           | 694 |
| Fig. 22-5 Host Controller Data Receive State Machine .....           | 696 |
| Fig. 22-6 Dual-Buffer Descriptor Structure .....                     | 702 |
| Fig. 22-7 Chain Descriptor Structure .....                           | 702 |
| Fig. 22-8 Descriptor Formats for 32-bit AHB Address Bus Width .....  | 702 |
| Fig. 22-9 Clock Generation Unit .....                                | 706 |
| Fig. 22-10 Host Controller Initialization Sequence .....             | 729 |
| Fig. 22-11 Voltage Switching Command Flow Diagram .....              | 737 |
| Fig. 22-12 ACMD41 Argument .....                                     | 737 |
| Fig. 22-13 ACMD41 Response(R3).....                                  | 738 |
| Fig. 22-14 Voltage Switch Normal Scenario .....                      | 738 |
| Fig. 22-15 Voltage Switch Error Scenario .....                       | 739 |
| Fig. 22-16 Card Detection Method 2 .....                             | 746 |
| Fig. 23-1 SPI Controller Block Diagram .....                         | 748 |
| Fig. 23-2 SPI Master and Slave Interconnection .....                 | 749 |
| Fig. 23-3 SPI Format (SCPH=0 SCPOL=0).....                           | 749 |
| Fig. 23-4 SPI Format (SCPH=0 SCPOL=1).....                           | 750 |

---

|                                                              |     |
|--------------------------------------------------------------|-----|
| Fig. 23-5 SPI Format (SCPH=1 SCPOL=0).....                   | 750 |
| Fig. 23-6 SPI Format (SCPH=1 SCPOL=1).....                   | 750 |
| Fig. 23-7 SPI Master transfer flow diagram.....              | 760 |
| Fig. 23-8 SPI Slave transfe .....                            | 761 |
| Fig. 24-1 RTC Block Diagram .....                            | 762 |
| Fig. 25-1 DECOM Block Diagram .....                          | 775 |
| Fig. 25-2 DECOM Data Flow .....                              | 777 |
| Fig. 26-1 VICAP Block Diagram.....                           | 787 |
| Fig. 26-2 BT656/BT1120 interlace timing relationship .....   | 788 |
| Fig. 26-3 BT656/BT1120 progressive timing relationship ..... | 788 |
| Fig. 26-4 BT656/BT1120 timing relationship .....             | 789 |
| Fig. 26-5 MIPI CSI RAW8 format.....                          | 789 |
| Fig. 26-6 MIPI CSI RAW10 format.....                         | 789 |
| Fig. 26-7 MIPI CSI RAW12 format.....                         | 789 |
| Fig. 26-8 MIPI CSI RAW14 format.....                         | 789 |
| Fig. 26-9 MIPI CSI YUV422 format .....                       | 789 |
| Fig. 26-10 LVDS RAW8 format.....                             | 790 |
| Fig. 26-11 LVDS RAW10 format .....                           | 790 |
| Fig. 26-12 LVDS RAW12 format .....                           | 790 |
| Fig. 26-13 Crop .....                                        | 791 |
| Fig. 26-14 8 times Scale down.....                           | 791 |
| Fig. 26-15 NV16 .....                                        | 792 |
| Fig. 26-16 NV12 .....                                        | 792 |
| Fig. 26-17 YUV400.....                                       | 793 |
| Fig. 26-18 YUYV .....                                        | 793 |
| Fig. 26-19 Compact RAW12 .....                               | 793 |
| Fig. 26-20 Noncompact RAW12(high align).....                 | 793 |
| Fig. 27-1 Mailbox Block Diagram.....                         | 869 |
| Fig. 28-1 WDT Block Diagram.....                             | 874 |
| Fig. 28-2 WDT Operation Flow (RMOD=1) .....                  | 875 |

## Table Index

|                                                               |     |
|---------------------------------------------------------------|-----|
| Table 1-1 Address Mapping .....                               | 12  |
| Table 1-2 Address Remapping .....                             | 13  |
| Table 1-3 RV1106 Interrupt Connection List.....               | 14  |
| Table 1-4 RV1106 DMAC Hardware Request Connection List.....   | 16  |
| Table 2-1 CRU Base Address.....                               | 17  |
| Table 2-2 RV1106 PLL Introduction.....                        | 19  |
| Table 2-3 BIU Clocks dependency .....                         | 136 |
| Table 3-1 DAP-Lite Interface Description .....                | 138 |
| Table 4-1 GRF Address Mapping Table.....                      | 139 |
| Table 7-1 Block Description Summary.....                      | 259 |
| Table 7-2 Interface Description .....                         | 279 |
| Table 7-3 PMU Debug Information Decode.....                   | 279 |
| Table 8-1 MCU Subsystem Configurations.....                   | 281 |
| Table 8-2 MCU Serial Wire Debug Interface Description .....   | 296 |
| Table 8-3 Address Map for the Cache RAM Debug .....           | 297 |
| Table 9-1 TIMER attribute .....                               | 309 |
| Table 10-1 DMAC Request Mapping Table .....                   | 310 |
| Table 10-2 Source Size in DMAC_CCRn .....                     | 364 |
| Table 10-3 DMAC Instruction Sets .....                        | 364 |
| Table 10-4 DMAC Instruction Encoding.....                     | 365 |
| Table 11-1 TS-ADC Start Timing .....                          | 373 |
| Table 11-2 TS-ADC Look up Table.....                          | 373 |
| Table 12-1 PWM Interface Description.....                     | 395 |
| Table 13-1 UART0 Interface Description .....                  | 421 |
| Table 13-2 UART1 Interface Description .....                  | 422 |
| Table 13-3 UART2 Interface Description .....                  | 422 |
| Table 13-4 UART3 Interface Description .....                  | 423 |
| Table 13-5 UART4 Interface Description .....                  | 423 |
| Table 13-6 UART5 Interface Description .....                  | 423 |
| Table 13-7 UART baud rate configuration.....                  | 428 |
| Table 14-1 GPIO Interface Description .....                   | 439 |
| Table 15-1 I2C Interface Description .....                    | 456 |
| Table 17-1 Digital Audio Codec Interface Description.....     | 493 |
| Table 18-1 FSPI Address Mapping .....                         | 496 |
| Table 18-2 FSPI Interface Description .....                   | 514 |
| Table 19-1 MDIO Clause 45 Frame Structure .....               | 525 |
| Table 19-2 MDIO Clause 22 Frame Structure .....               | 526 |
| Table 19-3 TDES0 Normal Descriptor (Read Format) .....        | 628 |
| Table 19-4 TDES1 Normal Descriptor (Read Format) .....        | 628 |
| Table 19-5 TDES2 Normal Descriptor (Read Format) .....        | 628 |
| Table 19-6 TDES3 Normal Descriptor (Read Format) .....        | 629 |
| Table 19-7 TDES0 Normal Descriptor (Write-Back Format).....   | 632 |
| Table 19-8 TDES1 Normal Descriptor (Write-Back Format).....   | 632 |
| Table 19-9 TDES2 Normal Descriptor (Write-Back Format).....   | 632 |
| Table 19-10 TDES2 Normal Descriptor (Write-Back Format) ..... | 632 |
| Table 19-11 TDES0 Context Descriptor .....                    | 640 |
| Table 19-12 TDES1 Context Descriptor .....                    | 640 |
| Table 19-13 TDES2 Context Descriptor .....                    | 640 |
| Table 19-14 TDES3 Context Descriptor .....                    | 640 |
| Table 19-15 TDES0 Normal Descriptor(Read Format) .....        | 642 |
| Table 19-16 TDES1 Normal Descriptor(Read Format) .....        | 642 |
| Table 19-17 TDES2 Normal Descriptor(Read Format) .....        | 642 |
| Table 19-18 TDES3 Normal Descriptor(Read Format) .....        | 642 |
| Table 19-19 TDES0 Normal Descriptor(Write-Back Format) .....  | 643 |
| Table 19-20 TDES1 Normal Descriptor(Write-Back Format) .....  | 643 |

---

|                                                                      |     |
|----------------------------------------------------------------------|-----|
| Table 19-21 TDES2 Normal Descriptor(Write-Back Format) .....         | 645 |
| Table 19-22 TDES3 Normal Descriptor(Write-Back Format) .....         | 647 |
| Table 19-23 TDES0 Context Descriptor .....                           | 649 |
| Table 19-24 TDES1 Context Descriptor .....                           | 649 |
| Table 19-25 TDES2 Context Descriptor .....                           | 650 |
| Table 19-26 TDES3 Context Descriptor .....                           | 650 |
| Table 21-1 Supported Data Formats in Different Modes .....           | 660 |
| Table 22-1 Bits in Interrupt Status Register .....                   | 688 |
| Table 22-2 Auto-Stop Generation .....                                | 697 |
| Table 22-3 Non-data Transfer Commands and Requirements .....         | 698 |
| Table 22-4 Bits in IDMAC DES0 Element.....                           | 702 |
| Table 22-5 Bits in IDMAC DES1 Element.....                           | 703 |
| Table 22-6 Bits in IDMAC DES2 Element.....                           | 703 |
| Table 22-7 Bits in IDMAC DES3 Element.....                           | 704 |
| Table 22-8 SDMMC Interface Description .....                         | 726 |
| Table 22-9 SDIO M0 Interface Description .....                       | 727 |
| Table 22-10 SDIO M1 Interface Description .....                      | 727 |
| Table 22-11 EMMC Interface Description .....                         | 727 |
| Table 22-12 Command Settings for No-Data Command .....               | 731 |
| Table 22-13 Command Setting for Single or Multiple-Block Read.....   | 733 |
| Table 22-14 Command Settings for Single or Multiple-Block Write..... | 734 |
| Table 22-15 PBL and Watermark Levels.....                            | 741 |
| Table 22-16 Configuration for SDMMC Variable Delay Usage.....        | 742 |
| Table 22-17 Configuration for SDIO Variable Delay Usage .....        | 743 |
| Table 22-18 Configuration for EMMC Variable Delay Usage .....        | 743 |
| Table 22-19 Register for SDMMC Card Detection Method 3.....          | 746 |
| Table 23-1 SPI0 Interface Description .....                          | 758 |
| Table 23-2 SPI1 Interface Description .....                          | 758 |
| Table 24-1 RTC Interface Description .....                           | 773 |
| Table 26-1 VICAP Address Mapping .....                               | 793 |
| Table 26-2 VICAP Interface Description .....                         | 866 |

## **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™ 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 © 2022 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

RV1106 boot from internal BootRom, which supports remap function by software programming. Remap is controlled by PMU\_SGRF\_SOC\_CON1[11:10]. When remap is set to 2'b01, the BootRom is un-accessible and PMU\_SRAM is mapped to address 0xFFFF0000. When remap is set to 2'b10, the BootRom is un-accessible and SYSTEM\_SRAM is mapped to address 0xFFFF0000.

Table 1-1 Address Mapping

| Module       | Start Address | Size  | Module             | Start Address | Size  |
|--------------|---------------|-------|--------------------|---------------|-------|
| PERI_GRF     | FF000000      | 64KB  | ACODEC PHY         | FF480000      | 64KB  |
| VENC_GRF     | FF010000      | 32KB  | PWM2               | FF490000      | 64KB  |
| NPU_GRF      | FF018000      | 32KB  | UART0              | FF4A0000      | 64KB  |
| PMU_GRF      | FF020000      | 64KB  | UART1              | FF4B0000      | 64KB  |
| DDR_GRF      | FF030000      | 64KB  | UART2              | FF4C0000      | 64KB  |
| CORE_GRF     | FF040000      | 64KB  | UART3              | FF4D0000      | 64KB  |
| VI_GRF       | FF050000      | 64KB  | UART4              | FF4E0000      | 64KB  |
| VO_GRF       | FF060000      | 32KB  | UART5              | FF4F0000      | 64KB  |
| RESERVED     | FF068000      | 32KB  | SPI0               | FF500000      | 64KB  |
| PERI_SGRF    | FF070000      | 8KB   | SPI1               | FF510000      | 64KB  |
| VI_SGRF      | FF072000      | 8KB   | DECOM              | FF520000      | 64KB  |
| NPU_SGRF     | FF074000      | 8KB   | GPIO1              | FF530000      | 32KB  |
| CPU_SGRF     | FF076000      | 8KB   | GPIO1_IOC          | FF538000      | 32KB  |
| RKVENC_SGRF  | FF078000      | 8KB   | GPIO2              | FF540000      | 32KB  |
| VO_SGRF      | FF07A000      | 8KB   | GPIO2_IOC          | FF548000      | 32KB  |
| RESERVED     | FF07C000      | 16KB  | GPIO3              | FF550000      | 32KB  |
| PMU_SGRF     | FF080000      | 64KB  | GPIO3_IOC          | FF558000      | 32KB  |
| RESERVED     | FF090000      | 448KB | GPIO4              | FF560000      | 32KB  |
| INTERCONNECT | FF100000      | 448KB | GPIO4_IOC          | FF568000      | 32KB  |
| RESERVED     | FF170000      | 320KB | RESERVED           | FF570000      | 64KB  |
| RTC          | FF1C0000      | 64KB  | TIMER_6CH          | FF580000      | 64KB  |
| RESERVED     | FF1D0000      | 128KB | STIMER_2CH         | FF590000      | 64KB  |
| GIC400       | FF1F0000      | 64KB  | WDTNS              | FF5A0000      | 64KB  |
| DEBUG        | FF200000      | 256KB | WDTS               | FF5B0000      | 64KB  |
| CORE_PVTM    | FF240000      | 64KB  | MAILBOX            | FF5C0000      | 64KB  |
| RESERVED     | FF250000      | 640KB | INTMUX             | FF5D0000      | 64KB  |
| TIMER_HP     | FF2F0000      | 64KB  | RESERVED           | FF5E0000      | 384KB |
| PMU          | FF300000      | 64KB  | MCU CACHE          | FF640000      | 64KB  |
| I2C0         | FF310000      | 64KB  | MCU CACHE RAM TEST | FF650000      | 64KB  |
| I2C1         | FF320000      | 64KB  | NPU                | FF660000      | 64KB  |
| RESERVED     | FF330000      | 64KB  | PMU_SRAM           | FF670000      | 64KB  |
| DSM          | FF340000      | 64KB  | NPU_CBUF           | FF680000      | 256KB |
| PWM0         | FF350000      | 64KB  | SYSTEM_SRAM        | FF6C0000      | 256KB |
| PWM1         | FF360000      | 64KB  | SYSTEM_SRAM_EXT    | FF700000      | 1MB   |
| PMU_WDT      | FF370000      | 32KB  | DDR CONTROLLER     | FF800000      | 64KB  |
| PMU_MAILBOX  | FF378000      | 32KB  | DDR_MONITOR        | FF810000      | 64KB  |

| Module      | Start Address | Size  | Module      | Start Address | Size  |
|-------------|---------------|-------|-------------|---------------|-------|
| GPIO0       | FF380000      | 32KB  | DDR_PHY     | FF820000      | 64KB  |
| GPIO0_IOC   | FF388000      | 32KB  | DDR_DFICTRL | FF830000      | 32KB  |
| PMU_PVTM    | FF390000      | 64KB  | DDR_HWLP    | FF838000      | 32KB  |
| PMU_CRU     | FF3A0000      | 64KB  | RESERVED    | FF840000      | 768KB |
| TOP_CRU     | FF3B0000      | 8KB   | DDR_SECURE  | FF900000      | 64KB  |
| PERI_CRU    | FF3B2000      | 8KB   | SHRM_SECURE | FF910000      | 64KB  |
| VI_CRU      | FF3B4000      | 8KB   | RESERVED    | FF920000      | 384KB |
| NPU_CRU     | FF3B6000      | 8KB   | RGA         | FF980000      | 64KB  |
| CORE_CRU    | FF3B8000      | 8KB   | VOP_LITE    | FF990000      | 64KB  |
| RKVENC_CRU  | FF3BA000      | 8KB   | SDIO        | FF9A0000      | 64KB  |
| VO_CRU      | FF3BC000      | 8KB   | RESERVED    | FF9B0000      | 320KB |
| DDR_CRU     | FF3BE000      | 4KB   | ISP         | FFA00000      | 64KB  |
| DDR_SUBCRU  | FF3BF000      | 4KB   | VICAP       | FFA10000      | 64KB  |
| SARADC_CON  | FF3C0000      | 32KB  | CSI2HOST0   | FFA20000      | 64KB  |
| TSADC_CON   | FF3C8000      | 32KB  | CSI2HOST1   | FFA30000      | 64KB  |
| OTP_NS_CTRL | FF3D0000      | 32KB  | RESERVED    | FFA40000      | 64KB  |
| OTP_S_CTRL  | FF3D8000      | 32KB  | RKVENC      | FFA50000      | 64KB  |
| OTG_APB     | FF3E0000      | 32KB  | VEPU_PP     | FFA60000      | 64KB  |
| CSI_PHY     | FF3E8000      | 32KB  | DVBM        | FFA70000      | 64KB  |
| RESERVED    | FF3F0000      | 32KB  | MAC         | FFA80000      | 64KB  |
| MAC_PHY     | FF3F8000      | 32KB  | EMMC        | FFA90000      | 64KB  |
| RESERVED    | FF400000      | 128KB | SDMMC       | FFAA0000      | 64KB  |
| DMAC        | FF420000      | 64KB  | RESERVED    | FFAB0000      | 64KB  |
| SDMAC       | FF430000      | 64KB  | FSPI        | FFAC0000      | 64KB  |
| CRYPTO      | FF440000      | 32KB  | RKIVE       | FFAD0000      | 64KB  |
| TRNG_NS     | FF448000      | 16KB  | I2S0_8CH    | FFAE0000      | 32KB  |
| TRNG_SEC    | FF44C000      | 16KB  | RESERVED    | FFAE8000      | 32KB  |
| I2C2        | FF450000      | 64KB  | RESERVED    | FFAF0000      | 64KB  |
| I2C3        | FF460000      | 64KB  | USB2        | FFB00000      | 1MB   |
| I2C4        | FF470000      | 64KB  | BOOTROM     | FFFF0000      | 64KB  |

The following table show the boot address when before remap and after remap

Table 1-2 Address Remapping

| remap[1:0]=2'b00 |                    | remap[1:0]=2'b01 |                    | remap[1:0]=2'b10 |                    |
|------------------|--------------------|------------------|--------------------|------------------|--------------------|
|                  |                    | not accessible   | BootRom(20KB)      | not accessible   | BootRom(20KB)      |
| 0xFFFF0000       | BootRom(20KB)      | 0xFFFF0000       | PMU_SRAM(8KB)      | 0xFFFF0000       | SYSTEM_SRAM(64KB)  |
| 0xFF670000       | PMU_SRAM(8KB)      | 0xFF670000       | PMU_SRAM(8KB)      | 0xFF670000       | PMU_SRAM(8KB)      |
| 0xFF6C0000       | SYSTEM_SRAM(256KB) | 0xFF6C0000       | SYSTEM_SRAM(256KB) | 0xFF6C0000       | SYSTEM_SRAM(256KB) |

## 1.2 System Boot

RV1106 provides system boot from off-chip devices such as SDMMC card, eMMC memory, Serial NAND or NOR flash. When boot code is not ready in these devices, also provide system code download into them by USB OTG or UART interface. All of the boot code will be stored in internal BootRom. The following is the whole boot procedure for boot code, which will be stored in BootRom in advance.

The following features are supported.

- Support system boot from the following device:
  - Serial NOR Flash, 1bit or 4bits data width (device layout in FSPI IO)
  - Serial NAND Flash, 1bit data width (device layout in FSPI IO)
  - eMMC Interface, 4bits or 8bits data width
  - SDMMC Card, 4bits data width
- Support system code download by USB OTG or UART

## 1.3 System Interrupt Connection

RV1106 provides a general interrupt controller (GIC) for CPU, which has 128 SPI (shared peripheral interrupts) interrupt sources. The triggered type for each SPI interrupt is high level sensitive, not programmable. The detailed interrupt sources connection is in the following table.

Table 1-3 RV1106 Interrupt Connection List

| Number   | Source         | Polarity   | Number | Source              | Polarity   |
|----------|----------------|------------|--------|---------------------|------------|
| 0-31 PPI |                | Low level  | 97     | dma_int2            | High level |
| 32       | cache_irq      | High level | 98     | dma_int3            | High level |
| 33       | mailbox_irq_ap | High level | 99     | dma_int4            | High level |
| 34       | mailbox_irq_bb | High level | 100    | dma_int5            | High level |
| 35       | core_pvtm_int  | High level | 101    | dma_int6            | High level |
| 36       | pmu_pvtm_int   | High level | 102    | dma_int7            | High level |
| 37       | gpio0_int      | High level | 103    | dma_int8            | High level |
| 38       | gpio0_ext_int  | High level | 104    | dma_int9            | High level |
| 39       | gpio1_int      | High level | 105    | dma_int10           | High level |
| 40       | gpio1_ext_int  | High level | 106    | dma_int11           | High level |
| 41       | gpio2_int      | High level | 107    | dma_int12           | High level |
| 42       | gpio2_ext_int  | High level | 108    | dma_int13           | High level |
| 43       | gpio3_int      | High level | 109    | dma_int14           | High level |
| 44       | gpio3_ext_int  | High level | 110    | dma_int15           | High level |
| 45       | gpio4_int      | High level | 111    | dma_abort_int       | High level |
| 46       | gpio4_ext_int  | High level | 112    | i2s0_8ch_int        | High level |
| 47       | crypto_int     | High level | 113    | msch_alarm_irq      | High level |
| 48       | trng_s_int     | High level | 114    | ddrmon_int          | High level |
| 49       | trng_ns_int    | High level | 115    | upctl_alert_err_int | High level |
| 50       | i2c0_int       | High level | 116    | upctl_awpoison_int  | High level |
| 51       | i2c1_int       | High level | 117    | upctl_arpoison_int  | High level |
| 52       | i2c2_int       | High level | 118    | rknpor_powergood    | High level |
| 53       | i2c3_int       | High level | 119    | rga_intr            | High level |
| 54       | i2c4_int       | High level | 120    | vop_intr_post_lb    | High level |
| 55       | spi0_int       | High level | 121    | vop_intr            | High level |
| 56       | spi1_int       | High level | 122    | otpc_ns_int         | High level |
| 57       | uart0_int      | High level | 123    | otpc_s_int          | High level |

| <b>Number</b> | <b>Source</b>                    | <b>Polarity</b> | <b>Number</b> | <b>Source</b>                | <b>Polarity</b> |
|---------------|----------------------------------|-----------------|---------------|------------------------------|-----------------|
| 58            | uart1_int                        | High level      | 124           | otp_mask_int                 | High level      |
| 59            | uart2_int                        | High level      | 125           | irq_gmac_sbd_intr_o          | High level      |
| 60            | uart3_int                        | High level      | 126           | irq_gmac_sbd_perch_tx_intr_o | High level      |
| 61            | uart4_int                        | High level      | 127           | irq_gmac_sbd_perch_rx_intr_o | High level      |
| 62            | uart5_int                        | High level      | 128           | irq_gmac_pmt_intr_o          | High level      |
| 63            | pwm0_int                         | High level      | 129           | tsadc_int                    | High level      |
| 64            | pwm0_int_pwr                     | High level      | 130           | rtc_int                      | High level      |
| 65            | pwm1_int                         | High level      | 131           | csi2host0_intr1              | High level      |
| 66            | pwm1_int_pwr                     | High level      | 132           | csi2host0_intr2              | High level      |
| 67            | pwm2_int                         | High level      | 133           | csi2host1_intr1              | High level      |
| 68            | pwm2_int_pwr                     | High level      | 134           | csi2host1_intr2              | High level      |
| 69            | hptimer_int                      | High level      | 135           | mipi_irq                     | High level      |
| 70            | timer0_int                       | High level      | 136           | mi_irq                       | High level      |
| 71            | timer1_int                       | High level      | 137           | isp_irq                      | High level      |
| 72            | timer2_int                       | High level      | 138           | vicap_int                    | High level      |
| 73            | timer3_int                       | High level      | 139           | o_enc_int                    | High level      |
| 74            | timer4_int                       | High level      | 140           | vepu_pp_int                  | High level      |
| 75            | timer5_int                       | High level      | 141           | rknn_int                     | High level      |
| 76            | stimer0_int                      | High level      | 142           | NOT USED                     | High level      |
| 77            | stimer1_int                      | High level      | 143           | sw_ive_irq                   | High level      |
| 78            | wdt_ns_int                       | High level      | 144           | decom_int                    | High level      |
| 79            | wdt_s_int                        | High level      | 145           | pmuwdt_int                   | High level      |
| 80            | emmc_int                         | High level      | 146           | pmu_mailbox_irq_ap           | High level      |
| 81            | sdio_int                         | High level      | 147           | pmu_mailbox_irq_bb           | High level      |
| 82            | sdmmc_dectn_in_flt               | High level      | 148           | dvbm_int                     | High level      |
| 83            | sdmmc_detectn_irq                | High level      | 149           | irq_macphy                   | High level      |
| 84            | sdmmc_int                        | High level      | 150           | irq_mgp_macphy               | High level      |
| 85            | sfc_int                          | High level      | 151           | irq_excmgp_macphy            | High level      |
| 86            | usb0tg_int                       | High level      | 152           | NOT USED                     | High level      |
| 87            | usb0tg_host_sys_err              | High level      | 153           | NOT USED                     | High level      |
| 88            | usb0tg_pme_generation            | High level      | 154           | NOT USED                     | High level      |
| 89            | usb0tg_host_legacy_smi_interrupt | High level      | 155           | NOT USED                     | High level      |
| 90            | otg_bvalid_irq                   | High level      | 156           | NOT USED                     | High level      |
| 91            | otg_id_irq                       | High level      | 157           | NOT USED                     | High level      |
| 92            | otg_linestate_irq                | High level      | 158           | naxierirq                    | High level      |
| 93            | otg_disconnect_irq               | High level      | 159           | npmuirq                      | High level      |
| 94            | saradc_int                       | High level      | 160           |                              | High level      |
| 95            | dma_int0                         | High level      | 97            |                              | High level      |
| 96            | dma_int1                         | High level      | 98            |                              | High level      |

## 1.4 System DMA Hardware Request Connection

RV1106 provides three DMA controller (DMAC) inside the system, the following tables are the DMA hardware request list.

Table 1-4 RV1106 DMAC Hardware Request Connection List

| Req Number | Source   | Polarity   | Req Number | Source      | Polarity   |
|------------|----------|------------|------------|-------------|------------|
| 0          | SPI0_RX  | High level | 16         | UART5_RX    | High level |
| 1          | SPI0_TX  | High level | 17         | UART5_TX    | High level |
| 2          | SPI1_RX  | High level | 18         | PWM0        | High level |
| 3          | SPI1_TX  | High level | 19         | PWM1        | High level |
| 4          | NOT USED | High level | 20         | PWM2        | High level |
| 5          | NOT USED | High level | 21         | I2S0_8CH_RX | High level |
| 6          | UART0_RX | High level | 22         | I2S0_8CH_TX | High level |
| 7          | UART0_TX | High level | 23         | NOT USED    | High level |
| 8          | UART1_RX | High level | 24         | NOT USED    | High level |
| 9          | UART1_TX | High level | 25         | NOT USED    | High level |
| 10         | UART2_RX | High level | 26         | NOT USED    | High level |
| 11         | UART2_TX | High level | 27         | NOT USED    | High level |
| 12         | UART3_RX | High level | 28         | NOT USED    | High level |
| 13         | UART3_TX | High level | 29         | NOT USED    | High level |
| 14         | UART4_RX | High level | 30         | NOT USED    | High level |
| 15         | UART4_TX | High level | 31         | NOT USED    | High level |

## Chapter 2 Clock & Reset Unit (CRU)

### 2.1 Overview

CRU is an APB slave module that is designed for generating all kinds of internal and system clocks and resets in the 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, software reset or temperature sensor.

CRU is located at several addresses.

Table 2-1 CRU Base Address

|              | Description         | Base Address |
|--------------|---------------------|--------------|
| PMUCRU_BASE  | Used for PMUCRU.    | 0xFF3A0000   |
| CRU_BASE     | Used for TOPCRU.    | 0xFF3B0000   |
| PERICRU_BASE | Used for PERICRU.   | 0xFF3B2000   |
| VICRU_BASE   | Used for VICRU.     | 0xFF3B4000   |
| NPUCRU_BASE  | Used for NPUCRU.    | 0xFF3B6000   |
| CORECRU_BASE | Used for CORECRU.   | 0xFF3B8000   |
| VEPUCRU_BASE | Used for VEPUCRU.   | 0xFF3BA000   |
| VOCRU_BASE   | Used for VOCRU.     | 0xFF3BC000   |
| DDRCRU_BASE  | Used for DDRCRU.    | 0xFF3BE000   |
| SUBDDR_BASE  | Used for SUBDDRCRU. | 0xFF3BF000   |

The CRU supports the following features:

- Compliance with AMBA APB interface
- Embedded with 2 fractional PLLs (GPLL and DPLL) and 2 integer PLLs (APLL and CPLL)
- Flexible selection of clock source
- Use clock matrix scheme
- Support dividing clock separately
- Support gating clock separately
- Support software reset each module separately

### 2.2 Block Diagram

The 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 System Clock Solution

There are 2 fractional PLLs in RV1106: DPLL and GPLL. There are also 2 integer PLLs: APLL,

and CPLL. Each PLL can only receive 24MHz oscillator as input reference clock and can be set to three work modes: normal mode, slow mode and deep slow mode. Before power on or changing PLL setting, we must program PLL into slow mode or deep slow mode.

To maximize the flexibility, some clocks can select divider source from multiple PLLs. To provide some specific frequency, another solution is integrated: fractional divider. Divfree50 divider and divfree NP5 divider are also provided for some modules. All clocks can be gated by software.

The basic units for clock generation are:

- Gating
- MUX (multiplexer)
- Divfree(Glitch free divider)
  - $\text{clk\_out\_freq} = \text{clk\_in\_freq}/(\text{divcon} + 1)$
  - When divcon is even, the clock duty cycle of clk\_out is 50%
  - When divcon is odd, the clock duty cycle of clk\_out is not 50%
- Fracdiv(Fractional divider)
  - $\text{clk\_out\_freq} = \text{clk\_in\_freq} * \text{numerator}/\text{denominator}$ , both numerator and denominator are 16 bits
- Divfree50(Glitch free divider for duty cycle 50%)
  - $\text{clk\_out\_freq} = \text{clk\_in\_freq}/(\text{divcon} + 1)$
  - When divcon is even or odd, the clock duty cycle of clk\_out is 50%
- DivFreeNP5(Glitch free divider for null point 5)
  - $\text{clk\_out\_freq} = \text{clk\_in\_freq}/(\text{div\_con}+1.5)$
  - The clock duty cycle of clk\_out is not 50%

The settings of all basic units are controlled by CRU registers.

### 2.3.2 System Reset Solution

Almost all modules have these reset source as the following figure shows. The 'xxx' in the figure is the module name.



Fig. 2-2 Reset Architecture Diagram

Reset source of each reset signal includes:

- NPOR: External power on reset
- soc\_wdt\_rstn: Reset from WDT module
- soc\_tsadc\_rstn: Reset from TSADC module
- softrstn\_req: Software reset request by programming CRU\_SOFRST\_CON
- glb\_srstn\_1: First global software reset by programming CRU\_GLB\_SRST\_FST as 0xfdः9
- glb\_srstn\_2: Second global software reset by programming CRU\_GLB\_SRST\_SND as 0xeaः8

### 2.3.3 PLL Introduction

PLL is phase locked loop (PLL) with a wide-output-frequency-range for frequency synthesis.

Table 2-2 RV1106 PLL Introduction

|           | FRACPLL(INT Mode)                           |         | INTPLL                                      |         | FRACPLL(FRAC Mode)                                          |         |
|-----------|---------------------------------------------|---------|---------------------------------------------|---------|-------------------------------------------------------------|---------|
| Parameter | Min                                         | Max     | Min                                         | Max     | Min                                                         | Max     |
| Fref(MHz) | 24                                          |         | 24                                          |         | 24                                                          |         |
| Refdiv    | 1                                           | 63      | 1                                           | 63      | 1                                                           | 63      |
| Fbdiv     | 16                                          | 3800    | 16                                          | 190     | 20                                                          | 380     |
| Postdiv   | 1                                           | 49      | 1                                           | 49      | 1                                                           | 49      |
| PFD(MHz)  | 1                                           | Fvco/16 | 10                                          | Fvco/16 | 1                                                           | Fvco/20 |
| Fvco(MHz) | 950                                         | 3800    | 475                                         | 1900    | 950                                                         | 3800    |
| Fout(MHz) | 19                                          | 3800    | 9                                           | 1900    | 19                                                          | 3800    |
| lock time |                                             | 500     |                                             | 1500    |                                                             | 500     |
| Fvco      | $F_{VCO} = F_{REF} * F_{BDIV} / Refdiv$     |         | $F_{VCO} = F_{REF} * F_{BDIV} / Refdiv$     |         | $F_{VCO} = F_{REF} * (F_{BDIV} + F_{frac}/2^{24}) / Refdiv$ |         |
| Fout      | $F_{OUT} = F_{VCO} / (postdiv1 * postdiv2)$ |         | $F_{OUT} = F_{VCO} / (postdiv1 * postdiv2)$ |         | $F_{OUT} = F_{VCO} / (postdiv1 * postdiv2)$                 |         |

### 2.3.3.1 FRACPLL Introduction

The fractional PLLs inside RV1106 output clock's frequency up to 3.8GHz. The PLL is a general purpose, high-performance PLL-based clock generator. Also, the PLL is a multi-function, 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.

The PLL supports the following features:

- Input frequency range: 1MHz to 1200MHz for integer mode and 10MHz to 1200MHz for fractional mode
- PFD minimum reference frequency range: 1MHz for integer mode and 10MHz for fractional mode
- Output frequency range: 19MHz to 3.8GHz
- VCO output frequency range: 950MHz to 3.8GHz
- 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) ensures excellent supply rejection in noisy SoC applications
- Lock detect signal indicates when frequency lock has been achieved

FRACPLL block diagram is shown below.



Fig. 2-3 FRACPLL Block Diagram

### 2.3.3.2 INTPLL Introduction

The integer PLLs inside RV1106 output clock's frequency up to 1.9 GHz. The PLL is a multi-function, general purpose frequency synthesizer optimized for low power digital clocking. Wide input and output ranges along with best-in-class jitter performance allow the PLL to be used for a variety of different application. With excellent supply noise immunity, the PLL is ideal for use in noisy SoC environments.

The PLL supports the following features:

- Input frequency range: 10MHz to 800MHz
  - PFD minimum reference frequency range: 10MHz
  - Output frequency range: 9MHz to 1.9GHz
  - VCO output frequency range: 475 MHz to 1.9GHz
  - 4:1 VCO frequency range allows PLL to be optimized for minimum jitter or minimum power
  - Low period jitter provides maximum timing margin in high frequency designs
  - Lock detect signal indicates when frequency lock has been achieved
- INTPLL block diagram is shown below.



Fig. 2-4 INTPLL Block Diagram

## 2.4 CRU Register Description

### 2.4.1 Registers Summary

| Name           | Offset | Size | Reset Value | Description                   |
|----------------|--------|------|-------------|-------------------------------|
| CRU_APLL_CON0  | 0x0000 | W    | 0x0000105B  | APLL configuration register0  |
| CRU_APLL_CON1  | 0x0004 | W    | 0x00001042  | APLL configuration register1  |
| CRU_APLL_CON2  | 0x0008 | W    | 0x00000000  | APLL configuration register2  |
| CRU_APLL_CON3  | 0x000C | W    | 0x00000007  | APLL configuration register3  |
| CRU_APLL_CON4  | 0x0010 | W    | 0x00007F00  | APLL configuration register4  |
| CRU_CPLL_CON0  | 0x0020 | W    | 0x00001053  | CPLL configuration register0  |
| CRU_CPLL_CON1  | 0x0024 | W    | 0x00001042  | CPLL configuration register1  |
| CRU_CPLL_CON2  | 0x0028 | W    | 0x00000000  | CPLL configuration register2  |
| CRU_CPLL_CON3  | 0x002C | W    | 0x00000007  | CPLL configuration register3  |
| CRU_CPLL_CON4  | 0x0030 | W    | 0x00007F00  | CPLL configuration register4  |
| CRU_DPLL_CON0  | 0x0040 | W    | 0x0000312C  | DPLL configuration register0  |
| CRU_DPLL_CON1  | 0x0044 | W    | 0x00001083  | DPLL configuration register1  |
| CRU_DPLL_CON2  | 0x0048 | W    | 0x00000000  | DPLL configuration register2  |
| CRU_DPLL_CON3  | 0x004C | W    | 0x00000007  | DPLL configuration register3  |
| CRU_DPLL_CON4  | 0x0050 | W    | 0x00007F00  | DPLL configuration register4  |
| CRU_GPLL_CON0  | 0x0060 | W    | 0x00001063  | GPLL configuration register0  |
| CRU_GPLL_CON1  | 0x0064 | W    | 0x00001042  | GPLL configuration register1  |
| CRU_GPLL_CON2  | 0x0068 | W    | 0x00000000  | GPLL configuration register2  |
| CRU_GPLL_CON3  | 0x006C | W    | 0x00000007  | GPLL configuration register3  |
| CRU_GPLL_CON4  | 0x0070 | W    | 0x00007F00  | GPLL configuration register4  |
| CRU_SSGTBL0_3  | 0x0140 | W    | 0x00000000  | External wave table register0 |
| CRU_SSGTBL4_7  | 0x0144 | W    | 0x00000000  | External wave table register1 |
| CRU_SSGTBL8_11 | 0x0148 | W    | 0x00000000  | External wave table register2 |

| Name              | Offset | Size | Reset Value | Description                                   |
|-------------------|--------|------|-------------|-----------------------------------------------|
| CRU_SSGTBL12_15   | 0x014C | W    | 0x00000000  | External wave table register3                 |
| CRU_SSGTBL16_19   | 0x0150 | W    | 0x00000000  | External wave table register4                 |
| CRU_SSGTBL20_23   | 0x0154 | W    | 0x00000000  | External wave table register5                 |
| CRU_SSGTBL24_27   | 0x0158 | W    | 0x00000000  | External wave table register6                 |
| CRU_SSGTBL28_31   | 0x015C | W    | 0x00000000  | External wave table register7                 |
| CRU_SSGTBL32_35   | 0x0160 | W    | 0x00000000  | External wave table register8                 |
| CRU_SSGTBL36_39   | 0x0164 | W    | 0x00000000  | External wave table register9                 |
| CRU_SSGTBL40_43   | 0x0168 | W    | 0x00000000  | External wave table register10                |
| CRU_SSGTBL44_47   | 0x016C | W    | 0x00000000  | External wave table register11                |
| CRU_SSGTBL48_51   | 0x0170 | W    | 0x00000000  | External wave table register12                |
| CRU_SSGTBL52_55   | 0x0174 | W    | 0x00000000  | External wave table register13                |
| CRU_SSGTBL56_59   | 0x0178 | W    | 0x00000000  | External wave table register14                |
| CRU_SSGTBL60_63   | 0x017C | W    | 0x00000000  | External wave table register15                |
| CRU_SSGTBL64_67   | 0x0180 | W    | 0x00000000  | External wave table register16                |
| CRU_SSGTBL68_71   | 0x0184 | W    | 0x00000000  | External wave table register17                |
| CRU_SSGTBL72_75   | 0x0188 | W    | 0x00000000  | External wave table register18                |
| CRU_SSGTBL76_79   | 0x018C | W    | 0x00000000  | External wave table register19                |
| CRU_SSGTBL80_83   | 0x0190 | W    | 0x00000000  | External wave table register20                |
| CRU_SSGTBL84_87   | 0x0194 | W    | 0x00000000  | External wave table register21                |
| CRU_SSGTBL88_91   | 0x0198 | W    | 0x00000000  | External wave table register22                |
| CRU_SSGTBL92_95   | 0x019C | W    | 0x00000000  | External wave table register23                |
| CRU_SSGTBL96_99   | 0x01A0 | W    | 0x00000000  | External wave table register24                |
| CRU_SSGTBL100_103 | 0x01A4 | W    | 0x00000000  | External wave table register25                |
| CRU_SSGTBL104_107 | 0x01A8 | W    | 0x00000000  | External wave table register26                |
| CRU_SSGTBL108_111 | 0x01AC | W    | 0x00000000  | External wave table register27                |
| CRU_SSGTBL112_115 | 0x01B0 | W    | 0x00000000  | External wave table register28                |
| CRU_SSGTBL116_119 | 0x01B4 | W    | 0x00000000  | External wave table register29                |
| CRU_SSGTBL120_123 | 0x01B8 | W    | 0x00000000  | External wave table register30                |
| CRU_SSGTBL124_127 | 0x01BC | W    | 0x00000000  | External wave table register31                |
| CRU_MODE_CON00    | 0x0280 | W    | 0x00000000  | Internal clock select and division register 0 |
| CRU_CLKSEL_CON00  | 0x0300 | W    | 0x00000A73  | Internal clock select and division register 0 |
| CRU_CLKSEL_CON01  | 0x0304 | W    | 0x00000147  | Internal clock select and division register 1 |
| CRU_CLKSEL_CON02  | 0x0308 | W    | 0x000000E3  | Internal clock select and division register 2 |
| CRU_CLKSEL_CON03  | 0x030C | W    | 0x00000082  | Internal clock select and division register 3 |
| CRU_CLKSEL_CON04  | 0x0310 | W    | 0x000000841 | Internal clock select and division register 4 |
| CRU_CLKSEL_CON05  | 0x0314 | W    | 0x000000001 | Internal clock select and division register 5 |

| Name             | Offset | Size | Reset Value | Description                                    |
|------------------|--------|------|-------------|------------------------------------------------|
| CRU_CLKSEL_CON06 | 0x0318 | W    | 0x001403DE  | Internal clock select and division register 6  |
| CRU_CLKSEL_CON07 | 0x031C | W    | 0x00000006  | Internal clock select and division register 7  |
| CRU_CLKSEL_CON08 | 0x0320 | W    | 0x001403DE  | Internal clock select and division register 8  |
| CRU_CLKSEL_CON09 | 0x0324 | W    | 0x00000006  | Internal clock select and division register 9  |
| CRU_CLKSEL_CON10 | 0x0328 | W    | 0x001403DE  | Internal clock select and division register 10 |
| CRU_CLKSEL_CON11 | 0x032C | W    | 0x00000006  | Internal clock select and division register 11 |
| CRU_CLKSEL_CON12 | 0x0330 | W    | 0x001403DE  | Internal clock select and division register 12 |
| CRU_CLKSEL_CON13 | 0x0334 | W    | 0x00000006  | Internal clock select and division register 13 |
| CRU_CLKSEL_CON14 | 0x0338 | W    | 0x001403DE  | Internal clock select and division register 14 |
| CRU_CLKSEL_CON15 | 0x033C | W    | 0x00000006  | Internal clock select and division register 15 |
| CRU_CLKSEL_CON16 | 0x0340 | W    | 0x001403DE  | Internal clock select and division register 16 |
| CRU_CLKSEL_CON17 | 0x0344 | W    | 0x00000006  | Internal clock select and division register 17 |
| CRU_CLKSEL_CON18 | 0x0348 | W    | 0x03355460  | Internal clock select and division register 18 |
| CRU_CLKSEL_CON19 | 0x034C | W    | 0x00000007  | Internal clock select and division register 19 |
| CRU_CLKSEL_CON20 | 0x0350 | W    | 0x03355460  | Internal clock select and division register 20 |
| CRU_CLKSEL_CON21 | 0x0354 | W    | 0x0000000B  | Internal clock select and division register 21 |
| CRU_CLKSEL_CON23 | 0x035C | W    | 0x00000038  | Internal clock select and division register 23 |
| CRU_CLKSEL_CON24 | 0x0360 | W    | 0x000000580 | Internal clock select and division register 24 |
| CRU_CLKSEL_CON25 | 0x0364 | W    | 0x00000004  | Internal clock select and division register 25 |
| CRU_CLKSEL_CON26 | 0x0368 | W    | 0x001403DE  | Internal clock select and division register 26 |
| CRU_CLKSEL_CON27 | 0x036C | W    | 0x00000006  | Internal clock select and division register 27 |
| CRU_CLKSEL_CON28 | 0x0370 | W    | 0x001403DE  | Internal clock select and division register 28 |

| Name               | Offset | Size | Reset Value | Description                                    |
|--------------------|--------|------|-------------|------------------------------------------------|
| CRU_CLKSEL_CON29   | 0x0374 | W    | 0x00000006  | Internal clock select and division register 29 |
| CRU_CLKSEL_CON30   | 0x0378 | W    | 0x001403DE  | Internal clock select and division register 30 |
| CRU_CLKSEL_CON31   | 0x037C | W    | 0x00000006  | Internal clock select and division register 31 |
| CRU_CLKSEL_CON32   | 0x0380 | W    | 0x001403DE  | Internal clock select and division register 32 |
| CRU_CLKSEL_CON33   | 0x0384 | W    | 0x00000002  | Internal clock select and division register 33 |
| CRU_GATE_CON00     | 0x0800 | W    | 0x00000000  | Internal clock gate and division register 0    |
| CRU_GATE_CON01     | 0x0804 | W    | 0x00000000  | Internal clock gate and division register 1    |
| CRU_GATE_CON02     | 0x0808 | W    | 0x0000E000  | Internal clock gate and division register 2    |
| CRU_GATE_CON03     | 0x080C | W    | 0x00000001  | Internal clock gate and division register 3    |
| CRU_SOFT_RST_CON02 | 0x0A08 | W    | 0x00000000  | Internal clock reset register 2                |
| CRU_GLB_CNT_TH     | 0x0C00 | W    | 0x00640064  | GLB_CNT_TH                                     |
| CRU_GLB_RST_ST     | 0x0C04 | W    | 0x00000000  | GLB_RST_ST                                     |
| CRU_GLB_SRST_FST   | 0x0C08 | W    | 0x00000000  | GLB_SRST_FST                                   |
| CRU_GLB_SRST SND   | 0x0C0C | W    | 0x00000000  | GLB_SRST_SND                                   |
| CRU_GLB_RST_CON    | 0x0C10 | W    | 0x00000000  | GLB_RST_CON                                    |

Notes:Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**-

Double WORD (64 bits) access

## 2.4.2 Detail Registers Description

### CRU\_APLL\_CON0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15    | RW   | 0x0         | bypass<br>PLL Bypass. FREF bypasses PLL to FOUTPOSTDIV<br>1'b0: No bypass<br>1'b1: Bypass                                          |
| 14:12 | RW   | 0x1         | postdiv1<br>First Post Divide Value, (1-7)<br>should obey the rule : postdiv1 > = postdiv2                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0       | RW          | 0x05b              | <p>fbdv<br/>Feedback Divide Value, valid divider settings are:<br/>[16, 2500] in integer mode<br/>[20, 500] in fractional mode<br/>Tips: No plus one operation</p> |

**CRU APLL CON1**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>write_enable<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                          |
| 15         | RW          | 0x0                | <p>pllpsel<br/>PLL global power down source selection<br/>If pllpsel == 1, PLL can be power down only by pllld1, otherwise pll is power down when any one of refdiv/fbdv/fracdiv is changed or pllpd0 is asserted</p> |
| 14         | RW          | 0x0                | <p>pllld1<br/>PLL global power down request<br/>1'b0: No power down<br/>1'b1: Power down</p>                                                                                                                          |
| 13         | RW          | 0x0                | <p>pllpd0<br/>PLL global power down request<br/>1'b0: No power down<br/>1'b1: Power down</p>                                                                                                                          |
| 12         | RW          | 0x1                | <p>dsmpd<br/>PLL delta sigma modulator enable<br/>1'b0: Modulator is enable<br/>1'b1: Modulator is disabled</p>                                                                                                       |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                              |
| 10         | RW          | 0x0                | <p>pll_lock<br/>PLL lock status<br/>1'b0: Unlock<br/>1'b1: Lock</p>                                                                                                                                                   |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                              |
| 8:6        | RW          | 0x1                | <p>postdiv2<br/>Second Post Divide Value, (1-7)</p>                                                                                                                                                                   |
| 5:0        | RW          | 0x02               | <p>refdiv<br/>Reference Clock Divide Value, (1-63)<br/>APLL is int pll. refdiv must use 1 or 2</p>                                                                                                                    |

**CRU APLL CON2**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                         |
| 27         | RW          | 0x0                | fout4phasepd<br>Power down 4-phase clocks and 2X, 3X, 4X clocks<br>1'b0: No power down<br>1'b1: Power down       |
| 26         | RW          | 0x0                | foutvcopd<br>Power down buffered VCO clock<br>1'b0: No power down<br>1'b1: Power down                            |
| 25         | RW          | 0x0                | foutpostdivpd<br>Power down all outputs except for buffered VCO clock<br>1'b0: No power down<br>1'b1: Power down |
| 24         | RW          | 0x0                | dacpd<br>Power down quantization noise cancellation DAC<br>1'b0: No power down<br>1'b1: Power down               |
| 23:0       | RW          | 0x000000           | fracdiv<br>Fractional part of feedback divide<br>(fraction = FRAC/2^24)                                          |

**CRU APPL CON3**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12:8       | RW          | 0x00               | ssmod_spread<br>spread amplitude<br>% = 0.1 * SPREAD[4: 0]                                                                         |
| 7:4        | RW          | 0x0                | ssmod_divval<br>Divider required to set the modulation frequency                                                                   |
| 3          | RW          | 0x0                | ssmod_downspread<br>Selects center spread or downs pread<br>1'b0: Down spread<br>1'b1: Center spread                               |
| 2          | RW          | 0x1                | ssmod_reset<br>Reset modulator state<br>1'b0: No reset<br>1'b1: Reset                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 1          | RW          | 0x1                | ssmod_disable_sscg<br>Bypass SSMOD by module<br>1'b0: No bypass<br>1'b1: Bypass |
| 0          | RW          | 0x1                | ssmod_bp<br>Bypass SSMOD by integration<br>1'b0: No bypass<br>1'b1: Bypass      |

**CRU APLL CON4**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RW          | 0x7f               | ssmod_ext_maxaddr<br>External wave table data inputs<br>(0-255)                                                                    |
| 7:1        | RO          | 0x00               | reserved                                                                                                                           |
| 0          | RW          | 0x0                | ssmod_sel_ext_wave<br>select external wave<br>1'b0: No select ext_wave<br>1'b1: Select ext_wave                                    |

**CRU CPLL CON0**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                      |
| 15         | RW          | 0x0                | bypass<br>PLL Bypass. FREF bypasses PLL to FOUTPOSTDIV<br>1'b0: No bypass<br>1'b1: Bypass                                                               |
| 14:12      | RW          | 0x1                | postdiv1<br>First Post Divide Value, (1-7)<br>should obey the rule : postdiv1 > = postdiv2                                                              |
| 11:0       | RW          | 0x053              | fbdv<br>Feedback Divide Value, valid divider settings are:<br>[16, 2500] in integer mode<br>[20, 500] in fractional mode<br>Tips: No plus one operation |

**CRU CPLL CON1**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                           |
| 15         | RW          | 0x0                | pllpsel<br>PLL global power down source selection<br>If pllpsel == 1, PLL can be power down only by pllpd1, otherwise pll is power down when any one of refdiv/fbdv/fracdiv is changed or pllpd0 is asserted |
| 14         | RW          | 0x0                | pllpd1<br>PLL global power down request<br>1'b0: No power down<br>1'b1: Power down                                                                                                                           |
| 13         | RW          | 0x0                | pllpd0<br>PLL global power down request<br>1'b0: No power down<br>1'b1: Power down                                                                                                                           |
| 12         | RW          | 0x1                | dsmpd<br>PLL delta sigma modulator enable<br>1'b0: Modulator is enable<br>1'b1: Modulator is disabled                                                                                                        |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                     |
| 10         | RW          | 0x0                | pll_lock<br>PLL lock status<br>1'b0: Unlock<br>1'b1: Lock                                                                                                                                                    |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                     |
| 8:6        | RW          | 0x1                | postdiv2<br>Second Post Divide Value, (1-7)                                                                                                                                                                  |
| 5:0        | RW          | 0x02               | refdiv<br>Reference Clock Divide Value, (1-63)<br>APLL is int pll. refdiv must use 1 or 2                                                                                                                    |

**CRU CPLL CON2**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                   |
| 27         | RW          | 0x0                | fout4phasepd<br>Power down 4-phase clocks and 2X, 3X, 4X clocks<br>1'b0: No power down<br>1'b1: Power down |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 26         | RW          | 0x0                | foutvcopd<br>Power down buffered VCO clock<br>1'b0: No power down<br>1'b1: Power down                            |
| 25         | RW          | 0x0                | foutpostdivpd<br>Power down all outputs except for buffered VCO clock<br>1'b0: No power down<br>1'b1: Power down |
| 24         | RW          | 0x0                | dacpd<br>Power down quantization noise cancellation DAC<br>1'b0: No power down<br>1'b1: Power down               |
| 23:0       | RW          | 0x000000           | fracdiv<br>Fractional part of feedback divide<br>(fraction = FRAC/2^24)                                          |

**CRU CPLL CON3**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12:8       | RW          | 0x00               | ssmod_spread<br>spread amplitude<br>% = 0.1 * SPREAD[4: 0]                                                                         |
| 7:4        | RW          | 0x0                | ssmod_divval<br>Divider required to set the modulation frequency                                                                   |
| 3          | RW          | 0x0                | ssmod_downspread<br>Selects center spread or down spread<br>1'b0: Down spread<br>1'b1: Center spread                               |
| 2          | RW          | 0x1                | ssmod_reset<br>Reset modulator state<br>1'b0: No reset<br>1'b1: Reset                                                              |
| 1          | RW          | 0x1                | ssmod_disable_sscg<br>Bypass SSMOD by module<br>1'b0: No bypass<br>1'b1: Bypass                                                    |
| 0          | RW          | 0x1                | ssmod_bp<br>Bypass SSMOD by integration<br>1'b0: No bypass<br>1'b1: Bypass                                                         |

**CRU CPLL CON4**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RW          | 0x7f               | ssmod_ext_maxaddr<br>External wave table data inputs<br>(0-255)                                                                    |
| 7:1        | RO          | 0x00               | reserved                                                                                                                           |
| 0          | RW          | 0x0                | ssmod_sel_ext_wave<br>select external wave<br>1'b0: No select ext_wave<br>1'b1: Select ext_wave                                    |

**CRU DPLL CON0**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                      |
| 15         | RW          | 0x0                | bypass<br>PLL Bypass. FREF bypasses PLL to FOUTPOSTDIV<br>1'b0: No bypass<br>1'b1: Bypass                                                               |
| 14:12      | RW          | 0x3                | postdiv1<br>First Post Divide Value, (1-7)<br>should obey the rule : postdiv1 > = postdiv2                                                              |
| 11:0       | RW          | 0x12c              | fbdv<br>Feedback Divide Value, valid divider settings are:<br>[16, 2500] in integer mode<br>[20, 500] in fractional mode<br>Tips: No plus one operation |

**CRU DPLL CON1**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | pllpdsel<br>PLL global power down source selection<br>If pllpdsel == 1, PLL can be power down only by pllpd1, otherwise pll is power down when any one of refdiv/fbddiv/fracdiv is changed or pllpd0 is asserted |
| 14         | RW          | 0x0                | pllpd1<br>PLL global power down request<br>1'b0: No power down<br>1'b1: Power down                                                                                                                               |
| 13         | RW          | 0x0                | pllpd0<br>PLL global power down request<br>1'b0: No power down<br>1'b1: Power down                                                                                                                               |
| 12         | RW          | 0x1                | dsmpd<br>PLL delta sigma modulator enable<br>1'b0: Modulator is enable,<br>1'b1: Modulator is disabled                                                                                                           |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                         |
| 10         | RW          | 0x0                | pll_lock<br>PLL lock status<br>1'b0: Unlock<br>1'b1: Lock                                                                                                                                                        |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                         |
| 8:6        | RW          | 0x2                | postdiv2<br>Second Post Divide Value<br>(1-7)                                                                                                                                                                    |
| 5:0        | RW          | 0x03               | refdiv<br>Reference Clock Divide Value<br>(1-63)                                                                                                                                                                 |

**CRU DPLL CON2**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                   |
| 27         | RW          | 0x0                | fout4phasepd<br>Power down 4-phase clocks and 2X, 3X, 4X clocks<br>1'b0: No power down<br>1'b1: Power down |
| 26         | RW          | 0x0                | foutvcopd<br>Power down buffered VCO clock<br>1'b0: No power down<br>1'b1: Power down                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 25         | RW          | 0x0                | foutpostdivpd<br>Power down all outputs except for buffered VCO clock<br>1'b0: No power down<br>1'b1: Power down |
| 24         | RW          | 0x0                | dacpd<br>Power down quantization noise cancellation DAC<br>1'b0: No power down<br>1'b1: Power down               |
| 23:0       | RW          | 0x000000           | fracdiv<br>Fractional part of feedback divide<br>(fraction = FRAC/2^24)                                          |

**CRU DPLL CON3**

Address: Operational Base + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12:8       | RW          | 0x00               | ssmod_spread<br>spread amplitude<br>% = 0.1 * SPREAD[4: 0]                                                                         |
| 7:4        | RW          | 0x0                | ssmod_divval<br>Divider required to set the modulation frequency                                                                   |
| 3          | RW          | 0x0                | ssmod_downspread<br>Selects center spread or downs pread<br>1'b0: Down spread<br>1'b1: Center spread                               |
| 2          | RW          | 0x1                | ssmod_reset<br>Reset modulator state<br>1'b0: No reset<br>1'b1: Reset                                                              |
| 1          | RW          | 0x1                | ssmod_disable_sscg<br>Bypass SSMOD by module<br>1'b0: No bypass<br>1'b1: Bypass                                                    |
| 0          | RW          | 0x1                | ssmod_bp<br>Bypass SSMOD by integration<br>1'b0: No bypass<br>1'b1: Bypass                                                         |

**CRU DPLL CON4**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RW          | 0x7f               | ssmod_ext_maxaddr<br>External wave table data inputs, (0-255)                                                                      |
| 7:1        | RO          | 0x00               | reserved                                                                                                                           |
| 0          | RW          | 0x0                | ssmod_sel_ext_wave<br>select external wave<br>1'b0: No select ext_wave<br>1'b1: Select ext_wave                                    |

**CRU GPLL CON0**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                      |
| 15         | RW          | 0x0                | bypass<br>PLL Bypass. FREF bypasses PLL to FOUTPOSTDIV<br>1'b0: No bypass<br>1'b1: Bypass                                                               |
| 14:12      | RW          | 0x1                | postdiv1<br>First Post Divide Value, (1-7)<br>should obey the rule : postdiv1 > = postdiv2                                                              |
| 11:0       | RW          | 0x063              | fbdv<br>Feedback Divide Value, valid divider settings are:<br>[16, 2500] in integer mode<br>[20, 500] in fractional mode<br>Tips: No plus one operation |

**CRU GPLL CON1**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                   |
| 15         | RW          | 0x0                | pllpdsel<br>PLL global power down source selection<br>If pllpdsel == 1, PLL can be power down only by pllpd1,<br>otherwise pll is power down when any one of refdiv/fbdv/fracdiv<br>is changed or pllpd0 is asserted |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | pllpd1<br>PLL global power down request<br>1'b0: No power down<br>1'b1: Power down                    |
| 13         | RW          | 0x0                | pllpd0<br>PLL global power down request<br>1'b0: No power down<br>1'b1: Power down                    |
| 12         | RW          | 0x1                | dsmpd<br>PLL delta sigma modulator enable<br>1'b0: Modulator is enable<br>1'b1: Modulator is disabled |
| 11         | RO          | 0x0                | reserved                                                                                              |
| 10         | RW          | 0x0                | pll_lock<br>PLL lock status<br>1'b0: Unlock<br>1'b1: Lock                                             |
| 9          | RO          | 0x0                | reserved                                                                                              |
| 8:6        | RW          | 0x1                | postdiv2<br>Second Post Divide Value<br>(1-7)                                                         |
| 5:0        | RW          | 0x02               | refdiv<br>Reference Clock Divide Value<br>(1-63)                                                      |

**CRU GPLL CON2**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                         |
| 27         | RW          | 0x0                | fout4phasepd<br>Power down 4-phase clocks and 2X, 3X, 4X clocks<br>1'b0: No power down<br>1'b1: Power down       |
| 26         | RW          | 0x0                | foutvcopd<br>Power down buffered VCO clock<br>1'b0: No power down<br>1'b1: Power down                            |
| 25         | RW          | 0x0                | foutpostdivpd<br>Power down all outputs except for buffered VCO clock<br>1'b0: No power down<br>1'b1: Power down |
| 24         | RW          | 0x0                | dacpd<br>Power down quantization noise cancellation DAC<br>1'b0: No power down<br>1'b1: Power down               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 23:0       | RW          | 0x000000           | fracdiv<br>Fractional part of feedback divide<br>(fraction = FRAC/2^24) |

**CRU GPLL CON3**

Address: Operational Base + offset (0x006C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12:8       | RW          | 0x00               | ssmod_spread<br>spread amplitude<br>% = 0.1 * SPREAD[4: 0]                                                                         |
| 7:4        | RW          | 0x0                | ssmod_divval<br>Divider required to set the modulation frequency                                                                   |
| 3          | RW          | 0x0                | ssmod_downspread<br>Selects center spread or down spread<br>1'b0: Down spread<br>1'b1: Center spread                               |
| 2          | RW          | 0x1                | ssmod_reset<br>Reset modulator state<br>1'b0: No reset<br>1'b1: Reset                                                              |
| 1          | RW          | 0x1                | ssmod_disable_sscg<br>Bypass SSMOD by module<br>1'b0: No bypass<br>1'b1: Bypass                                                    |
| 0          | RW          | 0x1                | ssmod_bp<br>Bypass SSMOD by integration<br>1'b0: No bypass<br>1'b1: Bypass                                                         |

**CRU GPLL CON4**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RW          | 0x7f               | ssmod_ext_maxaddr<br>External wave table data inputs, (0-255)                                                                      |
| 7:1        | RO          | 0x00               | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | ssmod_sel_ext_wave<br>select external wave<br>1'b0: No select ext_wave<br>1'b1: Select ext_wave |

**CRU SSGTBL0\_3**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl0_3<br>Extern wave table 0-3<br>7-0: table0<br>15-8: table1<br>23-16: table2<br>31-24: table3 |

**CRU SSGTBL4\_7**

Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl4_7<br>Extern wave table 4-7<br>7-0: table4<br>15-8: table5<br>23-16: table6<br>31-24: table7 |

**CRU SSGTBL8\_11**

Address: Operational Base + offset (0x0148)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl8_11<br>Extern wave table 8-11<br>7-0: table8<br>15-8: table9<br>23-16: table10<br>31-24: table11 |

**CRU SSGTBL12\_15**

Address: Operational Base + offset (0x014C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl12_15<br>Extern wave table 12-15<br>7-0: table12<br>15-8: table13<br>23-16: table14<br>31-24: table15 |

**CRU SSGTBL16 19**

Address: Operational Base + offset (0x0150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl16_19<br>Extern wave table 16-19<br>7-0: table16<br>15-8: table17<br>23-16: table18<br>31-24: table19 |

**CRU SSGTBL20 23**

Address: Operational Base + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl20_23<br>Extern wave table 20-23<br>7-0: table20<br>15-8: table21<br>23-16: table22<br>31-24: table23 |

**CRU SSGTBL24 27**

Address: Operational Base + offset (0x0158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl24_27<br>Extern wave table 24-27<br>7-0: table24<br>15-8: table25<br>23-16: table26<br>31-24: table27 |

**CRU SSGTBL28 31**

Address: Operational Base + offset (0x015C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl28_31<br>Extern wave table 28-31<br>7-0: table28<br>15-8: table29<br>23-16: table30<br>31-24: table31 |

**CRU SSGTBL32 35**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl32_35<br>Extern wave table 32-35<br>7-0: table32<br>15-8: table33<br>23-16: table34<br>31-24: table35 |

**CRU SSGTBL36 39**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl36_39<br>Extern wave table 36-39<br>7-0: table36<br>15-8: table37<br>23-16: table38<br>31-24: table39 |

**CRU SSGTBL40 43**

Address: Operational Base + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl40_43<br>Extern wave table 40-43<br>7-0: table40<br>15-8: table41<br>23-16: table42<br>31-24: table43 |

**CRU SSGTBL44 47**

Address: Operational Base + offset (0x016C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl44_47<br>Extern wave table 44-47<br>7-0: table44<br>15-8: table45<br>23-16: table46<br>31-24: table47 |

**CRU SSGTBL48 51**

Address: Operational Base + offset (0x0170)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl48_51<br>Extern wave table 48-51<br>7-0: table48<br>15-8: table49<br>23-16: table50<br>31-24: table51 |

**CRU SSGTBL52 55**

Address: Operational Base + offset (0x0174)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl52_55<br>Extern wave table 52-55<br>7-0: table52<br>15-8: table53<br>23-16: table54<br>31-24: table55 |

**CRU SSGTBL56 59**

Address: Operational Base + offset (0x0178)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl56_59<br>Extern wave table 56-59<br>7-0: table56<br>15-8: table57<br>23-16: table58<br>31-24: table59 |

**CRU SSGTBL60 63**

Address: Operational Base + offset (0x017C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl60_63<br>Extern wave table 60-63<br>7-0: table60<br>15-8: table61<br>23-16: table62<br>31-24: table63 |

**CRU SSGTBL64 67**

Address: Operational Base + offset (0x0180)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl64_67<br>Extern wave table 64-67<br>7-0: table64<br>15-8: table65<br>23-16: table66<br>31-24: table67 |

**CRU SSGTBL68 71**

Address: Operational Base + offset (0x0184)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl68_71<br>Extern wave table 68-71<br>7-0: table68<br>15-8: table69<br>23-16: table70<br>31-24: table71 |

**CRU SSGTBL72 75**

Address: Operational Base + offset (0x0188)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl72_75<br>Extern wave table 72-75<br>7-0: table72<br>15-8: table73<br>23-16: table74<br>31-24: table75 |

**CRU SSGTBL76 79**

Address: Operational Base + offset (0x018C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl76_79<br>Extern wave table 76-79<br>7-0: table76<br>15-8: table77<br>23-16: table78<br>31-24: table79 |

**CRU SSGTBL80 83**

Address: Operational Base + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl80_83<br>Extern wave table 76-79<br>7-0: table80<br>15-8: table81<br>23-16: table82<br>31-24: table83 |

**CRU SSGTBL84 87**

Address: Operational Base + offset (0x0194)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl84_87<br>Extern wave table 84-87<br>7-0: table84<br>15-8: table85<br>23-16: table86<br>31-24: table87 |

**CRU SSGTBL88 91**

Address: Operational Base + offset (0x0198)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl88_91<br>Extern wave table 88-91<br>7-0: table88<br>15-8: table89<br>23-16: table90<br>31-24: table91 |

**CRU SSGTBL92 95**

Address: Operational Base + offset (0x019C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl92_95<br>Extern wave table 92-95<br>7-0: table92<br>15-8: table93<br>23-16: table94<br>31-24: table95 |

**CRU SSGTBL96 99**

Address: Operational Base + offset (0x01A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl96_99<br>Extern wave table 96-99<br>7-0: table96<br>15-8: table97<br>23-16: table98<br>31-24: table99 |

**CRU SSGTBL100 103**

Address: Operational Base + offset (0x01A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl100_103<br>Extern wave table 100-103<br>7-0: table100<br>15-8: table101<br>23-16: table102<br>31-24: table103 |

**CRU SSGTBL104 107**

Address: Operational Base + offset (0x01A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl104_107<br>Extern wave table 104-107<br>7-0: table104<br>15-8: table105<br>23-16: table106<br>31-24: table107 |

**CRU SSGTBL108 111**

Address: Operational Base + offset (0x01AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl108_111<br>Extern wave table 108-111<br>7-0: table108<br>15-8: table109<br>23-16: table110<br>31-24: table111 |

**CRU SSGTBL112 115**

Address: Operational Base + offset (0x01B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl112_115<br>Extern wave table 112-115<br>7-0: table112<br>15-8: table113<br>23-16: table114<br>31-24: table115 |

**CRU SSGTBL116 119**

Address: Operational Base + offset (0x01B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl116_119<br>Extern wave table 116-119<br>7-0: table116<br>15-8: table117<br>23-16: table118<br>31-24: table119 |

**CRU SSGTBL120 123**

Address: Operational Base + offset (0x01B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl120_123<br>Extern wave table 120-123<br>7-0: table120<br>15-8: table121<br>23-16: table122<br>31-24: table123 |

**CRU SSGTBL124 127**

Address: Operational Base + offset (0x01BC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ssgtbl124_127<br>Extern wave table 124-127<br>7-0: table124<br>15-8: table125<br>23-16: table126<br>31-24: table127 |

**CRU MODE CON00**

Address: Operational Base + offset (0x0280)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:6       | RO          | 0x000              | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 5:4        | RW          | 0x0                | clk_gpll_mode<br>clk_gpll_mux clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_gpll<br>2'b10: clk_deepslow |
| 3:2        | RW          | 0x0                | clk_cpll_mode<br>clk_cpll_mux clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_cpll<br>2'b10: clk_deepslow |
| 1:0        | RW          | 0x0                | clk_apll_mode<br>clk_apll_mux clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_apll<br>2'b10: clk_deepslow |

**CRU CLKSEL CON00**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x1                | clk_matrix_100m_src_sel<br>clk_matrix_100m_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                              |
| 10:6       | RW          | 0x09               | clk_matrix_100m_src_div<br>Divide clk_matrix_100m_src by (div_con + 1).                                                            |
| 5          | RW          | 0x1                | clk_matrix_50m_src_sel<br>clk_matrix_50m_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                |
| 4:0        | RW          | 0x13               | clk_matrix_50m_src_div<br>Divide clk_matrix_50m_src by (div_con + 1).                                                              |

**CRU CLKSEL CON01**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | clk_matrix_200m_src_sel<br>clk_matrix_200m_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux |
| 10:6       | RW          | 0x05               | clk_matrix_200m_src_div<br>Divide clk_matrix_200m_src by (div_con + 1).                               |
| 5          | RW          | 0x0                | clk_matrix_150m_src_sel<br>clk_matrix_150m_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux |
| 4:0        | RW          | 0x07               | clk_matrix_150m_src_div<br>Divide clk_matrix_150m_src by (div_con + 1).                               |

**CRU CLKSEL CON02**

Address: Operational Base + offset (0x0308)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | clk_matrix_300m_src_sel<br>clk_matrix_300m_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                              |
| 10:6       | RW          | 0x03               | clk_matrix_300m_src_div<br>Divide clk_matrix_300m_src by (div_con + 1).                                                            |
| 5          | RW          | 0x1                | clk_matrix_250m_src_sel<br>clk_matrix_250m_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                              |
| 4:0        | RW          | 0x03               | clk_matrix_250m_src_div<br>Divide clk_matrix_250m_src by (div_con + 1).                                                            |

**CRU CLKSEL CON03**

Address: Operational Base + offset (0x030C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | clk_matrix_400m_src_sel<br>clk_matrix_400m_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux       |
| 10:6       | RW          | 0x02               | clk_matrix_400m_src_div<br>DT50 division register.<br>Divide clk_matrix_400m_src by (div_con + 1).          |
| 5          | RW          | 0x0                | clk_matrix_339m_src_sel<br>clk_matrix_339m_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux       |
| 4:0        | RW          | 0x02               | clk_matrix_339m_src_div<br>NP5 division register.<br>Divide clk_matrix_339m_src by ((2 * div_con + 3) / 2). |

**CRU CLKSEL CON04**

Address: Operational Base + offset (0x0310)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x1                | clk_matrix_500m_src_sel<br>clk_matrix_500m_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                              |
| 10:6       | RW          | 0x01               | clk_matrix_500m_src_div<br>Divide clk_matrix_500m_src by (div_con + 1).                                                            |
| 5          | RW          | 0x0                | clk_matrix_450m_src_sel<br>clk_matrix_450m_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                              |
| 4:0        | RW          | 0x01               | clk_matrix_450m_src_div<br>NP5 division register.<br>Divide clk_matrix_450m_src by ((2 * div_con + 3) / 2).                        |

**CRU CLKSEL CON05**

Address: Operational Base + offset (0x0314)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:6       | RO          | 0x000              | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | clk_uart0_src_sel<br>clk_uart0_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux |
| 4:0        | RW          | 0x01               | clk_uart0_src_div<br>Divide clk_uart0_src by (div_con + 1).                               |

**CRU CLKSEL CON06**

Address: Operational Base + offset (0x0318)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x001403de         | clk_uart0_frac_div<br>clk_uart0_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON07**

Address: Operational Base + offset (0x031C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | clk_uart1_src_sel<br>clk_uart1_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                          |
| 6:2        | RW          | 0x01               | clk_uart1_src_div<br>Divide clk_uart1_src by (div_con + 1).                                                                        |
| 1:0        | RW          | 0x2                | sclk_uart0_src_sel<br>sclk_uart0_src clock mux.<br>2'b00: clk_uart0_src<br>2'b01: clk_uart0_frac<br>2'b10: xin_osc0_func           |

**CRU CLKSEL CON08**

Address: Operational Base + offset (0x0320)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x001403de         | clk_uart1_frac_div<br>clk_uart1_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON09**

Address: Operational Base + offset (0x0324)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8  | RO   | 0x00        | reserved                                                                                                                           |
| 7     | RW   | 0x0         | clk_uart2_src_sel<br>clk_uart2_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                          |
| 6:2   | RW   | 0x01        | clk_uart2_src_div<br>Divide clk_uart2_src by (div_con + 1).                                                                        |
| 1:0   | RW   | 0x2         | sclk_uart1_src_sel<br>sclk_uart1_src clock mux.<br>2'b00: clk_uart1_src<br>2'b01: clk_uart1_frac<br>2'b10: xin_osc0_func           |

**CRU CLKSEL CON10**

Address: Operational Base + offset (0x0328)

| Bit  | Attr | Reset Value | Description                                                                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x001403de  | clk_uart2_frac_div<br>clk_uart2_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON11**

Address: Operational Base + offset (0x032C)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8  | RO   | 0x00        | reserved                                                                                                                           |
| 7     | RW   | 0x0         | clk_uart3_src_sel<br>clk_uart3_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                          |
| 6:2   | RW   | 0x01        | clk_uart3_src_div<br>Divide clk_uart3_src by (div_con + 1).                                                                        |
| 1:0   | RW   | 0x2         | sclk_uart2_src_sel<br>sclk_uart2_src clock mux.<br>2'b00: clk_uart2_src<br>2'b01: clk_uart2_frac<br>2'b10: xin_osc0_func           |

**CRU CLKSEL CON12**

Address: Operational Base + offset (0x0330)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x001403de         | clk_uart3_frac_div<br>clk_uart3_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON13**

Address: Operational Base + offset (0x0334)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | clk_uart4_src_sel<br>clk_uart4_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                          |
| 6:2        | RW          | 0x01               | clk_uart4_src_div<br>Divide clk_uart4_src by (div_con + 1).                                                                        |
| 1:0        | RW          | 0x2                | sclk_uart3_src_sel<br>sclk_uart3_src clock mux.<br>2'b00: clk_uart3_src<br>2'b01: clk_uart3_frac<br>2'b10: xin_osc0_func           |

**CRU CLKSEL CON14**

Address: Operational Base + offset (0x0338)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x001403de         | clk_uart4_frac_div<br>clk_uart4_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON15**

Address: Operational Base + offset (0x033C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | clk_uart5_src_sel<br>clk_uart5_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                |
| 6:2        | RW          | 0x01               | clk_uart5_src_div<br>Divide clk_uart5_src by (div_con + 1).                                                              |
| 1:0        | RW          | 0x2                | sclk_uart4_src_sel<br>sclk_uart4_src clock mux.<br>2'b00: clk_uart4_src<br>2'b01: clk_uart4_frac<br>2'b10: xin_osc0_func |

**CRU CLKSEL CON16**

Address: Operational Base + offset (0x0340)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x001403de         | clk_uart5_frac_div<br>clk_uart5_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON17**

Address: Operational Base + offset (0x0344)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | clk_i2s0_8ch_tx_src_sel<br>clk_i2s0_8ch_tx_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                              |
| 6:2        | RW          | 0x01               | clk_i2s0_8ch_tx_src_div<br>Divide clk_i2s0_8ch_tx_src by (div_con + 1).                                                            |
| 1:0        | RW          | 0x2                | sclk_uart5_src_sel<br>sclk_uart5_src clock mux.<br>2'b00: clk_uart5_src<br>2'b01: clk_uart5_frac<br>2'b10: xin_osc0_func           |

**CRU CLKSEL CON18**

Address: Operational Base + offset (0x0348)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x03355460         | clk_i2s0_8ch_tx_frac_div<br>clk_i2s0_8ch_tx_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON19**

Address: Operational Base + offset (0x034C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                               |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                                         |
| 7          | RW          | 0x0                | clk_i2s0_8ch_rx_src_sel<br>clk_i2s0_8ch_rx_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                                                            |
| 6:2        | RW          | 0x01               | clk_i2s0_8ch_rx_src_div<br>Divide clk_i2s0_8ch_rx_src by (div_con + 1).                                                                                                          |
| 1:0        | RW          | 0x3                | mclk_i2s0_8ch_tx_src_peri_sel<br>mclk_i2s0_8ch_tx_src_peri clock mux.<br>2'b00: clk_i2s0_8ch_tx_src<br>2'b01: clk_i2s0_8ch_tx_frac<br>2'b10: i2s0_mclkin<br>2'b11: xin_osc0_half |

**CRU CLKSEL CON20**

Address: Operational Base + offset (0x0350)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x03355460         | clk_i2s0_8ch_rx_frac_div<br>clk_i2s0_8ch_rx_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON21**

Address: Operational Base + offset (0x0354)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x2                | i2s0_8ch_mclkout_sel<br>i2s0_8ch_mclkout clock mux.<br>2'b00: mclk_i2s0_8ch_tx_src_peri<br>2'b01: mclk_i2s0_8ch_rx_src_peri<br>2'b10: xin_osc0_half                              |
| 1:0        | RW          | 0x3                | mclk_i2s0_8ch_rx_src_peri_sel<br>mclk_i2s0_8ch_rx_src_peri clock mux.<br>2'b00: clk_i2s0_8ch_rx_src<br>2'b01: clk_i2s0_8ch_rx_frac<br>2'b10: i2s0_mclkin<br>2'b11: xin_osc0_half |

**CRU CLKSEL CON23**

Address: Operational Base + offset (0x035C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13:9       | RW          | 0x00               | clk_ref_pvtpll_0_div<br>Divide clk_ref_pvtpll_0 by (div_con + 1).                                                                  |
| 8          | RW          | 0x0                | dclk_vop_src_sel<br>dclk_vop_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                            |
| 7:3        | RW          | 0x07               | dclk_vop_src_div<br>Divide dclk_vop_src by (div_con + 1).                                                                          |
| 2:0        | RO          | 0x0                | reserved                                                                                                                           |

**CRU CLKSEL CON24**

Address: Operational Base + offset (0x0360)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13:12      | RW          | 0x0                | clk_testout_top2vepu_sel<br>clk_testout_top2vepu clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: pclk_top_root  |
| 11:7       | RW          | 0x0b               | clk_testout_top2vepu_div<br>Divide clk_testout_top2vepu by (div_con + 1).                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 6:5        | RW          | 0x0                | pclk_top_root_sel<br>pclk_top_root clock mux.<br>2'b00: clk_matrix_100m_src<br>2'b01: clk_matrix_50m_src<br>2'b10: xin_osc0_func |
| 4:0        | RW          | 0x00               | clk_ref_pvtpll_1_div<br>Divide clk_ref_pvtpll_1 by (div_con + 1).                                                                |

**CRU CLKSEL CON25**

Address: Operational Base + offset (0x0364)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | clk_ref_mipi0_src_sel<br>clk_ref_mipi0_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                  |
| 6:2        | RW          | 0x01               | clk_ref_mipi0_src_div<br>Divide clk_ref_mipi0_src by (div_con + 1).                                                                |
| 1:0        | RO          | 0x0                | reserved                                                                                                                           |

**CRU CLKSEL CON26**

Address: Operational Base + offset (0x0368)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x001403de         | clk_ref_mipi0_frac_div<br>clk_ref_mipi0_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON27**

Address: Operational Base + offset (0x036C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | clk_ref_mipi1_src_sel<br>clk_ref_mipi1_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 6:2        | RW          | 0x01               | clk_ref_mipi1_src_div<br>Divide clk_ref_mipi1_src by (div_con + 1).                                                                    |
| 1:0        | RW          | 0x2                | clk_ref_mipi0_out_sel<br>clk_ref_mipi0_out clock mux.<br>2'b00: clk_ref_mipi0_src<br>2'b01: clk_ref_mipi0_frac<br>2'b10: xin_osc0_func |

**CRU CLKSEL CON28**

Address: Operational Base + offset (0x0370)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x001403de         | clk_ref_mipi1_frac_div<br>clk_ref_mipi1_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON29**

Address: Operational Base + offset (0x0374)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable     |
| 15:8       | RO          | 0x00               | reserved                                                                                                                               |
| 7          | RW          | 0x0                | clk_vicap_m0_src_sel<br>clk_vicap_m0_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                        |
| 6:2        | RW          | 0x1                | clk_vicap_m0_src_div<br>Divide clk_vicap_m0_src by (div_con + 1).                                                                      |
| 1:0        | RW          | 0x2                | clk_ref_mipi1_out_sel<br>clk_ref_mipi1_out clock mux.<br>2'b00: clk_ref_mipi1_src<br>2'b01: clk_ref_mipi1_frac<br>2'b10: xin_osc0_func |

**CRU CLKSEL CON30**

Address: Operational Base + offset (0x0378)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x001403de         | clk_vicap_m0_frac_div<br>clk_vicap_m0_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON31**

Address: Operational Base + offset (0x037C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | clk_vicap_m1_src_sel<br>clk_vicap_m1_src clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                    |
| 6:2        | RW          | 0x01               | clk_vicap_m1_src_div<br>Divide clk_vicap_m1_src by (div_con + 1).                                                                  |
| 1:0        | RW          | 0x2                | clk_vicap_m0_out_sel<br>clk_vicap_m0_out clock mux.<br>2'b00: clk_vicap_m0_src<br>2'b01: clk_vicap_m0_frac<br>2'b10: xin_osc0_func |

**CRU CLKSEL CON32**

Address: Operational Base + offset (0x0380)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x001403de         | clk_vicap_m1_frac_div<br>clk_vicap_m1_frac fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON33**

Address: Operational Base + offset (0x0384)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                           |
| 1:0        | RW          | 0x2                | clk_vicap_m1_out_sel<br>clk_vicap_m1_out clock mux.<br>2'b00: clk_vicap_m1_src<br>2'b01: clk_vicap_m1_frac<br>2'b10: xin_osc0_func |

**CRU GATE CON00**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_uart1_frac_en<br>clk_uart1_frac clock gating control.<br>When high, disable clock                                              |
| 14         | RW          | 0x0                | clk_uart1_en<br>clk_uart1_src clock gating control.<br>When high, disable clock                                                    |
| 13         | RW          | 0x0                | sclk_uart0_en<br>sclk_uart0_src clock gating control.<br>When high, disable clock                                                  |
| 12         | RW          | 0x0                | clk_uart0_frac_en<br>clk_uart0_frac clock gating control.<br>When high, disable clock                                              |
| 11         | RW          | 0x0                | clk_uart0_en<br>clk_uart0_src clock gating control.<br>When high, disable clock                                                    |
| 10         | RW          | 0x0                | clk_matrix_500m_src_en<br>clk_matrix_500m_src clock gating control.<br>When high, disable clock                                    |
| 9          | RW          | 0x0                | clk_matrix_450m_src_en<br>clk_matrix_450m_src clock gating control.<br>When high, disable clock                                    |
| 8          | RW          | 0x0                | clk_matrix_400m_src_en<br>clk_matrix_400m_src clock gating control.<br>When high, disable clock                                    |
| 7          | RW          | 0x0                | clk_matrix_339m_src_en<br>clk_matrix_339m_src clock gating control.<br>When high, disable clock                                    |
| 6          | RW          | 0x0                | clk_matrix_300m_src_en<br>clk_matrix_300m_src clock gating control.<br>When high, disable clock                                    |
| 5          | RW          | 0x0                | clk_matrix_250m_src_en<br>clk_matrix_250m_src clock gating control.<br>When high, disable clock                                    |
| 4          | RW          | 0x0                | clk_matrix_200m_src_en<br>clk_matrix_200m_src clock gating control.<br>When high, disable clock                                    |
| 3          | RW          | 0x0                | clk_matrix_150m_src_en<br>clk_matrix_150m_src clock gating control.<br>When high, disable clock                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | clk_matrix_100m_src_en<br>clk_matrix_100m_src clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | clk_matrix_50m_src_en<br>clk_matrix_50m_src clock gating control.<br>When high, disable clock   |
| 0          | RO          | 0x0                | reserved                                                                                        |

**CRU GATE CON01**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | mclk_i2s0_8ch_tx_src_en<br>mclk_i2s0_8ch_tx_src_peri clock gating control.<br>When high, disable clock                             |
| 14         | RW          | 0x0                | clk_i2s0_8ch_frac_tx_en<br>clk_i2s0_8ch_tx_frac clock gating control.<br>When high, disable clock                                  |
| 13         | RW          | 0x0                | clk_i2s0_8ch_tx_en<br>clk_i2s0_8ch_tx_src clock gating control.<br>When high, disable clock                                        |
| 12         | RW          | 0x0                | sclk_uart5_en<br>sclk_uart5_src clock gating control.<br>When high, disable clock                                                  |
| 11         | RW          | 0x0                | clk_uart5_frac_en<br>clk_uart5_frac clock gating control.<br>When high, disable clock                                              |
| 10         | RW          | 0x0                | clk_uart5_en<br>clk_uart5_src clock gating control.<br>When high, disable clock                                                    |
| 9          | RW          | 0x0                | sclk_uart4_en<br>sclk_uart4_src clock gating control.<br>When high, disable clock                                                  |
| 8          | RW          | 0x0                | clk_uart4_frac_en<br>clk_uart4_frac clock gating control.<br>When high, disable clock                                              |
| 7          | RW          | 0x0                | clk_uart4_en<br>clk_uart4_src clock gating control.<br>When high, disable clock                                                    |
| 6          | RW          | 0x0                | sclk_uart3_en<br>sclk_uart3_src clock gating control.<br>When high, disable clock                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | clk_uart3_frac_en<br>clk_uart3_frac clock gating control.<br>When high, disable clock |
| 4          | RW          | 0x0                | clk_uart3_en<br>clk_uart3_src clock gating control.<br>When high, disable clock       |
| 3          | RW          | 0x0                | sclk_uart2_en<br>sclk_uart2_src clock gating control.<br>When high, disable clock     |
| 2          | RW          | 0x0                | clk_uart2_frac_en<br>clk_uart2_frac clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | clk_uart2_en<br>clk_uart2_src clock gating control.<br>When high, disable clock       |
| 0          | RW          | 0x0                | sclk_uart1_en<br>sclk_uart1_src clock gating control.<br>When high, disable clock     |

**CRU\_GATE\_CON02**

Address: Operational Base + offset (0x0808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x1                | clk_cplltest_en<br>clk_cplltest clock gating control.<br>When high, disable clock                                                  |
| 14         | RW          | 0x1                | clk_dplltest_en<br>clk_dplltest clock gating control.<br>When high, disable clock                                                  |
| 13         | RW          | 0x1                | clk_aplltest_en<br>clk_aplltest clock gating control.<br>When high, disable clock                                                  |
| 12         | RW          | 0x0                | clk_testout_en<br>clk_testout_top2vepu clock gating control.<br>When high, disable clock                                           |
| 11         | RW          | 0x0                | pclk_cru_biu_en<br>pclk_cru_biu clock gating control.<br>When high, disable clock                                                  |
| 10         | RW          | 0x0                | pclk_cru_en<br>pclk_cru clock gating control.<br>When high, disable clock                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | pclk_top_root_en<br>pclk_top_root clock gating control.<br>When high, disable clock                |
| 8          | RW          | 0x0                | clk_ref_pvtpll_1_en<br>clk_ref_pvtpll_1 clock gating control.<br>When high, disable clock          |
| 7          | RW          | 0x0                | clk_ref_pvtpll_0_en<br>clk_ref_pvtpll_0 clock gating control.<br>When high, disable clock          |
| 6          | RW          | 0x0                | dclk_vop_src_en<br>dclk_vop_src clock gating control.<br>When high, disable clock                  |
| 5:3        | RO          | 0x0                | reserved                                                                                           |
| 2          | RW          | 0x0                | mclk_i2s0_8ch_rx_en<br>mclk_i2s0_8ch_rx_src_peri clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | clk_i2s0_8ch_frac_rx_en<br>clk_i2s0_8ch_rx_frac clock gating control.<br>When high, disable clock  |
| 0          | RW          | 0x0                | clk_i2s0_8ch_rx_en<br>clk_i2s0_8ch_rx_src clock gating control.<br>When high, disable clock        |

**CRU GATE CON03**

Address: Operational Base + offset (0x080C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_vicap_m1_out_en<br>clk_vicap_m1_out clock gating control.<br>When high, disable clock                                          |
| 14         | RW          | 0x0                | clk_vicap_m1_frac_en<br>clk_vicap_m1_frac clock gating control.<br>When high, disable clock                                        |
| 13         | RW          | 0x0                | clk_vicap_m1_src_en<br>clk_vicap_m1_src clock gating control.<br>When high, disable clock                                          |
| 12         | RW          | 0x0                | clk_vicap_m0_out_en<br>clk_vicap_m0_out clock gating control.<br>When high, disable clock                                          |
| 11         | RW          | 0x0                | clk_vicap_m0_frac_en<br>clk_vicap_m0_frac clock gating control.<br>When high, disable clock                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | clk_vicap_m0_src_en<br>clk_vicap_m0_src clock gating control.<br>When high, disable clock     |
| 9          | RW          | 0x0                | clk_ref_mipi1_out_en<br>clk_ref_mipi1_out clock gating control.<br>When high, disable clock   |
| 8          | RW          | 0x0                | clk_ref_mipi1_frac_en<br>clk_ref_mipi1_frac clock gating control.<br>When high, disable clock |
| 7          | RW          | 0x0                | clk_ref_mipi1_src_en<br>clk_ref_mipi1_src clock gating control.<br>When high, disable clock   |
| 6          | RW          | 0x0                | clk_ref_mipi0_out_en<br>clk_ref_mipi0_out clock gating control.<br>When high, disable clock   |
| 5          | RW          | 0x0                | clk_ref_mipi0_frac_en<br>clk_ref_mipi0_frac clock gating control.<br>When high, disable clock |
| 4          | RW          | 0x0                | clk_ref_mipi0_src_en<br>clk_ref_mipi0_src clock gating control.<br>When high, disable clock   |
| 3:1        | RO          | 0x0                | reserved                                                                                      |
| 0          | RW          | 0x1                | clk_gplltest_en<br>clk_gplltest clock gating control.<br>When high, disable clock             |

**CRU SOFTRST CON02**

Address: Operational Base + offset (0x0A08)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | presetn_cru_biu<br>When high, reset relative logic                                                                                 |
| 10         | RW          | 0x0                | presetn_cru<br>When high, reset relative logic                                                                                     |
| 9          | RO          | 0x0                | reserved                                                                                                                           |
| 8          | RW          | 0x0                | resetn_ref_pvtpll_1<br>When high, reset relative logic                                                                             |
| 7          | RW          | 0x0                | resetn_ref_pvtpll_0<br>When high, reset relative logic                                                                             |
| 6:0        | RO          | 0x00               | reserved                                                                                                                           |

**CRU GLB CNT TH**

Address: Operational Base + offset (0x0C00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0064             | Reserved                                                                                                                                         |
| 15:0       | RW          | 0x0064             | global_reset_counter_threshold<br>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 (0x0C04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                                                                              |
| 11         | RW          | 0x0                | wdt0_src_st<br>If High, glbrst by wdt0_src                                                                                                                                                            |
| 10:7       | RO          | 0x0                | reserved                                                                                                                                                                                              |
| 6          | RW          | 0x0                | glbrst_wdt0_rst<br>If High, global reset by WDT0                                                                                                                                                      |
| 5          | RW          | 0x0                | snd_glb_wdt_RST_st<br>sencond global WDT triggered reset flag<br>1'b0: Last hot reset is not sencond global WDT triggered reset<br>1'b1: Last hot reset is sencond global WDT triggered reset         |
| 4          | RW          | 0x0                | fst_glb_wdt_RST_st<br>first global WDT triggered reset flag<br>1'b0: Last hot reset is not first global WDT triggered reset<br>1'b1: Last hot reset is first global WDT triggered reset               |
| 3          | RW          | 0x0                | snd_glb_tsadc_RST_st<br>sencond global TSADC triggered reset flag<br>1'b0: Last hot reset is not sencond global TSADC triggered reset<br>1'b1: Last hot reset is sencond global TSADC triggered reset |
| 2          | RW          | 0x0                | fst_glb_tsadc_RST_st<br>first global TSADC triggered reset flag<br>1'b0: Last hot reset is not first global TSADC triggered reset<br>1'b1: Last hot reset is first global TSADC triggered reset       |
| 1          | RW          | 0x0                | snd_glb_RST_st<br>second global rst flag<br>1'b0: Last hot reset is not sencond global reset<br>1'b1: Last hot reset is sencond global reset                                                          |
| 0          | RW          | 0x0                | fst_glb_RST_st<br>first global rst flag<br>1'b0: Last hot reset is not first global reset<br>1'b1: Last hot reset is first global reset                                                               |

**CRU GLB SRST FST**

Address: Operational Base + offset (0x0C08)

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

**CRU GLB SRST SND**

Address: Operational Base + offset (0x0C0C)

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

**CRU GLB\_RST\_CON**

Address: Operational Base + offset (0x0C10)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x000000           | reserved                                                                                                                                                           |
| 11         | RW          | 0x0                | cru_wdt0_con<br>1'b0: Wdt0 trigger second global reset<br>1'b1: Wdt0 trigger first global reset                                                                    |
| 10:7       | RO          | 0x0                | reserved                                                                                                                                                           |
| 6          | RW          | 0x0                | cru_wdt0_en<br>1'b0: Wdt0 trigger global reset disable<br>1'b1: Wdt0 trigger global reset enable                                                                   |
| 5          | RO          | 0x0                | reserved                                                                                                                                                           |
| 4          | RW          | 0x0                | pmu_srst_wdt_en<br>0: Enable Wdt reset as pmu reset source<br>1: Disable Wdt reset as pmu reset source                                                             |
| 3          | RW          | 0x0                | pmu_srst_glb_en<br>1'b0: global reset trigger pmu reset<br>1'b1: global reset dont trigger pmu reset                                                               |
| 2          | RW          | 0x0                | pmu_srst_glb_ctrl<br>0: Enable first global reset as pmu reset source<br>1: Enable second global reset as pmu reset source<br>effective when glb_rst_con[3] enable |
| 1          | RW          | 0x0                | tsadc_glb_srst_en<br>1'b0: tsadc trigger global reset disable<br>1'b1: tsadc trigger global reset enable                                                           |
| 0          | RW          | 0x0                | tsadc_glb_srst_ctrl<br>1'b0: tsadc trigger second global reset<br>1'b1: tsadc trigger first global reset                                                           |

**2.5 CORECRU Register Description****2.5.1 Registers Summary**

| Name                         | Offset | Size | Reset Value | Description                                   |
|------------------------------|--------|------|-------------|-----------------------------------------------|
| CORECRU CORECLKSEL CON00     | 0x0300 | W    | 0x00000081  | Internal clock select and division register 0 |
| CORECRU CORECLKSEL CON01     | 0x0304 | W    | 0x00003847  | Internal clock select and division register 1 |
| CORECRU CORECLKSEL CON02     | 0x0308 | W    | 0x00000005  | Internal clock select and division register 2 |
| CORECRU CORECLKSEL CON03     | 0x030C | W    | 0x000000C0  | Internal clock select and division register 3 |
| CORECRU CORECLKSEL CON04     | 0x0310 | W    | 0x00000009  | Internal clock select and division register 4 |
| CORECRU COREGATE CO N00      | 0x0800 | W    | 0x00000000  | Internal clock gate and division register 0   |
| CORECRU COREGATE CO N01      | 0x0804 | W    | 0x00000000  | Internal clock gate and division register 1   |
| CORECRU CORESOFRST CON00     | 0x0A00 | W    | 0x00000100  | Internal clock reset register 0               |
| CORECRU CORESOFRST CON01     | 0x0A04 | W    | 0x0000001E  | Internal clock reset register 1               |
| CORECRU AUTOCS CORE SRC CON0 | 0x0D00 | W    | 0x00040014  | Pdcore auto clock switch control 0            |
| CORECRU AUTOCS CORE SRC CON1 | 0x0D04 | W    | 0x00000000  | Pdcore auto clock switch control 1            |

Notes:Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 2.5.2 Detail Registers Description

### CORECRU CORECLKSEL CON00

Address: Operational Base + offset (0x0300)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:13 | RO   | 0x0         | reserved                                                                                                                           |
| 12    | RW   | 0x0         | clk_core_pvtpll_src_sel<br>clk_core_pvtpll_src clock mux.<br>1'b0: clk_deepslow<br>1'b1: clk_core_pvtpll                           |
| 11:7  | RW   | 0x01        | aclk_m_core_biu_div<br>Divide aclk_m_core_biu by (div_con + 1).                                                                    |
| 6:5   | RW   | 0x0         | clk_core_src_sel<br>clk_core_src clock mux.<br>2'b00: clk_apll_mux<br>2'b01: clk_core_pvtpll_src<br>2'b10: clk_core_gpll_src       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 4:0        | RW          | 0x01               | clk_core_gpll_src_div<br>Divide clk_core_gpll_src by (div_con + 1). |

**CORECRU CORECLKSEL CON01**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:11      | RW          | 0x07               | clk_scanhs_pclk_dbg_div<br>Divide clk_scanhs_pclk_dbg by (div_con + 1).                                                            |
| 10:6       | RW          | 0x01               | clk_scanhs_aclkm_core_div<br>Divide clk_scanhs_aclkm_core by (div_con + 1).                                                        |
| 5          | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x07               | pclk_dbg_div<br>Divide pclk_dbg by (div_con + 1).                                                                                  |

**CORECRU CORECLKSEL CON02**

Address: Operational Base + offset (0x0308)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:6       | RO          | 0x000              | reserved                                                                                                                           |
| 5          | RW          | 0x0                | hclk_cpu_biu_sel<br>hclk_cpu_biu clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: xin_osc0_func                                           |
| 4:0        | RW          | 0x05               | hclk_cpu_biu_div<br>Divide hclk_cpu_biu by (div_con + 1).                                                                          |

**CORECRU CORECLKSEL CON03**

Address: Operational Base + offset (0x030C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | clk_core_mcu_sel<br>clk_core_mcu clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: xin_osc0_func                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 10:6       | RW          | 0x03               | clk_core_mcu_div<br>Divide clk_core_mcu by (div_con + 1).                                          |
| 5          | RW          | 0x0                | clk_ref_pvtpll_core_sel<br>clk_ref_pvtpll_core clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_core |
| 4:0        | RW          | 0x00               | clk_ref_pvtpll_core_div<br>Divide clk_ref_pvtpll_core by (div_con + 1).                            |

**CORECRU CORECLKSEL CON04**

Address: Operational Base + offset (0x0310)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                 |
| 15:7       | RO          | 0x000              | reserved                                                                                                                                           |
| 6:5        | RW          | 0x0                | clk_testout_core2vi_sel<br>clk_testout_core2vi clock mux.<br>2'b00: clk_core<br>2'b01: clk_core_mcu<br>2'b10: pclk_cpu_root<br>2'b11: hclk_cpu_biu |
| 4:0        | RW          | 0x09               | clk_testout_core2vi_div<br>Divide clk_testout_core2vi by (div_con + 1).                                                                            |

**CORECRU COREGATE CON00**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | pclk_pvtm_core_en<br>pclk_pvtm_core clock gating control.<br>When high, disable clock                                              |
| 14         | RW          | 0x0                | clk_pvtm_core_en<br>clk_pvtm_core clock gating control.<br>When high, disable clock                                                |
| 13         | RW          | 0x0                | pclk_cpu_biu_en<br>pclk_cpu_biu clock gating control.<br>When high, disable clock                                                  |
| 12         | RW          | 0x0                | hclk_cpu_biu_en<br>hclk_cpu_biu clock gating control.<br>When high, disable clock                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | pclk_core_grf_en<br>pclk_core_grf clock gating control.<br>When high, disable clock         |
| 10         | RW          | 0x0                | pclk_cpu_root_en<br>pclk_cpu_root clock gating control.<br>When high, disable clock         |
| 9          | RW          | 0x0                | clk_scanhs_core_en<br>clk_scanhs_core clock gating control.<br>When high, disable clock     |
| 8          | RW          | 0x0                | swclk_tck_en<br>swclk_tck clock gating control.<br>When high, disable clock                 |
| 7          | RO          | 0x0                | reserved                                                                                    |
| 6          | RW          | 0x0                | pclk_dbg_en<br>pclk_dbg clock gating control.<br>When high, disable clock                   |
| 5          | RW          | 0x0                | ack_m_core_biu_en<br>ack_m_core_biu clock gating control.<br>When high, disable clock       |
| 4:3        | RO          | 0x0                | reserved                                                                                    |
| 2          | RW          | 0x0                | clk_core_en<br>clk_core clock gating control.<br>When high, disable clock                   |
| 1          | RW          | 0x0                | clk_core_src_en<br>clk_core_src clock gating control.<br>When high, disable clock           |
| 0          | RW          | 0x0                | clk_core_gpll_src_en<br>clk_core_gpll_src clock gating control.<br>When high, disable clock |

**CORECRU COREGATE CON01**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13         | RW          | 0x0                | clk_testout_core_en<br>clk_testout_core2vi clock gating control.<br>When high, disable clock                                       |
| 12         | RW          | 0x0                | hclk_cache_en<br>hclk_cache clock gating control.<br>When high, disable clock                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | pclk_core_sgrf_en<br>pclk_core_sgrf clock gating control.<br>When high, disable clock           |
| 10         | RW          | 0x0                | pclk_core_cru_en<br>pclk_core_cru clock gating control.<br>When high, disable clock             |
| 9          | RW          | 0x0                | pclk_intmux_en<br>pclk_intmux clock gating control.<br>When high, disable clock                 |
| 8          | RW          | 0x0                | pclk_mailbox_en<br>pclk_mailbox clock gating control.<br>When high, disable clock               |
| 7          | RW          | 0x0                | clk_core_mcu_jtag_en<br>clk_core_mcu_jtag clock gating control.<br>When high, disable clock     |
| 6          | RW          | 0x0                | clk_core_mcu_RTC_en<br>clk_core_mcu_RTC clock gating control.<br>When high, disable clock       |
| 5          | RW          | 0x0                | clk_core_mcu_biu_en<br>clk_core_mcu_biu clock gating control.<br>When high, disable clock       |
| 4:2        | RO          | 0x0                | reserved                                                                                        |
| 1          | RW          | 0x0                | clk_core_mcu_en<br>clk_core_mcu clock gating control.<br>When high, disable clock               |
| 0          | RW          | 0x0                | clk_ref_pvtpll_core_en<br>clk_ref_pvtpll_core clock gating control.<br>When high, disable clock |

**CORECRU CORESOFRST CON00**

Address: Operational Base + offset (0x0A00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | presetn_pvtm_core<br>When high, reset relative logic                                                                               |
| 14         | RW          | 0x0                | resetn_pvtm_core<br>When high, reset relative logic                                                                                |
| 13         | RW          | 0x0                | presetn_cpu_biu<br>When high, reset relative logic                                                                                 |
| 12         | RW          | 0x0                | hresetn_cpu_biu<br>When high, reset relative logic                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 11         | RW          | 0x0                | presetn_core_grf<br>When high, reset relative logic   |
| 10:9       | RO          | 0x0                | reserved                                              |
| 8          | RW          | 0x1                | ntresetn_dbg<br>When high, reset relative logic       |
| 7          | RW          | 0x0                | potresetn_dbg<br>When high, reset relative logic      |
| 6          | RW          | 0x0                | presetn_dbg<br>When high, reset relative logic        |
| 5          | RW          | 0x0                | aresetn_m_core_biu<br>When high, reset relative logic |
| 4          | RW          | 0x0                | nl2reset<br>When high, reset relative logic           |
| 3          | RW          | 0x0                | ndbgreset<br>When high, reset relative logic          |
| 2          | RW          | 0x0                | ncoreset<br>When high, reset relative logic           |
| 1          | RW          | 0x0                | ncoreporeset<br>When high, reset relative logic       |
| 0          | RO          | 0x0                | reserved                                              |

**CORECRU CORESOFTRST CON01**

Address: Operational Base + offset (0x0A04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12         | RW          | 0x0                | hresetn_cache<br>When high, reset relative logic                                                                                   |
| 11         | RW          | 0x0                | presetn_core_sgrf<br>When high, reset relative logic                                                                               |
| 10         | RW          | 0x0                | presetn_core_cru<br>When high, reset relative logic                                                                                |
| 9          | RW          | 0x0                | presetn_intmux<br>When high, reset relative logic                                                                                  |
| 8          | RW          | 0x0                | presetn_mailbox<br>When high, reset relative logic                                                                                 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                           |
| 5          | RW          | 0x0                | resetn_mcu_biu<br>When high, reset relative logic                                                                                  |
| 4          | RW          | 0x1                | tresetn_core_mcu_cpu<br>When high, reset relative logic                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 3          | RW          | 0x1                | resetn_core_mcu_cpu<br>When high, reset relative logic    |
| 2          | RW          | 0x1                | resetn_core_mcu_pwrup<br>When high, reset relative logic  |
| 1          | RW          | 0x1                | resetn_core_mcu<br>When high, reset relative logic        |
| 0          | RW          | 0x0                | resetn_ref_pvtpll_core<br>When high, reset relative logic |

**CORECRU\_AUTOCS\_CORE\_SRC\_CON0**

Address: Operational Base + offset (0x0D00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0004             | clk_core_src_wait_th<br>wait_th<br>Wait time threshold, measured by original clk_core_src |
| 15:0       | RW          | 0x0014             | clk_core_src_idle_th<br>idle_th<br>Idle time threshold, measured by original clk_core_src |

**CORECRU\_AUTOCS\_CORE\_SRC\_CON1**

Address: Operational Base + offset (0x0D04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                        |
| 15:14      | RW          | 0x0                | clk_core_src_clksel_cfg<br>Auto switch clock selection as clk_core_src<br>2'b00: Original clk_core_src<br>2'b01: xin_osc0_func_div<br>2'b10: clk_RTC_32k  |
| 13         | RW          | 0x0                | clk_core_src_switch_en<br>switch_en<br>1'b1: Enable clk_core_src switch to lower frequency when module is inactive.<br>1'b0: Disable auto switch fuction. |
| 12         | RW          | 0x0                | clk_core_src_autoctrl_en<br>autoctrl_en<br>1'b1: Enable clk_core_src switch to lower frequency.<br>1'b0: Disable.                                         |
| 11:0       | RW          | 0x000              | clk_core_src_autoctrl_ctrl<br>autoctrl_ctrl<br>12'hffff: Enable clk_core_src switch to lower frequency.<br>12'h000: Disable.                              |

## 2.6 DDRCRU Register Description

### 2.6.1 Registers Summary

| Name                           | Offset | Size | Reset Value | Description                                   |
|--------------------------------|--------|------|-------------|-----------------------------------------------|
| <u>DDRCRU DDRCLKSEL CON00</u>  | 0x0300 | W    | 0x00001000  | Internal clock select and division register 0 |
| <u>DDRCRU DDRGATE CON00</u>    | 0x0800 | W    | 0x00000000  | Internal clock gate and division register 0   |
| <u>DDRCRU DDRGATE CON01</u>    | 0x0804 | W    | 0x00000000  | Internal clock gate and division register 1   |
| <u>DDRCRU DDRSOFTRST CON00</u> | 0x0A00 | W    | 0x00000000  | Internal clock reset register 0               |
| <u>DDRCRU DDRSOFTRST CON01</u> | 0x0A04 | W    | 0x00000000  | Internal clock reset register 1               |

Notes:B- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 2.6.2 Detail Registers Description

#### DDRCRU DDRCLKSEL CON00

Address: Operational Base + offset (0x0300)

| Bit   | Attr | Reset Value | Description                                                                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                              |
| 15    | RW   | 0x0         | clk_testout_ddr2peri_sel<br>clk_testout_ddr2peri clock mux.<br>1'b0: aclk_ddr_root<br>1'b1: clk_core_ddrc                                                       |
| 14:10 | RW   | 0x04        | clk_testout_ddr2peri_div<br>Divide clk_testout_ddr2peri by (div_con + 1).                                                                                       |
| 9:8   | RW   | 0x0         | aclk_ddr_root_sel<br>aclk_ddr_root clock mux.<br>2'b00: clk_matrix_500m_src<br>2'b01: clk_matrix_300m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func |
| 7:2   | RO   | 0x00        | reserved                                                                                                                                                        |
| 1:0   | RW   | 0x0         | pclk_ddr_root_sel<br>pclk_ddr_root clock mux.<br>2'b00: clk_matrix_100m_src<br>2'b01: clk_matrix_50m_src<br>2'b10: xin_osc0_func                                |

#### DDRCRU DDRGATE CON00

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | pclk_ddr_grf_en<br>pclk_ddr_grf clock gating control.<br>When high, disable clock                                                  |
| 14         | RW          | 0x0                | ackl_shrm_biu_en<br>ackl_shrm_biu clock gating control.<br>When high, disable clock                                                |
| 13         | RW          | 0x0                | ackl_sys_shrm_en<br>ackl_sys_shrm clock gating control.<br>When high, disable clock                                                |
| 12         | RW          | 0x0                | ackl_ddr_root_en<br>ackl_ddr_root clock gating control.<br>When high, disable clock                                                |
| 11         | RW          | 0x0                | pclk_dfictrl_en<br>pclk_dfictrl clock gating control.<br>When high, disable clock                                                  |
| 10:9       | RO          | 0x0                | reserved                                                                                                                           |
| 8          | RW          | 0x0                | clk_timer_ddrmon_en<br>clk_timer_ddrmon clock gating control.<br>When high, disable clock                                          |
| 7          | RW          | 0x0                | pclk_ddrmon_en<br>pclk_ddrmon clock gating control.<br>When high, disable clock                                                    |
| 6          | RO          | 0x0                | reserved                                                                                                                           |
| 5          | RW          | 0x0                | pclk_ddrc_en<br>pclk_ddrc clock gating control.<br>When high, disable clock                                                        |
| 4:3        | RO          | 0x0                | reserved                                                                                                                           |
| 2          | RW          | 0x0                | pclk_ddr_biu_en<br>pclk_ddr_biu clock gating control.<br>When high, disable clock                                                  |
| 1          | RO          | 0x0                | reserved                                                                                                                           |
| 0          | RW          | 0x0                | pclk_ddr_root_en<br>pclk_ddr_root clock gating control.<br>When high, disable clock                                                |

**DDRCRU DDRGATE CON01**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                           |
| 6          | RW          | 0x0                | mbist_clk_clk_ddr_biumem_en<br>mbist_clk_clk_ddr_biumem clock gating control.<br>When high, disable clock                          |
| 5          | RW          | 0x0                | mbist_clk_clk_core_ddrc_en<br>mbist_clk_clk_core_ddrc clock gating control.<br>When high, disable clock                            |
| 4          | RO          | 0x0                | reserved                                                                                                                           |
| 3          | RW          | 0x0                | pclk_ddrphy_en<br>pclk_ddrphy clock gating control.<br>When high, disable clock                                                    |
| 2          | RW          | 0x0                | pclk_ddr_hwlp_en<br>pclk_ddr_hwlp clock gating control.<br>When high, disable clock                                                |
| 1          | RW          | 0x0                | clk_ddr_testout_en<br>clk_testout_ddr2peri clock gating control.<br>When high, disable clock                                       |
| 0          | RW          | 0x0                | pclk_ddr_cru_en<br>pclk_ddr_cru clock gating control.<br>When high, disable clock                                                  |

**DDRCRU DDRSOFTRST CON00**

Address: Operational Base + offset (0x0A00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | presetn_ddr_grf<br>When high, reset relative logic                                                                                 |
| 14         | RW          | 0x0                | aresetn_shrm_biu<br>When high, reset relative logic                                                                                |
| 13         | RW          | 0x0                | aresetn_sys_shrm<br>When high, reset relative logic                                                                                |
| 12         | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | presetn_dfictrl<br>When high, reset relative logic                                                                                 |
| 10:9       | RO          | 0x0                | reserved                                                                                                                           |
| 8          | RW          | 0x0                | resetn_timer_ddrmon<br>When high, reset relative logic                                                                             |

| Bit | Attr | Reset Value | Description                                        |
|-----|------|-------------|----------------------------------------------------|
| 7   | RW   | 0x0         | presetn_ddrmon<br>When high, reset relative logic  |
| 6   | RO   | 0x0         | reserved                                           |
| 5   | RW   | 0x0         | presetn_ddrc<br>When high, reset relative logic    |
| 4:3 | RO   | 0x0         | reserved                                           |
| 2   | RW   | 0x0         | presetn_ddr_biu<br>When high, reset relative logic |
| 1:0 | RO   | 0x0         | reserved                                           |

**DDRCRU DDRSOFTRST CON01**

Address: Operational Base + offset (0x0A04)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4  | RO   | 0x000       | reserved                                                                                                                           |
| 3     | RW   | 0x0         | presetn_ddrphy<br>When high, reset relative logic                                                                                  |
| 2     | RW   | 0x0         | presetn_ddr_hwlp<br>When high, reset relative logic                                                                                |
| 1     | RO   | 0x0         | reserved                                                                                                                           |
| 0     | RW   | 0x0         | presetn_ddr_cru<br>When high, reset relative logic                                                                                 |

**2.7 SUBDDRCRU Register Description****2.7.1 Registers Summary**

| Name                              | Offset | Size | Reset Value | Description                                   |
|-----------------------------------|--------|------|-------------|-----------------------------------------------|
| SUBDDRCRU SUBDDRMO<br>DE CON00    | 0x0280 | W    | 0x00000000  | Internal clock select and division register 0 |
| SUBDDRCRU SUBDDRCLK<br>SEL CON00  | 0x0300 | W    | 0x00000001  | Internal clock select and division register 0 |
| SUBDDRCRU SUBDDRG<br>TE CON00     | 0x0800 | W    | 0x00000000  | Internal clock gate and division register 0   |
| SUBDDRCRU SUBDDRSO<br>FTRST CON00 | 0x0A00 | W    | 0x00000040  | Internal clock reset register 0               |

Notes:  
**B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**-  
 Double WORD (64 bits) access

**2.7.2 Detail Registers Description****SUBDDRCRU SUBDDRMODE CON00**

Address: Operational Base + offset (0x0280)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                           |
| 1:0        | RW          | 0x0                | clk_dpll_mode<br>clk_dpll_mux clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_dpll<br>2'b10: clk_deepslow                         |

**SUBDDRCRU SUBDDRCLKSEL CON00**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:6       | RO          | 0x000              | reserved                                                                                                                           |
| 5          | RW          | 0x0                | clk_core_ddrc_src_sel<br>clk_core_ddrc_src clock mux.<br>1'b0: clk_dpll_mux<br>1'b1: clk_matrix_300m_src                           |
| 4:0        | RW          | 0x01               | clk_core_ddrc_src_div<br>DT50 division register.<br>Divide clk_core_ddrc_src by (div_con + 1).                                     |

**SUBDDRCRU SUBDDRGATE CON00**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                           |
| 6          | RW          | 0x0                | clk_ddr_phy_en<br>clk_ddr_phy clock gating control.<br>When high, disable clock                                                    |
| 5          | RW          | 0x0                | clk_dfictrl_en<br>clk_dfictrl clock gating control.<br>When high, disable clock                                                    |
| 4          | RW          | 0x0                | clk_ddrmon_en<br>clk_ddrmon clock gating control.<br>When high, disable clock                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | clk_core_ddrc_en<br>clk_core_ddrc clock gating control.<br>When high, disable clock         |
| 2          | RW          | 0x0                | clk_core_ddrc_src_en<br>clk_core_ddrc_src clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | ack_ddrc_en<br>ack_ddrc clock gating control.<br>When high, disable clock                   |
| 0          | RW          | 0x0                | clk_msch_biu_en<br>clk_msch_biu clock gating control.<br>When high, disable clock           |

**SUBDDRCRU SUBDDRSPTRST CON00**

Address: Operational Base + offset (0x0A00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                           |
| 6          | RW          | 0x1                | resetn_ddr_phy<br>When high, reset relative logic                                                                                  |
| 5          | RW          | 0x0                | resetn_dfcctrl<br>When high, reset relative logic                                                                                  |
| 4          | RW          | 0x0                | resetn_ddrmon<br>When high, reset relative logic                                                                                   |
| 3          | RW          | 0x0                | resetn_core_ddrc<br>When high, reset relative logic                                                                                |
| 2          | RO          | 0x0                | reserved                                                                                                                           |
| 1          | RW          | 0x0                | aresetn_ddrc<br>When high, reset relative logic                                                                                    |
| 0          | RW          | 0x0                | resetn_msch_biu<br>When high, reset relative logic                                                                                 |

**2.8 NPUCRU Register Description****2.8.1 Registers Summary**

| <b>Name</b>                    | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                            |
|--------------------------------|---------------|-------------|--------------------|-----------------------------------------------|
| <u>NPUCRU_NPUCLKSEL_CO_N00</u> | 0x0300        | W           | 0x000000100        | Internal clock select and division register 0 |
| <u>NPUCRU_NPUGATE_CON0_0</u>   | 0x0800        | W           | 0x000000000        | Internal clock gate and division register 0   |
| <u>NPUCRU_NPUGATE_CON0_1</u>   | 0x0804        | W           | 0x000000000        | Internal clock gate and division register 1   |

| Name                          | Offset | Size | Reset Value | Description                     |
|-------------------------------|--------|------|-------------|---------------------------------|
| <u>NPUCRU_NPUSOFRST_CON00</u> | 0x0A00 | W    | 0x00000000  | Internal clock reset register 0 |

Notes:Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 2.8.2 Detail Registers Description

### NPUCRU\_NPUCLKSEL\_CON00

Address: Operational Base + offset (0x0300)

| Bit   | Attr | Reset Value | Description                                                                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:13 | RO   | 0x0         | reserved                                                                                                                                                       |
| 12:11 | RW   | 0x0         | clk_testout_npu2vi_sel<br>clk_testout_npu2vi clock mux.<br>2'b00: aclk_npu_root<br>2'b01: hclk_npu_root<br>2'b10: pclk_npu_root                                |
| 10:6  | RW   | 0x04        | clk_testout_npu2vi_div<br>Divide clk_testout_npu2vi by (div_con + 1).                                                                                          |
| 5:4   | RW   | 0x0         | pclk_npu_root_sel<br>pclk_npu_root clock mux.<br>2'b00: clk_matrix_100m_src<br>2'b01: clk_matrix_50m_src<br>2'b10: xin_osc0_func                               |
| 3:2   | RW   | 0x0         | aclk_npu_root_sel<br>aclk_npu_root clock mux.<br>2'b00: clk_matrix_500m_src<br>2'b01: clk_matrix_300m_src<br>2'b10: clk_pvtpll_0<br>2'b11: clk_pvtpll_1        |
| 1:0   | RW   | 0x0         | hclk_npu_root_sel<br>hclk_npu_root clock mux.<br>2'b00: clk_matrix_150m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func |

### NPUCRU\_NPUGATE\_CON00

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_matrix_50m_src2vi_en<br>clk_matrix_50m_src2vi clock gating control.<br>When high, disable clock                                |
| 14:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12         | RW          | 0x0                | clk_pvtpll_1_i2vi_en<br>clk_pvtpll_1_i2vi clock gating control.<br>When high, disable clock                                        |
| 11         | RW          | 0x0                | clk_pvtpll_0_i2vi_en<br>clk_pvtpll_0_i2vi clock gating control.<br>When high, disable clock                                        |
| 10         | RW          | 0x0                | ackl_rknn_en<br>ackl_rknn clock gating control.<br>When high, disable clock                                                        |
| 9          | RW          | 0x0                | hclk_rknn_en<br>hclk_rknn clock gating control.<br>When high, disable clock                                                        |
| 8          | RW          | 0x0                | pclk_npu_grf_en<br>pclk_npu_grf clock gating control.<br>When high, disable clock                                                  |
| 7          | RW          | 0x0                | pclk_npu_sgrf_en<br>pclk_npu_sgrf clock gating control.<br>When high, disable clock                                                |
| 6          | RW          | 0x0                | pclk_npu_cru_en<br>pclk_npu_cru clock gating control.<br>When high, disable clock                                                  |
| 5          | RW          | 0x0                | pclk_npu_biu_en<br>pclk_npu_biu clock gating control.<br>When high, disable clock                                                  |
| 4          | RW          | 0x0                | ackl_npu_biu_en<br>ackl_npu_biu clock gating control.<br>When high, disable clock                                                  |
| 3          | RW          | 0x0                | hclk_npu_biu_en<br>hclk_npu_biu clock gating control.<br>When high, disable clock                                                  |
| 2          | RW          | 0x0                | pclk_npu_root_en<br>pclk_npu_root clock gating control.<br>When high, disable clock                                                |
| 1          | RW          | 0x0                | ackl_npu_root_en<br>ackl_npu_root clock gating control.<br>When high, disable clock                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | hclk_npu_root_en<br>hclk_npu_root clock gating control.<br>When high, disable clock |

**NPUCRU\_NPUGATE CON01**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_testout_npu_en<br>clk_testout_npu2vi clock gating control.<br>When high, disable clock                                         |
| 14         | RW          | 0x0                | clk_matrix_500m_src2peri_en<br>clk_matrix_500m_src2peri clock gating control.<br>When high, disable clock                          |
| 13         | RW          | 0x0                | clk_matrix_400m_src2peri_en<br>clk_matrix_400m_src2peri clock gating control.<br>When high, disable clock                          |
| 12         | RW          | 0x0                | clk_matrix_300m_src2peri_en<br>clk_matrix_300m_src2peri clock gating control.<br>When high, disable clock                          |
| 11         | RW          | 0x0                | clk_matrix_200m_src2peri_en<br>clk_matrix_200m_src2peri clock gating control.<br>When high, disable clock                          |
| 10         | RW          | 0x0                | clk_matrix_100m_src2peri_en<br>clk_matrix_100m_src2peri clock gating control.<br>When high, disable clock                          |
| 9          | RW          | 0x0                | clk_matrix_50m_src2peri_en<br>clk_matrix_50m_src2peri clock gating control.<br>When high, disable clock                            |
| 8:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4          | RW          | 0x0                | clk_matrix_400m_src2vi_en<br>clk_matrix_400m_src2vi clock gating control.<br>When high, disable clock                              |
| 3          | RW          | 0x0                | clk_matrix_339m_src2vi_en<br>clk_matrix_339m_src2vi clock gating control.<br>When high, disable clock                              |
| 2          | RW          | 0x0                | clk_matrix_200m_src2vi_en<br>clk_matrix_200m_src2vi clock gating control.<br>When high, disable clock                              |
| 1          | RW          | 0x0                | clk_matrix_150m_src2vi_en<br>clk_matrix_150m_src2vi clock gating control.<br>When high, disable clock                              |

| Bit | Attr | Reset Value | Description                                                                                           |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | clk_matrix_100m_src2vi_en<br>clk_matrix_100m_src2vi clock gating control.<br>When high, disable clock |

**NPUCRU\_NPUSOFRST CON00**

Address: Operational Base + offset (0x0A00)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:11 | RO   | 0x00        | reserved                                                                                                                           |
| 10    | RW   | 0x0         | aresetn_rknn<br>When high, reset relative logic                                                                                    |
| 9     | RW   | 0x0         | hresetn_rknn<br>When high, reset relative logic                                                                                    |
| 8     | RW   | 0x0         | presetn_npu_grf<br>When high, reset relative logic                                                                                 |
| 7     | RW   | 0x0         | presetn_npu_sgrf<br>When high, reset relative logic                                                                                |
| 6     | RW   | 0x0         | presetn_npu_cru<br>When high, reset relative logic                                                                                 |
| 5     | RW   | 0x0         | presetn_npu_biu<br>When high, reset relative logic                                                                                 |
| 4     | RW   | 0x0         | aresetn_npu_biu<br>When high, reset relative logic                                                                                 |
| 3     | RW   | 0x0         | hresetn_npu_biu<br>When high, reset relative logic                                                                                 |
| 2:0   | RO   | 0x0         | reserved                                                                                                                           |

**2.9 PERICRU Register Description****2.9.1 Registers Summary**

| Name                      | Offset | Size | Reset Value | Description                                   |
|---------------------------|--------|------|-------------|-----------------------------------------------|
| PERICRU_PERICLKSEL_CO_N01 | 0x0304 | W    | 0x00000000  | Internal clock select and division register 1 |
| PERICRU_PERICLKSEL_CO_N02 | 0x0308 | W    | 0x00000000  | Internal clock select and division register 2 |
| PERICRU_PERICLKSEL_CO_N05 | 0x0314 | W    | 0x00000303  | Internal clock select and division register 5 |
| PERICRU_PERICLKSEL_CO_N06 | 0x0318 | W    | 0x00000001  | Internal clock select and division register 6 |
| PERICRU_PERICLKSEL_CO_N07 | 0x031C | W    | 0x00002000  | Internal clock select and division register 7 |

| Name                      | Offset | Size | Reset Value | Description                                    |
|---------------------------|--------|------|-------------|------------------------------------------------|
| PERICRU_PERICLKSEL_CO_N08 | 0x0320 | W    | 0x00000303  | Internal clock select and division register 8  |
| PERICRU_PERICLKSEL_CO_N09 | 0x0324 | W    | 0x00000000  | Internal clock select and division register 9  |
| PERICRU_PERICLKSEL_CO_N11 | 0x032C | W    | 0x00000000  | Internal clock select and division register 11 |
| PERICRU_PERIGATE_CONO_0   | 0x0800 | W    | 0x00000000  | Internal clock gate and division register 0    |
| PERICRU_PERIGATE_CONO_1   | 0x0804 | W    | 0x00000000  | Internal clock gate and division register 1    |
| PERICRU_PERIGATE_CONO_2   | 0x0808 | W    | 0x00000000  | Internal clock gate and division register 2    |
| PERICRU_PERIGATE_CONO_3   | 0x080C | W    | 0x00000000  | Internal clock gate and division register 3    |
| PERICRU_PERIGATE_CONO_4   | 0x0810 | W    | 0x00000000  | Internal clock gate and division register 4    |
| PERICRU_PERIGATE_CONO_5   | 0x0814 | W    | 0x00000000  | Internal clock gate and division register 5    |
| PERICRU_PERIGATE_CONO_6   | 0x0818 | W    | 0x00000000  | Internal clock gate and division register 6    |
| PERICRU_PERIGATE_CONO_7   | 0x081C | W    | 0x00000000  | Internal clock gate and division register 7    |
| PERICRU_PERISOFRST_C_ON00 | 0x0A00 | W    | 0x00000000  | Internal clock reset register 0                |
| PERICRU_PERISOFRST_C_ON01 | 0x0A04 | W    | 0x00000000  | Internal clock reset register 1                |
| PERICRU_PERISOFRST_C_ON02 | 0x0A08 | W    | 0x00000000  | Internal clock reset register 2                |
| PERICRU_PERISOFRST_C_ON03 | 0x0A0C | W    | 0x00000000  | Internal clock reset register 3                |
| PERICRU_PERISOFRST_C_ON04 | 0x0A10 | W    | 0x00000000  | Internal clock reset register 4                |
| PERICRU_PERISOFRST_C_ON05 | 0x0A14 | W    | 0x00000000  | Internal clock reset register 5                |
| PERICRU_PERISOFRST_C_ON06 | 0x0A18 | W    | 0x00000000  | Internal clock reset register 6                |
| PERICRU_PERISOFRST_C_ON07 | 0x0A1C | W    | 0x00000000  | Internal clock reset register 7                |

Notes:Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 2.9.2 Detail Registers Description

### PERICRU\_PERICLKSEL\_CON01

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                |
| 15:14      | RW          | 0x0                | clk_i2c3_sel<br>clk_i2c3 clock mux.<br>2'b00: clk_matrix_200m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func              |
| 13:12      | RW          | 0x0                | clk_i2c2_sel<br>clk_i2c2 clock mux.<br>2'b00: clk_matrix_200m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func              |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                          |
| 9:8        | RW          | 0x0                | clk_i2c0_sel<br>clk_i2c0 clock mux.<br>2'b00: clk_matrix_200m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func              |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                          |
| 5:4        | RW          | 0x0                | hclk_peri_root_sel<br>hclk_peri_root clock mux.<br>2'b00: clk_matrix_200m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func  |
| 3:2        | RW          | 0x0                | aclk_peri_root_sel<br>aclk_peri_root clock mux.<br>2'b00: clk_matrix_400m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func |
| 1:0        | RW          | 0x0                | pclk_peri_root_sel<br>pclk_peri_root clock mux.<br>2'b00: clk_matrix_100m_src<br>2'b01: clk_matrix_50m_src<br>2'b10: xin_osc0_func                                |

**PERICRU PERICLKSEL CON02**

Address: Operational Base + offset (0x0308)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                   |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                                             |
| 1:0        | RW          | 0x0                | clk_i2c4_sel<br>clk_i2c4 clock mux.<br>2'b00: clk_matrix_200m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func |

**PERICRU PERICLKSEL CON05**

Address: Operational Base + offset (0x0314)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                        |
| 15:13      | RW          | 0x0                | clk_testout_peri2vi_1_sel<br>clk_testout_peri2vi_1 clock mux.<br>3'b000: emmc_test_clkout_1<br>3'b001: sclk_uart2<br>3'b010: aclk_bus_root<br>3'b011: clk_core_crypto<br>3'b100: mclk_i2s0_8ch_tx         |
| 12:8       | RW          | 0x03               | clk_testout_peri2vi_1_div<br>Divide clk_testout_peri2vi_1 by (div_con + 1).                                                                                                                               |
| 7:5        | RW          | 0x0                | clk_testout_peri2vi_0_sel<br>clk_testout_peri2vi_0 clock mux.<br>3'b000: emmc_test_clkout_0<br>3'b001: aclk_peri_root<br>3'b010: hclk_peri_root<br>3'b011: pclk_peri_root<br>3'b100: clk_testout_ddr2peri |
| 4:0        | RW          | 0x03               | clk_testout_peri2vi_0_div<br>Divide clk_testout_peri2vi_0 by (div_con + 1).                                                                                                                               |

**PERICRU PERICLKSEL CON06**

Address: Operational Base + offset (0x0318)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                            |
| 12:11      | RW          | 0x0                | clk_pwm2_peri_sel<br>clk_pwm2_peri clock mux.<br>2'b00: clk_matrix_100m_src<br>2'b01: clk_matrix_50m_src<br>2'b10: xin_osc0_func                                    |
| 10:9       | RW          | 0x0                | clk_pwm1_peri_sel<br>clk_pwm1_peri clock mux.<br>2'b00: clk_matrix_100m_src<br>2'b01: clk_matrix_50m_src<br>2'b10: xin_osc0_func                                    |
| 8:7        | RW          | 0x0                | clk_pka_crypto_sel<br>clk_pka_crypto clock mux.<br>2'b00: clk_matrix_300m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func   |
| 6:5        | RW          | 0x0                | clk_core_crypto_sel<br>clk_core_crypto clock mux.<br>2'b00: clk_matrix_300m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func |
| 4:3        | RW          | 0x0                | clk_spi1_sel<br>clk_spi1 clock mux.<br>2'b00: clk_matrix_200m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func                |
| 2:0        | RW          | 0x1                | clk_saradc_div<br>Divide clk_saradc by (div_con + 1).                                                                                                               |

**PERICRU PERICLKSEL CON07**

Address: Operational Base + offset (0x031C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                        |
| 15:14      | RW          | 0x0                | dclk_decom_sel<br>dclk_decom clock mux.<br>2'b00: clk_matrix_400m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12      | RW          | 0x2                | sclk_sfc_sel<br>sclk_sfc clock mux.<br>2'b00: clk_matrix_500m_src<br>2'b01: clk_matrix_300m_src<br>2'b10: clk_matrix_200m_src<br>2'b11: xin_osc0_func |
| 11:7       | RW          | 0x00               | sclk_sfc_div<br>Divide sclk_sfc by (div_con + 1).                                                                                                     |
| 6          | RW          | 0x0                | cclk_src_emmc_sel<br>cclk_src_emmc clock mux.<br>1'b0: clk_matrix_400m_src<br>1'b1: xin_osc0_func                                                     |
| 5:0        | RW          | 0x00               | cclk_src_emmc_div<br>DT50 division register.<br>Divide cclk_src_emmc by (div_con + 1).                                                                |

**PERICRU PERICLKSEL CON08**

Address: Operational Base + offset (0x0320)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RW          | 0x03               | mclk_acodec_rx_div<br>Divide mclk_acodec_rx by (div_con + 1).                                                                      |
| 7:0        | RW          | 0x03               | mclk_acodec_tx_div<br>Divide mclk_acodec_tx by (div_con + 1).                                                                      |

**PERICRU PERICLKSEL CON09**

Address: Operational Base + offset (0x0324)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                           |

**PERICRU PERICLKSEL CON11**

Address: Operational Base + offset (0x032C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                           |
| 1:0        | RW          | 0x0                | clk_pwm0_peri_sel<br>clk_pwm0_peri clock mux.<br>2'b00: clk_matrix_100m_src<br>2'b01: clk_matrix_50m_src<br>2'b10: xin_osc0_func   |

**PERICRU PERIGATE CON00**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | pclk_stimer_en<br>pclk_stimer clock gating control.<br>When high, disable clock                                                    |
| 14         | RW          | 0x0                | clk_timer5_en<br>clk_timer5 clock gating control.<br>When high, disable clock                                                      |
| 13         | RW          | 0x0                | clk_timer4_en<br>clk_timer4 clock gating control.<br>When high, disable clock                                                      |
| 12         | RW          | 0x0                | clk_timer3_en<br>clk_timer3 clock gating control.<br>When high, disable clock                                                      |
| 11         | RW          | 0x0                | clk_timer2_en<br>clk_timer2 clock gating control.<br>When high, disable clock                                                      |
| 10         | RW          | 0x0                | clk_timer1_en<br>clk_timer1 clock gating control.<br>When high, disable clock                                                      |
| 9          | RW          | 0x0                | clk_timer0_en<br>clk_timer0 clock gating control.<br>When high, disable clock                                                      |
| 8          | RW          | 0x0                | pclk_timer_en<br>pclk_timer clock gating control.<br>When high, disable clock                                                      |
| 7          | RW          | 0x0                | hclk_bootrom_en<br>hclk_bootrom clock gating control.<br>When high, disable clock                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | hclk_peri_biu_en<br>hclk_peri_biu clock gating control.<br>When high, disable clock   |
| 5          | RW          | 0x0                | aclk_peri_biu_en<br>aclk_peri_biu clock gating control.<br>When high, disable clock   |
| 4          | RW          | 0x0                | pclk_peri_biu_en<br>pclk_peri_biu clock gating control.<br>When high, disable clock   |
| 3          | RW          | 0x0                | clk_timer_root_en<br>clk_timer_root clock gating control.<br>When high, disable clock |
| 2          | RW          | 0x0                | hclk_peri_root_en<br>hclk_peri_root clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | aclk_peri_root_en<br>aclk_peri_root clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | pclk_peri_root_en<br>pclk_peri_root clock gating control.<br>When high, disable clock |

**PERICRU PERIGATE CON01**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_i2c4_en<br>clk_i2c4 clock gating control.<br>When high, disable clock                                                          |
| 14         | RW          | 0x0                | pclk_i2c4_en<br>pclk_i2c4 clock gating control.<br>When high, disable clock                                                        |
| 13         | RW          | 0x0                | clk_i2c3_en<br>clk_i2c3 clock gating control.<br>When high, disable clock                                                          |
| 12         | RW          | 0x0                | pclk_i2c3_en<br>pclk_i2c3 clock gating control.<br>When high, disable clock                                                        |
| 11         | RW          | 0x0                | clk_i2c2_en<br>clk_i2c2 clock gating control.<br>When high, disable clock                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | pclk_i2c2_en<br>pclk_i2c2 clock gating control.<br>When high, disable clock     |
| 9:8        | RO          | 0x0                | reserved                                                                        |
| 7          | RW          | 0x0                | clk_i2c0_en<br>clk_i2c0 clock gating control.<br>When high, disable clock       |
| 6          | RW          | 0x0                | pclk_i2c0_en<br>pclk_i2c0 clock gating control.<br>When high, disable clock     |
| 5          | RW          | 0x0                | tclk_wdt_s_en<br>tclk_wdt_s clock gating control.<br>When high, disable clock   |
| 4          | RW          | 0x0                | pclk_wdt_s_en<br>pclk_wdt_s clock gating control.<br>When high, disable clock   |
| 3          | RW          | 0x0                | tclk_wdt_ns_en<br>tclk_wdt_ns clock gating control.<br>When high, disable clock |
| 2          | RW          | 0x0                | pclk_wdt_ns_en<br>pclk_wdt_ns clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | clk_stimer1_en<br>clk_stimer1 clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | clk_stimer0_en<br>clk_stimer0 clock gating control.<br>When high, disable clock |

**PERICRU PERIGATE CON02**

Address: Operational Base + offset (0x0808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | pclk_uart5_en<br>pclk_uart5 clock gating control.<br>When high, disable clock                                                      |
| 14         | RW          | 0x0                | sclk_uart4_en<br>sclk_uart4 clock gating control.<br>When high, disable clock                                                      |
| 13:12      | RO          | 0x0                | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | pclk_uart4_en<br>pclk_uart4 clock gating control.<br>When high, disable clock       |
| 10         | RW          | 0x0                | sclk_uart3_en<br>sclk_uart3 clock gating control.<br>When high, disable clock       |
| 9:8        | RO          | 0x0                | reserved                                                                            |
| 7          | RW          | 0x0                | pclk_uart3_en<br>pclk_uart3 clock gating control.<br>When high, disable clock       |
| 6          | RW          | 0x0                | sclk_uart2_en<br>sclk_uart2 clock gating control.<br>When high, disable clock       |
| 5:4        | RO          | 0x0                | reserved                                                                            |
| 3          | RW          | 0x0                | pclk_uart2_en<br>pclk_uart2 clock gating control.<br>When high, disable clock       |
| 2          | RW          | 0x0                | pclk_peri_ioc_en<br>pclk_peri_ioc clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | dbclk_gpio4_en<br>dbclk_gpio4 clock gating control.<br>When high, disable clock     |
| 0          | RW          | 0x0                | pclk_gpio4_en<br>pclk_gpio4 clock gating control.<br>When high, disable clock       |

**PERICRU PERIGATE CON03**

Address: Operational Base + offset (0x080C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | pclk_pwm1_peri_en<br>pclk_pwm1_peri clock gating control.<br>When high, disable clock                                              |
| 14         | RW          | 0x0                | hclk_crypto_en<br>hclk_crypto clock gating control.<br>When high, disable clock                                                    |
| 13         | RW          | 0x0                | aclk_crypto_en<br>aclk_crypto clock gating control.<br>When high, disable clock                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | clk_pka_crypto_en<br>clk_pka_crypto clock gating control.<br>When high, disable clock               |
| 11         | RW          | 0x0                | clk_core_crypto_en<br>clk_core_crypto clock gating control.<br>When high, disable clock             |
| 10         | RW          | 0x0                | hclk_trng_s_en<br>hclk_trng_s clock gating control.<br>When high, disable clock                     |
| 9          | RW          | 0x0                | hclk_trng_ns_en<br>hclk_trng_ns clock gating control.<br>When high, disable clock                   |
| 8          | RW          | 0x0                | sclk_in_spi1_en<br>sclk_in_spi1 clock gating control.<br>When high, disable clock                   |
| 7          | RW          | 0x0                | clk_spi1_en<br>clk_spi1 clock gating control.<br>When high, disable clock                           |
| 6          | RW          | 0x0                | pclk_spi1_en<br>pclk_spi1 clock gating control.<br>When high, disable clock                         |
| 5          | RO          | 0x0                | reserved                                                                                            |
| 4          | RW          | 0x0                | clk_saradc_en<br>clk_saradc clock gating control.<br>When high, disable clock                       |
| 3          | RW          | 0x0                | pclk_saradc_en<br>pclk_saradc clock gating control.<br>When high, disable clock                     |
| 2          | RW          | 0x0                | sclk_uart5_en<br>sclk_uart5 clock gating control.<br>When high, disable clock                       |
| 1          | RW          | 0x0                | clk_testout_peri2vi_1_en<br>clk_testout_peri2vi_1 clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | clk_testout_peri2vi_0_en<br>clk_testout_peri2vi_0 clock gating control.<br>When high, disable clock |

**PERICRU PERIGATE CON04**

Address: Operational Base + offset (0x0810)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 15         | RO          | 0x0                | reserved                                                                                            |
| 14         | RW          | 0x0                | hclk_sfc_en<br>hclk_sfc clock gating control.<br>When high, disable clock                           |
| 13         | RW          | 0x0                | hclk_emmc_en<br>hclk_emmc clock gating control.<br>When high, disable clock                         |
| 12         | RW          | 0x0                | cclk_src_emmc_en<br>cclk_src_emmc clock gating control.<br>When high, disable clock                 |
| 11         | RW          | 0x0                | mbist_clk_aclk_usb_en<br>mbist_clk_aclk_usb clock gating control.<br>When high, disable clock       |
| 10         | RW          | 0x0                | ackl_bus_biu_en<br>ackl_bus_biu clock gating control.<br>When high, disable clock                   |
| 9          | RW          | 0x0                | clk_utmi_usbotg_en<br>clk_utmi_usbotg clock gating control.<br>When high, disable clock             |
| 8          | RW          | 0x0                | clk_ref_usbotg_en<br>clk_ref_usbotg clock gating control.<br>When high, disable clock               |
| 7          | RW          | 0x0                | ackl_usbotg_en<br>ackl_usbotg clock gating control.<br>When high, disable clock                     |
| 6          | RW          | 0x0                | pclk_peri_cru_en<br>pclk_peri_cru clock gating control.<br>When high, disable clock                 |
| 5          | RW          | 0x0                | pclk_peri_grf_en<br>pclk_peri_grf clock gating control.<br>When high, disable clock                 |
| 4          | RW          | 0x0                | clk_capture_pwm2_peri_en<br>clk_capture_pwm2_peri clock gating control.<br>When high, disable clock |
| 3          | RW          | 0x0                | clk_pwm2_peri_en<br>clk_pwm2_peri clock gating control.<br>When high, disable clock                 |
| 2          | RW          | 0x0                | pclk_pwm2_peri_en<br>pclk_pwm2_peri clock gating control.<br>When high, disable clock               |
| 1          | RW          | 0x0                | clk_capture_pwm1_peri_en<br>clk_capture_pwm1_peri clock gating control.<br>When high, disable clock |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | clk_pwm1_peri_en<br>clk_pwm1_peri clock gating control.<br>When high, disable clock |

**PERICRU PERIGATE CON05**

Address: Operational Base + offset (0x0814)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | mclk_i2s0_8ch_tx_en<br>mclk_i2s0_8ch_tx clock gating control.<br>When high, disable clock                                          |
| 14         | RW          | 0x0                | mclk_sai_en<br>mclk_sai clock gating control.<br>When high, disable clock                                                          |
| 13         | RW          | 0x0                | hclk_sai_en<br>hclk_sai clock gating control.<br>When high, disable clock                                                          |
| 12         | RW          | 0x0                | pclk_peri_sgrf_en<br>pclk_peri_sgrf clock gating control.<br>When high, disable clock                                              |
| 11         | RW          | 0x0                | dclk_decom_en<br>dclk_decom clock gating control.<br>When high, disable clock                                                      |
| 10         | RW          | 0x0                | pclk_decom_en<br>pclk_decom clock gating control.<br>When high, disable clock                                                      |
| 9          | RW          | 0x0                | aclk_decom_en<br>aclk_decom clock gating control.<br>When high, disable clock                                                      |
| 8          | RW          | 0x0                | aclk_dmac_en<br>aclk_dmac clock gating control.<br>When high, disable clock                                                        |
| 7:3        | RO          | 0x00               | reserved                                                                                                                           |
| 2          | RW          | 0x0                | clk_ref_usbphy_en<br>clk_ref_usbphy clock gating control.<br>When high, disable clock                                              |
| 1          | RW          | 0x0                | pclk_usbphy_en<br>pclk_usbphy clock gating control.<br>When high, disable clock                                                    |
| 0          | RW          | 0x0                | sclk_sfc_en<br>sclk_sfc clock gating control.<br>When high, disable clock                                                          |

**PERICRU PERIGATE CON06**

Address: Operational Base + offset (0x0818)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | pclk_uart1_en<br>pclk_uart1 clock gating control.<br>When high, disable clock                                                      |
| 14         | RW          | 0x0                | sclk_uart0_en<br>sclk_uart0 clock gating control.<br>When high, disable clock                                                      |
| 13:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | pclk_uart0_en<br>pclk_uart0 clock gating control.<br>When high, disable clock                                                      |
| 10         | RW          | 0x0                | ackl_ive_en<br>ackl_ive clock gating control.<br>When high, disable clock                                                          |
| 9          | RW          | 0x0                | hclk_ive_en<br>hclk_ive clock gating control.<br>When high, disable clock                                                          |
| 8          | RW          | 0x0                | ackl_bus_root_en<br>ackl_bus_root clock gating control.<br>When high, disable clock                                                |
| 7          | RW          | 0x0                | pclk_dft2apb_en<br>pclk_dft2apb clock gating control.<br>When high, disable clock                                                  |
| 6          | RW          | 0x0                | mclk_i2s0_8ch_rx_en<br>mclk_i2s0_8ch_rx clock gating control.<br>When high, disable clock                                          |
| 5          | RW          | 0x0                | mclk_acodec_rx_en<br>mclk_acodec_rx clock gating control.<br>When high, disable clock                                              |
| 4          | RW          | 0x0                | mclk_acodec_tx_en<br>mclk_acodec_tx clock gating control.<br>When high, disable clock                                              |
| 3          | RW          | 0x0                | pclk_acodec_en<br>pclk_acodec clock gating control.<br>When high, disable clock                                                    |
| 2          | RW          | 0x0                | pclk_dsm_en<br>pclk_dsm clock gating control.<br>When high, disable clock                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 1          | RW          | 0x0                | mclk_dsm_en<br>mclk_dsm clock gating control.<br>When high, disable clock   |
| 0          | RW          | 0x0                | hclk_i2s0_en<br>hclk_i2s0 clock gating control.<br>When high, disable clock |

**PERICRU PERIGATE CON07**

Address: Operational Base + offset (0x081C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | mbist_clk_decom_400m_en<br>mbist_clk_decom_400m clock gating control.<br>When high, disable clock                                  |
| 10         | RW          | 0x0                | mbist_clk_ive_400m_en<br>mbist_clk_ive_400m clock gating control.<br>When high, disable clock                                      |
| 9          | RW          | 0x0                | mbist_clk_clk_emmc_en<br>mbist_clk_clk_emmc clock gating control.<br>When high, disable clock                                      |
| 8          | RW          | 0x0                | mbist_clk_aclk_crypto_en<br>mbist_clk_aclk_crypto clock gating control.<br>When high, disable clock                                |
| 7          | RW          | 0x0                | mbist_clk_clk_pka_crypto_en<br>mbist_clk_clk_pka_crypto clock gating control.<br>When high, disable clock                          |
| 6          | RW          | 0x0                | mbist_clk_clk_bootrom_en<br>mbist_clk_clk_bootrom clock gating control.<br>When high, disable clock                                |
| 5          | RW          | 0x0                | clk_capture_pwm0_peri_en<br>clk_capture_pwm0_peri clock gating control.<br>When high, disable clock                                |
| 4          | RW          | 0x0                | clk_pwm0_peri_en<br>clk_pwm0_peri clock gating control.<br>When high, disable clock                                                |
| 3          | RW          | 0x0                | pclk_pwm0_peri_en<br>pclk_pwm0_peri clock gating control.<br>When high, disable clock                                              |
| 2          | RW          | 0x0                | sclk_uart1_en<br>sclk_uart1 clock gating control.<br>When high, disable clock                                                      |

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

**PERICRU PERISOFRST CON00**

Address: Operational Base + offset (0x0A00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | presetn_stimer<br>When high, reset relative logic                                                                                  |
| 14         | RW          | 0x0                | resetn_timer5<br>When high, reset relative logic                                                                                   |
| 13         | RW          | 0x0                | resetn_timer4<br>When high, reset relative logic                                                                                   |
| 12         | RW          | 0x0                | resetn_timer3<br>When high, reset relative logic                                                                                   |
| 11         | RW          | 0x0                | resetn_timer2<br>When high, reset relative logic                                                                                   |
| 10         | RW          | 0x0                | resetn_timer1<br>When high, reset relative logic                                                                                   |
| 9          | RW          | 0x0                | resetn_timer0<br>When high, reset relative logic                                                                                   |
| 8          | RW          | 0x0                | presetn_timer<br>When high, reset relative logic                                                                                   |
| 7          | RW          | 0x0                | hresetn_bootrom<br>When high, reset relative logic                                                                                 |
| 6          | RW          | 0x0                | hresetn_peri_biu<br>When high, reset relative logic                                                                                |
| 5          | RW          | 0x0                | aresetn_peri_biu<br>When high, reset relative logic                                                                                |
| 4          | RW          | 0x0                | presetn_peri_biu<br>When high, reset relative logic                                                                                |
| 3:0        | RO          | 0x0                | reserved                                                                                                                           |

**PERICRU PERISOFRST CON01**

Address: Operational Base + offset (0x0A04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | resetn_i2c4<br>When high, reset relative logic                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 14         | RW          | 0x0                | presetn_i2c4<br>When high, reset relative logic   |
| 13         | RW          | 0x0                | resetn_i2c3<br>When high, reset relative logic    |
| 12         | RW          | 0x0                | presetn_i2c3<br>When high, reset relative logic   |
| 11         | RW          | 0x0                | resetn_i2c2<br>When high, reset relative logic    |
| 10         | RW          | 0x0                | presetn_i2c2<br>When high, reset relative logic   |
| 9:8        | RO          | 0x0                | reserved                                          |
| 7          | RW          | 0x0                | resetn_i2c0<br>When high, reset relative logic    |
| 6          | RW          | 0x0                | presetn_i2c0<br>When high, reset relative logic   |
| 5          | RW          | 0x0                | tresetn_wdt_s<br>When high, reset relative logic  |
| 4          | RW          | 0x0                | presetn_wdt_s<br>When high, reset relative logic  |
| 3          | RW          | 0x0                | tresetn_wdt_ns<br>When high, reset relative logic |
| 2          | RW          | 0x0                | presetn_wdt_ns<br>When high, reset relative logic |
| 1          | RW          | 0x0                | resetn_stimer1<br>When high, reset relative logic |
| 0          | RW          | 0x0                | resetn_stimer0<br>When high, reset relative logic |

**PERICRU PERISOFRST CON02**

Address: Operational Base + offset (0x0A08)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | presetn_uart5<br>When high, reset relative logic                                                                                   |
| 14         | RW          | 0x0                | sresetn_uart4<br>When high, reset relative logic                                                                                   |
| 13:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | presetn_uart4<br>When high, reset relative logic                                                                                   |
| 10         | RW          | 0x0                | sresetn_uart3<br>When high, reset relative logic                                                                                   |
| 9:8        | RO          | 0x0                | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 7          | RW          | 0x0                | presetn_uart3<br>When high, reset relative logic    |
| 6          | RW          | 0x0                | sresetn_uart2<br>When high, reset relative logic    |
| 5:4        | RO          | 0x0                | reserved                                            |
| 3          | RW          | 0x0                | presetn_uart2<br>When high, reset relative logic    |
| 2          | RW          | 0x0                | presetn_peri_ioc<br>When high, reset relative logic |
| 1          | RW          | 0x0                | dbresetn_gpio4<br>When high, reset relative logic   |
| 0          | RW          | 0x0                | presetn_gpio4<br>When high, reset relative logic    |

**PERICRU PERISOFTRST CON03**

Address: Operational Base + offset (0x0A0C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | presetn_pwm1_peri<br>When high, reset relative logic                                                                               |
| 14         | RW          | 0x0                | hresetn_crypto<br>When high, reset relative logic                                                                                  |
| 13         | RW          | 0x0                | aresetn_crypto<br>When high, reset relative logic                                                                                  |
| 12         | RW          | 0x0                | resetn_pka_crypto<br>When high, reset relative logic                                                                               |
| 11         | RW          | 0x0                | resetn_core_crypto<br>When high, reset relative logic                                                                              |
| 10         | RW          | 0x0                | hresetn_trng_s<br>When high, reset relative logic                                                                                  |
| 9          | RW          | 0x0                | hresetn_trng_ns<br>When high, reset relative logic                                                                                 |
| 8          | RO          | 0x0                | reserved                                                                                                                           |
| 7          | RW          | 0x0                | resetn_spi1<br>When high, reset relative logic                                                                                     |
| 6          | RW          | 0x0                | presetn_spi1<br>When high, reset relative logic                                                                                    |
| 5          | RW          | 0x0                | resetn_saradc_phy<br>When high, reset relative logic                                                                               |
| 4          | RW          | 0x0                | resetn_saradc<br>When high, reset relative logic                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 3          | RW          | 0x0                | presetn_saradc<br>When high, reset relative logic |
| 2          | RW          | 0x0                | sresetn_uart5<br>When high, reset relative logic  |
| 1:0        | RO          | 0x0                | reserved                                          |

**PERICRU PERISOFRST CON04**

Address: Operational Base + offset (0x0A10)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | hresetn_sfc<br>When high, reset relative logic                                                                                     |
| 13         | RW          | 0x0                | hresetn_emmc<br>When high, reset relative logic                                                                                    |
| 12:11      | RO          | 0x0                | reserved                                                                                                                           |
| 10         | RW          | 0x0                | aresetn_bus_biu<br>When high, reset relative logic                                                                                 |
| 9:8        | RO          | 0x0                | reserved                                                                                                                           |
| 7          | RW          | 0x0                | aresetn_usbotg<br>When high, reset relative logic                                                                                  |
| 6          | RW          | 0x0                | presetn_peri_cru<br>When high, reset relative logic                                                                                |
| 5          | RW          | 0x0                | presetn_peri_grf<br>When high, reset relative logic                                                                                |
| 4          | RO          | 0x0                | reserved                                                                                                                           |
| 3          | RW          | 0x0                | resetn_pwm2_peri<br>When high, reset relative logic                                                                                |
| 2          | RW          | 0x0                | presetn_pwm2_peri<br>When high, reset relative logic                                                                               |
| 1          | RO          | 0x0                | reserved                                                                                                                           |
| 0          | RW          | 0x0                | resetn_pwm1_peri<br>When high, reset relative logic                                                                                |

**PERICRU PERISOFRST CON05**

Address: Operational Base + offset (0x0A14)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 15         | RW          | 0x0                | mresetn_i2s0_8ch_tx<br>When high, reset relative logic |
| 14         | RW          | 0x0                | mresetn_sai<br>When high, reset relative logic         |
| 13         | RW          | 0x0                | hresetn_sai<br>When high, reset relative logic         |
| 12         | RW          | 0x0                | presetn_peri_sgrf<br>When high, reset relative logic   |
| 11         | RW          | 0x0                | dresetn_decom<br>When high, reset relative logic       |
| 10         | RW          | 0x0                | presetn_decom<br>When high, reset relative logic       |
| 9          | RW          | 0x0                | aresetn_decom<br>When high, reset relative logic       |
| 8          | RW          | 0x0                | aresetn_dmac<br>When high, reset relative logic        |
| 7:4        | RO          | 0x0                | reserved                                               |
| 3          | RW          | 0x0                | resetn_usbphy_otg<br>When high, reset relative logic   |
| 2          | RW          | 0x0                | resetn_usbphy_por<br>When high, reset relative logic   |
| 1          | RW          | 0x0                | presetn_usbphy<br>When high, reset relative logic      |
| 0          | RW          | 0x0                | sresetn_sfc<br>When high, reset relative logic         |

**PERICRU PERISOFRST CON06**

Address: Operational Base + offset (0x0A18)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | presetn_uart1<br>When high, reset relative logic                                                                                   |
| 14         | RW          | 0x0                | sresetn_uart0<br>When high, reset relative logic                                                                                   |
| 13:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | presetn_uart0<br>When high, reset relative logic                                                                                   |
| 10         | RW          | 0x0                | aresetn_ive<br>When high, reset relative logic                                                                                     |
| 9          | RW          | 0x0                | hresetn_ive<br>When high, reset relative logic                                                                                     |
| 8          | RO          | 0x0                | reserved                                                                                                                           |

| Bit | Attr | Reset Value | Description                                            |
|-----|------|-------------|--------------------------------------------------------|
| 7   | RW   | 0x0         | presetn_dft2apb<br>When high, reset relative logic     |
| 6   | RW   | 0x0         | mresetn_i2s0_8ch_rx<br>When high, reset relative logic |
| 5:4 | RO   | 0x0         | reserved                                               |
| 3   | RW   | 0x0         | presetn_acodec<br>When high, reset relative logic      |
| 2   | RW   | 0x0         | presetn_dsm<br>When high, reset relative logic         |
| 1   | RW   | 0x0         | mresetn_dsm<br>When high, reset relative logic         |
| 0   | RW   | 0x0         | hresetn_i2s0<br>When high, reset relative logic        |

**PERICRU PERISOFTRST CON07**

Address: Operational Base + offset (0x0A1C)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:5  | RO   | 0x000       | reserved                                                                                                                           |
| 4     | RW   | 0x0         | resetn_pwm0_peri<br>When high, reset relative logic                                                                                |
| 3     | RW   | 0x0         | presetn_pwm0_peri<br>When high, reset relative logic                                                                               |
| 2     | RW   | 0x0         | sresetn_uart1<br>When high, reset relative logic                                                                                   |
| 1:0   | RO   | 0x0         | reserved                                                                                                                           |

**2.10 PMUCRU Register Description****2.10.1 Registers Summary**

| Name                    | Offset | Size | Reset Value | Description                                   |
|-------------------------|--------|------|-------------|-----------------------------------------------|
| PMUCRU_PMUCLKSEL_CO_N00 | 0x0300 | W    | 0x000006101 | Internal clock select and division register 0 |
| PMUCRU_PMUCLKSEL_CO_N01 | 0x0304 | W    | 0x000000000 | Internal clock select and division register 1 |
| PMUCRU_PMUCLKSEL_CO_N06 | 0x0318 | W    | 0x0040B71B  | Internal clock select and division register 6 |
| PMUCRU_PMUCLKSEL_CO_N07 | 0x031C | W    | 0x000000000 | Internal clock select and division register 7 |
| PMUCRU_PMUGATE_CON0_0   | 0x0800 | W    | 0x000000000 | Internal clock gate and division register 0   |

| Name                   | Offset | Size | Reset Value | Description                                 |
|------------------------|--------|------|-------------|---------------------------------------------|
| PMUCRU_PMUGATE_CON0_1  | 0x0804 | W    | 0x00000000  | Internal clock gate and division register 1 |
| PMUCRU_PMUGATE_CON0_2  | 0x0808 | W    | 0x00000000  | Internal clock gate and division register 2 |
| PMUCRU_PMSOFTRST_CON00 | 0x0A00 | W    | 0x00001E00  | Internal clock reset register 0             |
| PMUCRU_PMSOFTRST_CON01 | 0x0A04 | W    | 0x00000000  | Internal clock reset register 1             |
| PMUCRU_PMSOFTRST_CON02 | 0x0A08 | W    | 0x00000000  | Internal clock reset register 2             |

Notes:  
Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 2.10.2 Detail Registers Description

### PMUCRU\_PMUCLKSEL\_CON00

Address: Operational Base + offset (0x0300)

| Bit   | Attr | Reset Value | Description                                                                                                                                          |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                   |
| 15    | RW   | 0x0         | dbclk_pmu_gpio0_sel<br>dbclk_pmu_gpio0 clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_deepslow                                                       |
| 14:13 | RW   | 0x3         | clk_testout_pmu_sel<br>clk_testout_pmu clock mux.<br>2'b00: hclk_pmu_root<br>2'b01: pclk_pmu_root<br>2'b10: clk_deepslow<br>2'b11: xin_osc0_div      |
| 12:8  | RW   | 0x01        | clk_testout_pmu_div<br>Divide clk_testout_pmu by (div_con + 1).                                                                                      |
| 7:6   | RW   | 0x0         | clk_i2c1_sel<br>clk_i2c1 clock mux.<br>2'b00: clk_matrix_200m_pmusrc<br>2'b01: clk_matrix_100m_pmusrc<br>2'b10: xin_osc0_func<br>2'b11: clk_deepslow |
| 5:4   | RW   | 0x0         | hclk_pmu_root_sel<br>hclk_pmu_root clock mux.<br>2'b00: clk_matrix_200m_pmusrc<br>2'b01: clk_matrix_100m_pmusrc<br>2'b10: xin_osc0_func              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | pclk_pmu_root_sel<br>pclk_pmu_root clock mux.<br>1'b0: clk_matrix_100m_pmusrc<br>1'b1: xin_osc0_func |
| 2:0        | RW          | 0x1                | clk_matrix_100m_pmusrc_div<br>Divide clk_matrix_100m_pmusrc by (div_con + 1).                        |

**PMUCRU PMUCLKSEL CON01**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:5       | RO          | 0x000              | reserved                                                                                                                           |
| 4:0        | RW          | 0x00               | clk_pvtm_pmu_div<br>Divide clk_pvtm_pmu by (div_con + 1).                                                                          |

**PMUCRU PMUCLKSEL CON06**

Address: Operational Base + offset (0x0318)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x0040b71b         | xin_osc0_div_div<br>xin_osc0_div fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**PMUCRU PMUCLKSEL CON07**

Address: Operational Base + offset (0x031C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:3       | RO          | 0x0000             | reserved                                                                                                                           |
| 2          | RW          | 0x0                | tclk_pmu_wdt_sel<br>tclk_pmu_wdt clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_deepslow                                           |
| 1:0        | RW          | 0x0                | clk_deepslow_sel<br>clk_deepslow clock mux.<br>2'b00: xin_osc0_div<br>2'b01: xin_osc1_32k<br>2'b10: clk_pvtm_32k                   |

**PMUCRU PMUGATE CON00**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_scanhs_clk_pmu_mcu_en<br>clk_scanhs_clk_pmu_mcu clock gating control.<br>When high, disable clock                              |
| 14         | RW          | 0x0                | clk_pmu_mcu_jtag_en<br>clk_pmu_mcu_jtag clock gating control.<br>When high, disable clock                                          |
| 13         | RW          | 0x0                | clk_pmu_mcu_RTC_en<br>clk_pmu_mcu_RTC clock gating control.<br>When high, disable clock                                            |
| 12:10      | RO          | 0x0                | reserved                                                                                                                           |
| 9          | RW          | 0x0                | clk_pmu_mcu_en<br>clk_pmu_mcu clock gating control.<br>When high, disable clock                                                    |
| 8          | RW          | 0x0                | hclk_pmu_sram_en<br>hclk_pmu_sram clock gating control.<br>When high, disable clock                                                |
| 7          | RW          | 0x0                | pclk_pmu_biu_en<br>pclk_pmu_biu clock gating control.<br>When high, disable clock                                                  |
| 6          | RW          | 0x0                | hclk_pmu_biu_en<br>hclk_pmu_biu clock gating control.<br>When high, disable clock                                                  |
| 5          | RW          | 0x0                | clk_testout_pmu_en<br>clk_testout_pmu clock gating control.<br>When high, disable clock                                            |
| 4          | RW          | 0x0                | clk_i2c1_en<br>clk_i2c1 clock gating control.<br>When high, disable clock                                                          |
| 3          | RW          | 0x0                | pclk_i2c1_en<br>pclk_i2c1 clock gating control.<br>When high, disable clock                                                        |
| 2          | RW          | 0x0                | hclk_pmu_root_en<br>hclk_pmu_root clock gating control.<br>When high, disable clock                                                |
| 1          | RW          | 0x0                | pclk_pmu_root_en<br>pclk_pmu_root clock gating control.<br>When high, disable clock                                                |
| 0          | RO          | 0x0                | reserved                                                                                                                           |

**PMUCRU PMUGATE CON01**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_ddr_fail_safe_en<br>clk_ddr_fail_safe clock gating control.<br>When high, disable clock                                        |
| 14         | RW          | 0x0                | xin_osc0_div_en<br>xin_osc0_div clock gating control.<br>When high, disable clock                                                  |
| 13:6       | RO          | 0x00               | reserved                                                                                                                           |
| 5          | RW          | 0x0                | pclk_pvtm_pmu_en<br>pclk_pvtm_pmu clock gating control.<br>When high, disable clock                                                |
| 4          | RW          | 0x0                | clk_pvtm_pmu_en<br>clk_pvtm_pmu clock gating control.<br>When high, disable clock                                                  |
| 3          | RW          | 0x0                | dbclk_pmu_gpio0_en<br>dbclk_pmu_gpio0 clock gating control.<br>When high, disable clock                                            |
| 2          | RW          | 0x0                | pclk_pmu_gpio0_en<br>pclk_pmu_gpio0 clock gating control.<br>When high, disable clock                                              |
| 1          | RW          | 0x0                | pclk_pmu_en<br>pclk_pmu clock gating control.<br>When high, disable clock                                                          |
| 0          | RW          | 0x0                | clk_pmu_en<br>clk_pmu clock gating control.<br>When high, disable clock                                                            |

**PMUCRU PMUGATE CON02**

Address: Operational Base + offset (0x0808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                           |
| 13         | RW          | 0x0                | clk_refout_en<br>clk_refout clock gating control.<br>When high, disable clock                                                      |
| 12         | RW          | 0x0                | occ_scanclk_pmu_gpio_en<br>occ_scanclk_pmu_gpio clock gating control.<br>When high, disable clock                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | occ_scanclk_pmu_mcu_jtag_en<br>occ_scanclk_pmu_mcu_jtag clock gating control.<br>When high, disable clock |
| 10         | RW          | 0x0                | pclk_pmu_mailbox_en<br>pclk_pmu_mailbox clock gating control.<br>When high, disable clock                 |
| 9          | RW          | 0x0                | tclk_pmu_wdt_en<br>tclk_pmu_wdt clock gating control.<br>When high, disable clock                         |
| 8          | RW          | 0x0                | pclk_pmu_wdt_en<br>pclk_pmu_wdt clock gating control.<br>When high, disable clock                         |
| 7          | RO          | 0x0                | reserved                                                                                                  |
| 6          | RW          | 0x0                | pclk_pmu_sgrf_en<br>pclk_pmu_sgrf clock gating control.<br>When high, disable clock                       |
| 5          | RW          | 0x0                | pclk_pmu_grf_en<br>pclk_pmu_grf clock gating control.<br>When high, disable clock                         |
| 4          | RW          | 0x0                | pclk_pmu_cru_en<br>pclk_pmu_cru clock gating control.<br>When high, disable clock                         |
| 3          | RW          | 0x0                | pclk_pmu_ioc_en<br>pclk_pmu_ioc clock gating control.<br>When high, disable clock                         |
| 2          | RW          | 0x0                | clk_pmu_32k_hp_timer_en<br>clk_pmu_32k_hp_timer clock gating control.<br>When high, disable clock         |
| 1          | RW          | 0x0                | clk_pmu_hp_timer_en<br>clk_pmu_hp_timer clock gating control.<br>When high, disable clock                 |
| 0          | RW          | 0x0                | pclk_pmu_hp_timer_en<br>pclk_pmu_hp_timer clock gating control.<br>When high, disable clock               |

**PMUCRU\_PMUSOFRST\_CON00**

Address: Operational Base + offset (0x0A00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12         | RW          | 0x1                | tresetn_pmu_mcu_cpu<br>When high, reset relative logic                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 11         | RW          | 0x1                | resetn_pmu_mcu_cpu<br>When high, reset relative logic   |
| 10         | RW          | 0x1                | resetn_pmu_mcu_pwrup<br>When high, reset relative logic |
| 9          | RW          | 0x1                | resetn_pmu_mcu<br>When high, reset relative logic       |
| 8          | RW          | 0x0                | hresetn_pmu_sram<br>When high, reset relative logic     |
| 7          | RW          | 0x0                | presetn_pmu_biu<br>When high, reset relative logic      |
| 6          | RW          | 0x0                | hresetn_pmu_biu<br>When high, reset relative logic      |
| 5          | RO          | 0x0                | reserved                                                |
| 4          | RW          | 0x0                | resetn_i2c1<br>When high, reset relative logic          |
| 3          | RW          | 0x0                | presetn_i2c1<br>When high, reset relative logic         |
| 2:0        | RO          | 0x0                | reserved                                                |

**PMUCRU PMUSOFRST CON01**

Address: Operational Base + offset (0x0A04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | resetn_ddr_fail_safe<br>When high, reset relative logic                                                                            |
| 14:6       | RO          | 0x000              | reserved                                                                                                                           |
| 5          | RW          | 0x0                | presetn_pvtm_pmu<br>When high, reset relative logic                                                                                |
| 4          | RW          | 0x0                | resetn_pvtm_pmu<br>When high, reset relative logic                                                                                 |
| 3          | RW          | 0x0                | dbresetn_pmu_gpio0<br>When high, reset relative logic                                                                              |
| 2          | RW          | 0x0                | presetn_pmu_gpio0<br>When high, reset relative logic                                                                               |
| 1:0        | RO          | 0x0                | reserved                                                                                                                           |

**PMUCRU PMUSOFRST CON02**

Address: Operational Base + offset (0x0A08)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:11 | RO   | 0x00        | reserved                                                                                                                           |
| 10    | RW   | 0x0         | presetn_pmu_mailbox<br>When high, reset relative logic                                                                             |
| 9     | RW   | 0x0         | tresetn_pmu_wdt<br>When high, reset relative logic                                                                                 |
| 8     | RW   | 0x0         | presetn_pmu_wdt<br>When high, reset relative logic                                                                                 |
| 7     | RW   | 0x0         | presetn_pmu_sgrf_remap<br>When high, reset relative logic                                                                          |
| 6     | RW   | 0x0         | presetn_pmu_sgrf<br>When high, reset relative logic                                                                                |
| 5     | RW   | 0x0         | presetn_pmu_grf<br>When high, reset relative logic                                                                                 |
| 4     | RW   | 0x0         | presetn_pmu_cru<br>When high, reset relative logic                                                                                 |
| 3     | RW   | 0x0         | presetn_pmu_ioc<br>When high, reset relative logic                                                                                 |
| 2     | RW   | 0x0         | resetn_pmu_32k_hp_timer<br>When high, reset relative logic                                                                         |
| 1     | RW   | 0x0         | resetn_pmu_hp_timer<br>When high, reset relative logic                                                                             |
| 0     | RW   | 0x0         | presetn_pmu_hp_timer<br>When high, reset relative logic                                                                            |

## 2.11 VEPUCRU Register Description

### 2.11.1 Registers Summary

| Name                     | Offset | Size | Reset Value | Description                                   |
|--------------------------|--------|------|-------------|-----------------------------------------------|
| VEPUCRU_VEPUCLKSEL_CON00 | 0x0300 | W    | 0x00000000  | Internal clock select and division register 0 |
| VEPUCRU_VEPUCLKSEL_CON01 | 0x0304 | W    | 0x000000181 | Internal clock select and division register 1 |
| VEPUCRU_VEPUGATE_CO_N00  | 0x0800 | W    | 0x00000000  | Internal clock gate and division register 0   |
| VEPUCRU_VEPUGATE_CO_N01  | 0x0804 | W    | 0x00000000  | Internal clock gate and division register 1   |
| VEPUCRU_VEPUGATE_CO_N02  | 0x0808 | W    | 0x00000000  | Internal clock gate and division register 2   |
| VEPUCRU_VEPUSOFRST_CON00 | 0x0A00 | W    | 0x00000000  | Internal clock reset register 0               |

| Name                        | Offset | Size | Reset Value | Description                     |
|-----------------------------|--------|------|-------------|---------------------------------|
| VEPUCRU_VEPUSOFRST<br>CON01 | 0x0A04 | W    | 0x00000000  | Internal clock reset register 1 |

Notes:Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 2.11.2 Detail Registers Description

### VEPUCRU\_VEPUCLKSEL\_CON00

Address: Operational Base + offset (0x0300)

| Bit   | Attr | Reset Value | Description                                                                                                                                                              |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                       |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                 |
| 13:12 | RW   | 0x0         | clk_spi0_sel<br>clk_spi0 clock mux.<br>2'b00: clk_matrix_200m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func                     |
| 11:10 | RW   | 0x0         | clk_core_vepu_dvbm_sel<br>clk_core_vepu_dvbm clock mux.<br>2'b00: clk_matrix_200m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func |
| 9:8   | RW   | 0x0         | clk_core_vepu_sel<br>clk_core_vepu clock mux.<br>2'b00: clk_matrix_400m_src<br>2'b01: clk_matrix_300m_src<br>2'b10: clk_pvtpll_0<br>2'b11: clk_pvtpll_1                  |
| 7:6   | RW   | 0x0         | pclk_vepu_root_sel<br>pclk_vepu_root clock mux.<br>2'b00: clk_matrix_100m_src<br>2'b01: clk_matrix_50m_src<br>2'b10: xin_osc0_func                                       |
| 5:4   | RW   | 0x0         | ackl_vepu_root_sel<br>ackl_vepu_root clock mux.<br>2'b00: clk_matrix_300m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x0                | aclk_vepu_com_root_sel<br>aclk_vepu_com_root clock mux.<br>2'b00: clk_matrix_400m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func |
| 1:0        | RW          | 0x0                | hclk_vepu_root_sel<br>hclk_vepu_root clock mux.<br>2'b00: clk_matrix_200m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func          |

**VEPUCRU VEPUCLKSEL CON01**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                              |
| 13:12      | RW          | 0x0                | clk_testout_vepu2vo_1_sel<br>clk_testout_vepu2vo_1 clock mux.<br>2'b00: clk_core_vepu<br>2'b01: clk_core_vepu_dvbm<br>2'b10: clk_testout_top2vepu                     |
| 11:7       | RW          | 0x03               | clk_testout_vepu2vo_1_div<br>Divide clk_testout_vepu2vo_1 by (div_con + 1).                                                                                           |
| 6:5        | RW          | 0x0                | clk_testout_vepu2vo_0_sel<br>clk_testout_vepu2vo_0 clock mux.<br>2'b00: hclk_vepu_root<br>2'b01: aclk_vepu_com_root<br>2'b10: aclk_vepu_root<br>2'b11: pclk_vepu_root |
| 4:0        | RW          | 0x01               | clk_testout_vepu2vo_0_div<br>Divide clk_testout_vepu2vo_0 by (div_con + 1).                                                                                           |

**VEPUCRU VEPUGATE CON00**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | pclk_gpio1_en<br>pclk_gpio1 clock gating control.<br>When high, disable clock                 |
| 14         | RW          | 0x0                | pclk_vicap_vepu_en<br>pclk_vicap_vepu clock gating control.<br>When high, disable clock       |
| 13         | RW          | 0x0                | clk_core_vepu_dvbm_en<br>clk_core_vepu_dvbm clock gating control.<br>When high, disable clock |
| 12         | RW          | 0x0                | ackl_vepu_pp_en<br>ackl_vepu_pp clock gating control.<br>When high, disable clock             |
| 11         | RW          | 0x0                | hclk_vepu_pp_en<br>hclk_vepu_pp clock gating control.<br>When high, disable clock             |
| 10         | RW          | 0x0                | clk_core_vepu_en<br>clk_core_vepu clock gating control.<br>When high, disable clock           |
| 9          | RW          | 0x0                | ackl_vepu_en<br>ackl_vepu clock gating control.<br>When high, disable clock                   |
| 8          | RW          | 0x0                | hclk_vepu_en<br>hclk_vepu clock gating control.<br>When high, disable clock                   |
| 7          | RW          | 0x0                | pclk_vepu_biu_en<br>pclk_vepu_biu clock gating control.<br>When high, disable clock           |
| 6          | RW          | 0x0                | ackl_vepu_com_biu_en<br>ackl_vepu_com_biu clock gating control.<br>When high, disable clock   |
| 5          | RW          | 0x0                | ackl_vepu_biu_en<br>ackl_vepu_biu clock gating control.<br>When high, disable clock           |
| 4          | RW          | 0x0                | hclk_vepu_biu_en<br>hclk_vepu_biu clock gating control.<br>When high, disable clock           |
| 3          | RW          | 0x0                | pclk_vepu_root_en<br>pclk_vepu_root clock gating control.<br>When high, disable clock         |
| 2          | RW          | 0x0                | ackl_vepu_root_en<br>ackl_vepu_root clock gating control.<br>When high, disable clock         |
| 1          | RW          | 0x0                | ackl_vepu_com_root_en<br>ackl_vepu_com_root clock gating control.<br>When high, disable clock |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | hclk_vepu_root_en<br>hclk_vepu_root clock gating control.<br>When high, disable clock |

**VEPUCRU VEPUGATE CON01**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_matrix_300m_src2npu_en<br>clk_matrix_300m_src2npu clock gating control.<br>When high, disable clock                            |
| 14         | RW          | 0x0                | clk_matrix_200m_src2npu_en<br>clk_matrix_200m_src2npu clock gating control.<br>When high, disable clock                            |
| 13         | RW          | 0x0                | clk_matrix_150m_src2npu_en<br>clk_matrix_150m_src2npu clock gating control.<br>When high, disable clock                            |
| 12         | RW          | 0x0                | clk_matrix_100m_src2npu_en<br>clk_matrix_100m_src2npu clock gating control.<br>When high, disable clock                            |
| 11         | RW          | 0x0                | clk_pvtpll_1_i2npu_en<br>clk_pvtpll_1_i2npu clock gating control.<br>When high, disable clock                                      |
| 10         | RW          | 0x0                | clk_pvtpll_0_i2npu_en<br>clk_pvtpll_0_i2npu clock gating control.<br>When high, disable clock                                      |
| 9          | RW          | 0x0                | clk_uart_detn_flt_en<br>clk_uart_detn_flt clock gating control.<br>When high, disable clock                                        |
| 8          | RW          | 0x0                | pclk_vepu_grf_en<br>pclk_vepu_grf clock gating control.<br>When high, disable clock                                                |
| 7          | RW          | 0x0                | pclk_vepu_sgrf_en<br>pclk_vepu_sgrf clock gating control.<br>When high, disable clock                                              |
| 6          | RW          | 0x0                | pclk_vepu_cru_en<br>pclk_vepu_cru clock gating control.<br>When high, disable clock                                                |
| 5          | RW          | 0x0                | pclk_vepu_cru_en<br>pclk_vepu_cru clock gating control.<br>When high, disable clock                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | sclk_in_spi0_en<br>sclk_in_spi0 clock gating control.<br>When high, disable clock   |
| 3          | RW          | 0x0                | clk_spi0_en<br>clk_spi0 clock gating control.<br>When high, disable clock           |
| 2          | RW          | 0x0                | pclk_spi0_en<br>pclk_spi0 clock gating control.<br>When high, disable clock         |
| 1          | RW          | 0x0                | pclk_vepu_ioc_en<br>pclk_vepu_ioc clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | dbclk_gpio1_en<br>dbclk_gpio1 clock gating control.<br>When high, disable clock     |

**VEPUCRU VEPUGATE CON02**

Address: Operational Base + offset (0x0808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | clk_testout_vepu_1_en<br>clk_testout_vepu2vo_1 clock gating control.<br>When high, disable clock                                   |
| 13         | RW          | 0x0                | clk_testout_vepu_0_en<br>clk_testout_vepu2vo_0 clock gating control.<br>When high, disable clock                                   |
| 12         | RW          | 0x0                | clk_matrix_400m_src2vo_en<br>clk_matrix_400m_src2vo clock gating control.<br>When high, disable clock                              |
| 11         | RW          | 0x0                | clk_matrix_300m_src2vo_en<br>clk_matrix_300m_src2vo clock gating control.<br>When high, disable clock                              |
| 10         | RW          | 0x0                | clk_matrix_200m_src2vo_en<br>clk_matrix_200m_src2vo clock gating control.<br>When high, disable clock                              |
| 9          | RW          | 0x0                | clk_matrix_150m_src2vo_en<br>clk_matrix_150m_src2vo clock gating control.<br>When high, disable clock                              |
| 8          | RW          | 0x0                | clk_matrix_100m_src2vo_en<br>clk_matrix_100m_src2vo clock gating control.<br>When high, disable clock                              |

| Bit | Attr | Reset Value | Description                                                                                             |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------|
| 7   | RW   | 0x0         | clk_matrix_50m_src2vo_en<br>clk_matrix_50m_src2vo clock gating control.<br>When high, disable clock     |
| 6   | RW   | 0x0         | clk_matrix_500m_src2ddr_en<br>clk_matrix_500m_src2ddr clock gating control.<br>When high, disable clock |
| 5   | RW   | 0x0         | clk_matrix_300m_src2ddr_en<br>clk_matrix_300m_src2ddr clock gating control.<br>When high, disable clock |
| 4   | RW   | 0x0         | clk_matrix_100m_src2ddr_en<br>clk_matrix_100m_src2ddr clock gating control.<br>When high, disable clock |
| 3   | RW   | 0x0         | clk_matrix_50m_src2ddr_en<br>clk_matrix_50m_src2ddr clock gating control.<br>When high, disable clock   |
| 2   | RW   | 0x0         | clk_matrix_500m_src2npu_en<br>clk_matrix_500m_src2npu clock gating control.<br>When high, disable clock |
| 1   | RW   | 0x0         | clk_matrix_400m_src2npu_en<br>clk_matrix_400m_src2npu clock gating control.<br>When high, disable clock |
| 0   | RW   | 0x0         | clk_matrix_339m_src2npu_en<br>clk_matrix_339m_src2npu clock gating control.<br>When high, disable clock |

**VEPUCRU VEPUSOFRST CON00**

Address: Operational Base + offset (0x0A00)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15    | RW   | 0x0         | presetn_gpio1<br>When high, reset relative logic                                                                                   |
| 14    | RW   | 0x0         | presetn_vicap_vepu<br>When high, reset relative logic                                                                              |
| 13    | RW   | 0x0         | resetn_core_vepu_dvbm<br>When high, reset relative logic                                                                           |
| 12    | RW   | 0x0         | aresetn_vepu_pp<br>When high, reset relative logic                                                                                 |
| 11    | RW   | 0x0         | hresetn_vepu_pp<br>When high, reset relative logic                                                                                 |
| 10    | RW   | 0x0         | resetn_core_vepu<br>When high, reset relative logic                                                                                |

| Bit | Attr | Reset Value | Description                                             |
|-----|------|-------------|---------------------------------------------------------|
| 9   | RW   | 0x0         | aresetn_vepu<br>When high, reset relative logic         |
| 8   | RW   | 0x0         | hresetn_vepu<br>When high, reset relative logic         |
| 7   | RW   | 0x0         | presetn_vepu_biu<br>When high, reset relative logic     |
| 6   | RW   | 0x0         | aresetn_vepu_com_biu<br>When high, reset relative logic |
| 5   | RW   | 0x0         | aresetn_vepu_biu<br>When high, reset relative logic     |
| 4   | RW   | 0x0         | hresetn_vepu_biu<br>When high, reset relative logic     |
| 3:0 | RO   | 0x0         | reserved                                                |

**VEPUCRU VEPUSOFRST CON01**

Address: Operational Base + offset (0x0A04)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:9  | RO   | 0x00        | reserved                                                                                                                           |
| 8     | RW   | 0x0         | resetn_uart_detn_flt<br>When high, reset relative logic                                                                            |
| 7     | RW   | 0x0         | presetn_vepu_grf<br>When high, reset relative logic                                                                                |
| 6     | RW   | 0x0         | presetn_vepu_sgrf<br>When high, reset relative logic                                                                               |
| 5     | RW   | 0x0         | presetn_vepu_cru<br>When high, reset relative logic                                                                                |
| 4     | RO   | 0x0         | reserved                                                                                                                           |
| 3     | RW   | 0x0         | resetn_spi0<br>When high, reset relative logic                                                                                     |
| 2     | RW   | 0x0         | presetn_spi0<br>When high, reset relative logic                                                                                    |
| 1     | RW   | 0x0         | presetn_vepu_ioc<br>When high, reset relative logic                                                                                |
| 0     | RW   | 0x0         | dbresetn_gpio1<br>When high, reset relative logic                                                                                  |

**2.12 VICRU Register Description****2.12.1 Registers Summary**

| Name                 | Offset | Size | Reset Value | Description                                   |
|----------------------|--------|------|-------------|-----------------------------------------------|
| VICRU_VICLKSEL_CON00 | 0x0300 | W    | 0x00000000  | Internal clock select and division register 0 |
| VICRU_VICLKSEL_CON01 | 0x0304 | W    | 0x00000000  | Internal clock select and division register 1 |
| VICRU_VICLKSEL_CON02 | 0x0308 | W    | 0x00000006  | Internal clock select and division register 2 |
| VICRU_VICLKSEL_CON03 | 0x030C | W    | 0x00000003  | Internal clock select and division register 3 |
| VICRU_VIGATE_CON00   | 0x0800 | W    | 0x00000000  | Internal clock gate and division register 0   |
| VICRU_VIGATE_CON01   | 0x0804 | W    | 0x00000000  | Internal clock gate and division register 1   |
| VICRU_VIGATE_CON02   | 0x0808 | W    | 0x00000000  | Internal clock gate and division register 2   |
| VICRU_VISOFRST_CON00 | 0x0A00 | W    | 0x00000000  | Internal clock reset register 0               |
| VICRU_VISOFRST_CON01 | 0x0A04 | W    | 0x00000000  | Internal clock reset register 1               |
| VICRU_VISOFRST_CON02 | 0x0A08 | W    | 0x00000000  | Internal clock reset register 2               |

Notes:Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 2.12.2 Detail Registers Description

### VICRU\_VICLKSEL\_CON00

Address: Operational Base + offset (0x0300)

| Bit   | Attr | Reset Value | Description                                                                                                                                                 |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                          |
| 15:11 | RO   | 0x00        | reserved                                                                                                                                                    |
| 10:9  | RW   | 0x0         | dclk_vicap_sel<br>dclk_vicap clock mux.<br>2'b00: clk_matrix_339m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func   |
| 8:7   | RW   | 0x0         | clk_core_isp3p2_sel<br>clk_core_isp3p2 clock mux.<br>2'b00: clk_matrix_339m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_pvtpll_0<br>2'b11: clk_pvtpll_1 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | pclk_vi_rtc_root_sel<br>pclk_vi_rtc_root clock mux.<br>1'b0: clk_matrix_50m_src<br>1'b1: xin_osc0_func                                                        |
| 5:4        | RW          | 0x0                | pclk_vi_root_sel<br>pclk_vi_root clock mux.<br>2'b00: clk_matrix_150m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func  |
| 3:2        | RW          | 0x0                | aclk_vi_root_sel<br>aclk_vi_root clock mux.<br>2'b00: clk_matrix_339m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func |
| 1:0        | RW          | 0x0                | hclk_vi_root_sel<br>hclk_vi_root clock mux.<br>2'b00: clk_matrix_150m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func  |

**VICRU\_VICLKSEL\_CON01**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | cclk_src_sdmmc_sel<br>cclk_src_sdmmc clock mux.<br>1'b0: clk_matrix_400m_src<br>1'b1: xin_osc0_func                                |
| 13:8       | RW          | 0x00               | cclk_src_sdmmc_div<br>DT50 division register.<br>Divide cclk_src_sdmmc by (div_con + 1).                                           |
| 7:0        | RO          | 0x00               | reserved                                                                                                                           |

**VICRU\_VICLKSEL\_CON02**

Address: Operational Base + offset (0x0308)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                         |
| 15:9       | RO          | 0x00               | reserved                                                                                                                                                                                   |
| 8:6        | RW          | 0x0                | clk_testout_vi2peri_0_sel<br>clk_testout_vi2peri_0 clock mux.<br>3'b000: sdmmc_test_clkout_0<br>3'b001: aclk_vi_root<br>3'b010: hclk_vi_root<br>3'b011: pclk_vi_root<br>3'b100: dclk_vicap |
| 5:1        | RW          | 0x03               | clk_testout_vi2peri_0_div<br>Divide clk_testout_vi2peri_0 by (div_con + 1).                                                                                                                |
| 0          | RO          | 0x0                | reserved                                                                                                                                                                                   |

**VICRU\_VICLKSEL\_CON03**

Address: Operational Base + offset (0x030C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                         |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                                                                                                   |
| 7:5        | RW          | 0x0                | clk_testout_vi2peri_1_sel<br>clk_testout_vi2peri_1 clock mux.<br>3'b000: sdmmc_test_clkout_1<br>3'b001: pclk_vi_rtc_root<br>3'b010: clk_core_isp3p2<br>3'b011: cclk_src_sdmmc<br>3'b100: clk_testout_core2vi<br>3'b101: clk_testout_npu2vi |
| 4:0        | RW          | 0x03               | clk_testout_vi2peri_1_div<br>Divide clk_testout_vi2peri_1 by (div_con + 1).                                                                                                                                                                |

**VICRU\_VIGATE\_CON00**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | i1clk_vicap_en<br>i1clk_vicap clock gating control.<br>When high, disable clock                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | i0clk_vicap_en<br>i0clk_vicap clock gating control.<br>When high, disable clock           |
| 13         | RW          | 0x0                | hclk_vicap_en<br>hclk_vicap clock gating control.<br>When high, disable clock             |
| 12         | RW          | 0x0                | ackl_vicap_en<br>ackl_vicap clock gating control.<br>When high, disable clock             |
| 11         | RW          | 0x0                | pclk_vicap_en<br>pclk_vicap clock gating control.<br>When high, disable clock             |
| 10         | RW          | 0x0                | dclk_vicap_en<br>dclk_vicap clock gating control.<br>When high, disable clock             |
| 9          | RW          | 0x0                | clk_core_isp3p2_en<br>clk_core_isp3p2 clock gating control.<br>When high, disable clock   |
| 8          | RW          | 0x0                | ackl_isp3p2_en<br>ackl_isp3p2 clock gating control.<br>When high, disable clock           |
| 7          | RW          | 0x0                | hclk_isp3p2_en<br>hclk_isp3p2 clock gating control.<br>When high, disable clock           |
| 6          | RW          | 0x0                | pclk_vi_biu_en<br>pclk_vi_biu clock gating control.<br>When high, disable clock           |
| 5          | RW          | 0x0                | ackl_vi_biu_en<br>ackl_vi_biu clock gating control.<br>When high, disable clock           |
| 4          | RW          | 0x0                | hclk_vi_biu_en<br>hclk_vi_biu clock gating control.<br>When high, disable clock           |
| 3          | RW          | 0x0                | pclk_vi_rtc_root_en<br>pclk_vi_rtc_root clock gating control.<br>When high, disable clock |
| 2          | RW          | 0x0                | pclk_vi_root_en<br>pclk_vi_root clock gating control.<br>When high, disable clock         |
| 1          | RW          | 0x0                | ackl_vi_root_en<br>ackl_vi_root clock gating control.<br>When high, disable clock         |
| 0          | RW          | 0x0                | hclk_vi_root_en<br>hclk_vi_root clock gating control.<br>When high, disable clock         |

**VICRU VIGATE CON01**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | pclk_gpio3_en<br>pclk_gpio3 clock gating control.<br>When high, disable clock                                                      |
| 14         | RW          | 0x0                | pclk_mipicsiphy_en<br>pclk_mipicsiphy clock gating control.<br>When high, disable clock                                            |
| 13         | RW          | 0x0                | clk_sdmmc_detn_flt_en<br>clk_sdmmc_detn_flt clock gating control.<br>When high, disable clock                                      |
| 12         | RW          | 0x0                | hclk_sdmmc_en<br>hclk_sdmmc clock gating control.<br>When high, disable clock                                                      |
| 11         | RW          | 0x0                | cclk_src_sdmmc_en<br>cclk_src_sdmmc clock gating control.<br>When high, disable clock                                              |
| 10         | RW          | 0x0                | mbist_clk_clk_core_isp3p2_en<br>mbist_clk_clk_core_isp3p2 clock gating control.<br>When high, disable clock                        |
| 9          | RW          | 0x0                | mbist_clk_aclk_isp3p2_en<br>mbist_clk_aclk_isp3p2 clock gating control.<br>When high, disable clock                                |
| 8          | RW          | 0x0                | mbist_clk_dclk_vicap_en<br>mbist_clk_dclk_vicap clock gating control.<br>When high, disable clock                                  |
| 7          | RW          | 0x0                | mbist_clk_aclk_vicap_en<br>mbist_clk_aclk_vicap clock gating control.<br>When high, disable clock                                  |
| 6          | RW          | 0x0                | clk_rxbyteclkhs_1_en<br>clk_rxbyteclkhs_1 clock gating control.<br>When high, disable clock                                        |
| 5          | RW          | 0x0                | pclk_csihost1_en<br>pclk_csihost1 clock gating control.<br>When high, disable clock                                                |
| 4          | RW          | 0x0                | clk_rxbyteclkhs_0_en<br>clk_rxbyteclkhs_0 clock gating control.<br>When high, disable clock                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | pclk_csihost0_en<br>pclk_csihost0 clock gating control.<br>When high, disable clock |
| 2          | RW          | 0x0                | isp0clk_vicap_en<br>isp0clk_vicap clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | rx1pclk_vicap_en<br>rx1pclk_vicap clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | rx0pclk_vicap_en<br>rx0pclk_vicap clock gating control.<br>When high, disable clock |

**VICRU\_VIGATE CON02**

Address: Operational Base + offset (0x0808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | clk_testout_vi2peri_1_en<br>clk_testout_vi2peri_1 clock gating control.<br>When high, disable clock                                |
| 10         | RW          | 0x0                | clk_testout_vi2peri_0_en<br>clk_testout_vi2peri_0 clock gating control.<br>When high, disable clock                                |
| 9:8        | RO          | 0x0                | reserved                                                                                                                           |
| 7          | RW          | 0x0                | pclk_vi_rtc_biu_en<br>pclk_vi_rtc_biu clock gating control.<br>When high, disable clock                                            |
| 6          | RW          | 0x0                | pclk_vi_rtc_phy_en<br>pclk_vi_rtc_phy clock gating control.<br>When high, disable clock                                            |
| 5          | RW          | 0x0                | pclk_vi_rtc_test_en<br>pclk_vi_rtc_test clock gating control.<br>When high, disable clock                                          |
| 4          | RW          | 0x0                | pclk_vi_cru_en<br>pclk_vi_cru clock gating control.<br>When high, disable clock                                                    |
| 3          | RW          | 0x0                | pclk_vi_sgrf_en<br>pclk_vi_sgrf clock gating control.<br>When high, disable clock                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | pclk_vi_grf_en<br>pclk_vi_grf clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | pclk_vi_ioc_en<br>pclk_vi_ioc clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | dbclk_gpio3_en<br>dbclk_gpio3 clock gating control.<br>When high, disable clock |

**VICRU\_VISOFRST CON00**

Address: Operational Base + offset (0x0A00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | i1resetn_vicap<br>When high, reset relative logic                                                                                  |
| 14         | RW          | 0x0                | i0resetn_vicap<br>When high, reset relative logic                                                                                  |
| 13         | RW          | 0x0                | hresetn_vicap<br>When high, reset relative logic                                                                                   |
| 12         | RW          | 0x0                | aresetn_vicap<br>When high, reset relative logic                                                                                   |
| 11         | RW          | 0x0                | presetn_vicap<br>When high, reset relative logic                                                                                   |
| 10         | RW          | 0x0                | dresetn_vicap<br>When high, reset relative logic                                                                                   |
| 9          | RW          | 0x0                | resetn_core_isp3p2<br>When high, reset relative logic                                                                              |
| 8:7        | RO          | 0x0                | reserved                                                                                                                           |
| 6          | RW          | 0x0                | presetn_vi_biu<br>When high, reset relative logic                                                                                  |
| 5          | RW          | 0x0                | aresetn_vi_biu<br>When high, reset relative logic                                                                                  |
| 4          | RW          | 0x0                | hresetn_vi_biu<br>When high, reset relative logic                                                                                  |
| 3:0        | RO          | 0x0                | reserved                                                                                                                           |

**VICRU\_VISOFRST CON01**

Address: Operational Base + offset (0x0A04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | presetn_gpio3<br>When high, reset relative logic                                                                                   |
| 14         | RW          | 0x0                | presetn_mipicsiphy<br>When high, reset relative logic                                                                              |
| 13         | RW          | 0x0                | resetn_sdmmc_detn_flt<br>When high, reset relative logic                                                                           |
| 12         | RW          | 0x0                | hresetn_sdmmc<br>When high, reset relative logic                                                                                   |
| 11:7       | RO          | 0x00               | reserved                                                                                                                           |
| 6          | RW          | 0x0                | presetn_csihost1<br>When high, reset relative logic                                                                                |
| 5          | RO          | 0x0                | reserved                                                                                                                           |
| 4          | RW          | 0x0                | presetn_csihost0<br>When high, reset relative logic                                                                                |
| 3          | RO          | 0x0                | reserved                                                                                                                           |
| 2          | RW          | 0x0                | isp0resetn_vicap<br>When high, reset relative logic                                                                                |
| 1          | RW          | 0x0                | rx1resetn_vicap<br>When high, reset relative logic                                                                                 |
| 0          | RW          | 0x0                | rx0resetn_vicap<br>When high, reset relative logic                                                                                 |

**VICRU VISOFTRST CON02**

Address: Operational Base + offset (0x0A08)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | presetn_vi_rtc_biu<br>When high, reset relative logic                                                                              |
| 6          | RO          | 0x0                | reserved                                                                                                                           |
| 5          | RW          | 0x0                | presetn_vi_rtc_test<br>When high, reset relative logic                                                                             |
| 4          | RW          | 0x0                | presetn_vi_cru<br>When high, reset relative logic                                                                                  |
| 3          | RW          | 0x0                | presetn_vi_sgrf<br>When high, reset relative logic                                                                                 |
| 2          | RW          | 0x0                | presetn_vi_grf<br>When high, reset relative logic                                                                                  |

| Bit | Attr | Reset Value | Description                                       |
|-----|------|-------------|---------------------------------------------------|
| 1   | RW   | 0x0         | presetn_vi_ioc<br>When high, reset relative logic |
| 0   | RW   | 0x0         | dbresetn_gpio3<br>When high, reset relative logic |

## 2.13 VOCRU Register Description

### 2.13.1 Registers Summary

| Name                  | Offset | Size | Reset Value | Description                                   |
|-----------------------|--------|------|-------------|-----------------------------------------------|
| VOCRU VOCLKSEL CON0_0 | 0x0300 | W    | 0x0000000C0 | Internal clock select and division register 0 |
| VOCRU VOCLKSEL CON0_1 | 0x0304 | W    | 0x000000003 | Internal clock select and division register 1 |
| VOCRU VOCLKSEL CON0_2 | 0x0308 | W    | 0x000000000 | Internal clock select and division register 2 |
| VOCRU VOCLKSEL CON0_3 | 0x030C | W    | 0x00002433  | Internal clock select and division register 3 |
| VOCRU VOGATE CON00    | 0x0800 | W    | 0x000000000 | Internal clock gate and division register 0   |
| VOCRU VOGATE CON01    | 0x0804 | W    | 0x000000000 | Internal clock gate and division register 1   |
| VOCRU VOGATE CON02    | 0x0808 | W    | 0x000000000 | Internal clock gate and division register 2   |
| VOCRU VOGATE CON03    | 0x080C | W    | 0x000000000 | Internal clock gate and division register 3   |
| VOCRU VOSOFRST CON00  | 0x0A00 | W    | 0x000000000 | Internal clock reset register 0               |
| VOCRU VOSOFRST CON01  | 0x0A04 | W    | 0x000000000 | Internal clock reset register 1               |
| VOCRU VOSOFRST CON02  | 0x0A08 | W    | 0x000000000 | Internal clock reset register 2               |
| VOCRU VOSOFRST CON03  | 0x0A0C | W    | 0x000000000 | Internal clock reset register 3               |

Notes:Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**-Double WORD (64 bits) access

### 2.13.2 Detail Registers Description

#### VOCRU VOCLKSEL CON00

Address: Operational Base + offset (0x0300)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14 | RO   | 0x0         | reserved                                                                                                                           |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:11 | RW   | 0x0         | clk_testout_vo_0_sel<br>clk_testout_vo_0 clock mux.<br>3'b000: sdio_test_clkout_0<br>3'b001: clk_testout_vepu2vo_0<br>3'b010: aclk_vo_root<br>3'b011: hclk_vo_root<br>3'b100: clk_core_rga2e<br>3'b101: aclk_vop_root |
| 10:6  | RW   | 0x03        | clk_testout_vo_0_div<br>Divide clk_testout_vo_0 by (div_con + 1).                                                                                                                                                     |
| 5:4   | RW   | 0x0         | pclk_vo_root_sel<br>pclk_vo_root clock mux.<br>2'b00: clk_matrix_150m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func                                                          |
| 3:2   | RW   | 0x0         | hclk_vo_root_sel<br>hclk_vo_root clock mux.<br>2'b00: clk_matrix_200m_src<br>2'b01: clk_matrix_100m_src<br>2'b10: clk_matrix_50m_src<br>2'b11: xin_osc0_func                                                          |
| 1:0   | RW   | 0x0         | ackl_vo_root_sel<br>ackl_vo_root clock mux.<br>2'b00: clk_matrix_400m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func                                                         |

**VOCRU VOCLKSEL CON01**

Address: Operational Base + offset (0x0304)

| Bit   | Attr | Reset Value | Description                                                                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                              |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                        |
| 13:12 | RW   | 0x0         | ackl_mac_root_sel<br>ackl_mac_root clock mux.<br>2'b00: clk_matrix_300m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                      |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:10 | RW   | 0x0         | aclk_vop_root_sel<br>aclk_vop_root clock mux.<br>2'b00: clk_matrix_300m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func                                                  |
| 9:8   | RW   | 0x0         | clk_core_rga2e_sel<br>clk_core_rga2e clock mux.<br>2'b00: clk_matrix_400m_src<br>2'b01: clk_matrix_200m_src<br>2'b10: clk_matrix_100m_src<br>2'b11: xin_osc0_func                                                |
| 7:5   | RW   | 0x0         | clk_testout_vo_1_sel<br>clk_testout_vo_1 clock mux.<br>3'b000: sdio_test_clkout_1<br>3'b001: clk_testout_vepu2vo_1<br>3'b010: aclk_mac_root<br>3'b011: pclk_vo_root<br>3'b100: cclk_src_sdio<br>3'b101: dclk_vop |
| 4:0   | RW   | 0x03        | clk_testout_vo_1_div<br>Divide clk_testout_vo_1 by (div_con + 1).                                                                                                                                                |

**VOCRU VOCLKSEL CON02**

Address: Operational Base + offset (0x0308)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14 | RO   | 0x0         | reserved                                                                                                                           |
| 13    | RW   | 0x0         | cclk_src_sdio_sel<br>cclk_src_sdio clock mux.<br>1'b0: clk_matrix_400m_src<br>1'b1: xin_osc0_func                                  |
| 12:7  | RW   | 0x00        | cclk_src_sdio_div<br>DT50 division register.<br>Divide cclk_src_sdio by (div_con + 1).                                             |
| 6:1   | RW   | 0x00        | clk_gmac0_tx_50m_o_div<br>Divide clk_gmac0_tx_50m_o by (div_con + 1).                                                              |
| 0     | RO   | 0x0         | reserved                                                                                                                           |

**VOCRU VOCLKSEL CON03**

Address: Operational Base + offset (0x030C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:13      | RW          | 0x1                | clk_user_otpc_s_div<br>Divide clk_user_otpc_s by (div_con + 1).                                                                    |
| 12:10      | RW          | 0x1                | clk_user_otpc_ns_div<br>Divide clk_user_otpc_ns by (div_con + 1).                                                                  |
| 9:5        | RW          | 0x01               | clk_tsadc_tsen_div<br>Divide clk_tsadc_tsen by (div_con + 1).                                                                      |
| 4:0        | RW          | 0x13               | clk_tsadc_div<br>Divide clk_tsadc by (div_con + 1).                                                                                |

**VOCRU VOGATE CON00**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | ackl_vop_en<br>ackl_vop clock gating control.<br>When high, disable clock                                                          |
| 14         | RW          | 0x0                | dclk_vop_en<br>dclk_vop clock gating control.<br>When high, disable clock                                                          |
| 13         | RW          | 0x0                | hclk_vop_en<br>hclk_vop clock gating control.<br>When high, disable clock                                                          |
| 12         | RW          | 0x0                | ackl_vop_biu_en<br>ackl_vop_biu clock gating control.<br>When high, disable clock                                                  |
| 11         | RW          | 0x0                | ackl_vop_root_en<br>ackl_vop_root clock gating control.<br>When high, disable clock                                                |
| 10         | RW          | 0x0                | pclk_vo_grf_en<br>pclk_vo_grf clock gating control.<br>When high, disable clock                                                    |
| 9          | RW          | 0x0                | clk_core_rga2e_en<br>clk_core_rga2e clock gating control.<br>When high, disable clock                                              |
| 8          | RW          | 0x0                | ackl_rga2e_en<br>ackl_rga2e clock gating control.<br>When high, disable clock                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | hclk_rga2e_en<br>hclk_rga2e clock gating control.<br>When high, disable clock             |
| 6          | RW          | 0x0                | clk_testout_vo_1_en<br>clk_testout_vo_1 clock gating control.<br>When high, disable clock |
| 5          | RW          | 0x0                | clk_testout_vo_0_en<br>clk_testout_vo_0 clock gating control.<br>When high, disable clock |
| 4          | RW          | 0x0                | hclk.vo_biu_en<br>hclk.vo_biu clock gating control.<br>When high, disable clock           |
| 3          | RW          | 0x0                | ackl.vo_biu_en<br>ackl.vo_biu clock gating control.<br>When high, disable clock           |
| 2          | RW          | 0x0                | pclk.vo_root_en<br>pclk.vo_root clock gating control.<br>When high, disable clock         |
| 1          | RW          | 0x0                | hclk.vo_root_en<br>hclk.vo_root clock gating control.<br>When high, disable clock         |
| 0          | RW          | 0x0                | ackl.vo_root_en<br>ackl.vo_root clock gating control.<br>When high, disable clock         |

**VOCRU VOGATE CON01**

Address: Operational Base + offset (0x0804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | hclk_sdio_en<br>hclk_sdio clock gating control.<br>When high, disable clock                                                        |
| 14         | RW          | 0x0                | cclk_src_sdio_en<br>cclk_src_sdio clock gating control.<br>When high, disable clock                                                |
| 13         | RW          | 0x0                | pclk.vo_cru_en<br>pclk.vo_cru clock gating control.<br>When high, disable clock                                                    |
| 12         | RW          | 0x0                | pclk.vo_sgrf_en<br>pclk.vo_sgrf clock gating control.<br>When high, disable clock                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | mbist_clk_aclk_mac_en<br>mbist_clk_aclk_mac clock gating control.<br>When high, disable clock |
| 10         | RO          | 0x0                | reserved                                                                                      |
| 9          | RW          | 0x0                | pclk_mac_en<br>pclk_mac clock gating control.<br>When high, disable clock                     |
| 8          | RW          | 0x0                | ackl_mac_en<br>ackl_mac clock gating control.<br>When high, disable clock                     |
| 7          | RW          | 0x0                | ackl_mac_biu_en<br>ackl_mac_biu clock gating control.<br>When high, disable clock             |
| 6          | RW          | 0x0                | pclk_mac_biu_en<br>pclk_mac_biu clock gating control.<br>When high, disable clock             |
| 5          | RO          | 0x0                | reserved                                                                                      |
| 4          | RW          | 0x0                | ackl_mac_root_en<br>ackl_mac_root clock gating control.<br>When high, disable clock           |
| 3          | RW          | 0x0                | mbist_clk_cclk_rga_en<br>mbist_clk_cclk_rga clock gating control.<br>When high, disable clock |
| 2          | RW          | 0x0                | mbist_clk_aclk_rga_en<br>mbist_clk_aclk_rga clock gating control.<br>When high, disable clock |
| 1          | RW          | 0x0                | mbist_clk_aclk_vop_en<br>mbist_clk_aclk_vop clock gating control.<br>When high, disable clock |
| 0          | RW          | 0x0                | mbist_clk_mac_phy_en<br>mbist_clk_mac_phy clock gating control.<br>When high, disable clock   |

**VOCRU VOGATE CON02**

Address: Operational Base + offset (0x0808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_pmc_otp_en<br>clk_pmc_otp clock gating control.<br>When high, disable clock                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | pclk_otp_mask_en<br>pclk_otp_mask clock gating control.<br>When high, disable clock       |
| 13         | RW          | 0x0                | clk_macphy_en<br>clk_macphy clock gating control.<br>When high, disable clock             |
| 12         | RO          | 0x0                | reserved                                                                                  |
| 11         | RW          | 0x0                | clk_otpc_arb_en<br>clk_otpc_arb clock gating control.<br>When high, disable clock         |
| 10         | RW          | 0x0                | clk_user_otpc_s_en<br>clk_user_otpc_s clock gating control.<br>When high, disable clock   |
| 9          | RW          | 0x0                | clk_sbpi_otpc_s_en<br>clk_sbpi_otpc_s clock gating control.<br>When high, disable clock   |
| 8          | RO          | 0x0                | reserved                                                                                  |
| 7          | RW          | 0x0                | pclk_otpc_s_en<br>pclk_otpc_s clock gating control.<br>When high, disable clock           |
| 6          | RW          | 0x0                | clk_user_otpc_ns_en<br>clk_user_otpc_ns clock gating control.<br>When high, disable clock |
| 5          | RW          | 0x0                | clk_sbpi_otpc_ns_en<br>clk_sbpi_otpc_ns clock gating control.<br>When high, disable clock |
| 4          | RO          | 0x0                | reserved                                                                                  |
| 3          | RW          | 0x0                | pclk_otpc_ns_en<br>pclk_otpc_ns clock gating control.<br>When high, disable clock         |
| 2          | RW          | 0x0                | clk_tsadc_tsen_en<br>clk_tsadc_tsen clock gating control.<br>When high, disable clock     |
| 1          | RW          | 0x0                | clk_tsadc_en<br>clk_tsadc clock gating control.<br>When high, disable clock               |
| 0          | RW          | 0x0                | pclk_tsadc_en<br>pclk_tsadc clock gating control.<br>When high, disable clock             |

**VOCRU VOGATE CON03**

Address: Operational Base + offset (0x080C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:3       | RO          | 0x0000             | reserved                                                                                                                           |
| 2          | RW          | 0x0                | pclk_vo_ioc_en<br>pclk_vo_ioc clock gating control.<br>When high, disable clock                                                    |
| 1          | RW          | 0x0                | dbclk_gpio2_en<br>dbclk_gpio2 clock gating control.<br>When high, disable clock                                                    |
| 0          | RW          | 0x0                | pclk_gpio2_en<br>pclk_gpio2 clock gating control.<br>When high, disable clock                                                      |

**VOCRU VOSOFRST CON00**

Address: Operational Base + offset (0x0A00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | aresetn_vop<br>When high, reset relative logic                                                                                     |
| 14         | RW          | 0x0                | dresetn_vop<br>When high, reset relative logic                                                                                     |
| 13         | RW          | 0x0                | hresetn_vop<br>When high, reset relative logic                                                                                     |
| 12         | RW          | 0x0                | aresetn_vop_biu<br>When high, reset relative logic                                                                                 |
| 11         | RO          | 0x0                | reserved                                                                                                                           |
| 10         | RW          | 0x0                | presetn_vo_grf<br>When high, reset relative logic                                                                                  |
| 9          | RW          | 0x0                | resetn_core_rga2e<br>When high, reset relative logic                                                                               |
| 8          | RW          | 0x0                | aresetn_rga2e<br>When high, reset relative logic                                                                                   |
| 7          | RW          | 0x0                | hresetn_rga2e<br>When high, reset relative logic                                                                                   |
| 6:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4          | RW          | 0x0                | hresetn_vo_biu<br>When high, reset relative logic                                                                                  |
| 3          | RW          | 0x0                | aresetn_vo_biu<br>When high, reset relative logic                                                                                  |
| 2:0        | RO          | 0x0                | reserved                                                                                                                           |

**VOCRU\_VOSOFRST CON01**

Address: Operational Base + offset (0x0A04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | hresetn_sdio<br>When high, reset relative logic                                                                                    |
| 14         | RO          | 0x0                | reserved                                                                                                                           |
| 13         | RW          | 0x0                | presetn_vo_cru<br>When high, reset relative logic                                                                                  |
| 12         | RW          | 0x0                | presetn_vo_sgrf<br>When high, reset relative logic                                                                                 |
| 11:9       | RO          | 0x0                | reserved                                                                                                                           |
| 8          | RW          | 0x0                | aresetn_mac<br>When high, reset relative logic                                                                                     |
| 7          | RW          | 0x0                | aresetn_mac_biu<br>When high, reset relative logic                                                                                 |
| 6          | RW          | 0x0                | presetn_mac_biu<br>When high, reset relative logic                                                                                 |
| 5:0        | RO          | 0x00               | reserved                                                                                                                           |

**VOCRU\_VOSOFRST CON02**

Address: Operational Base + offset (0x0A08)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | resetn_pmc_otp<br>When high, reset relative logic                                                                                  |
| 14         | RW          | 0x0                | presetn_otp_mask<br>When high, reset relative logic                                                                                |
| 13         | RW          | 0x0                | resetn_macphy<br>When high, reset relative logic                                                                                   |
| 12         | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | resetn_otpc_arb<br>When high, reset relative logic                                                                                 |
| 10         | RW          | 0x0                | resetn_user_otpc_s<br>When high, reset relative logic                                                                              |
| 9          | RW          | 0x0                | resetn_sbpi_otpc_s<br>When high, reset relative logic                                                                              |
| 8          | RO          | 0x0                | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 7          | RW          | 0x0                | presetn_otpc_s<br>When high, reset relative logic      |
| 6          | RW          | 0x0                | resetn_user_otpc_ns<br>When high, reset relative logic |
| 5          | RW          | 0x0                | resetn_sbpi_otpc_ns<br>When high, reset relative logic |
| 4          | RO          | 0x0                | reserved                                               |
| 3          | RW          | 0x0                | presetn_otpc_ns<br>When high, reset relative logic     |
| 2          | RO          | 0x0                | reserved                                               |
| 1          | RW          | 0x0                | resetn_tsadc<br>When high, reset relative logic        |
| 0          | RW          | 0x0                | presetn_tsadc<br>When high, reset relative logic       |

**VOCRU VOSOFRST CON03**

Address: Operational Base + offset (0x0A0C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:3       | RO          | 0x0000             | reserved                                                                                                                           |
| 2          | RW          | 0x0                | presetn_vo_ioc<br>When high, reset relative logic                                                                                  |
| 1          | RW          | 0x0                | dbresetn_gpio2<br>When high, reset relative logic                                                                                  |
| 0          | RW          | 0x0                | presetn_gpio2<br>When high, reset relative logic                                                                                   |

**2.14 Application Notes****2.14.1 PLL Usage****2.14.1.1 Start-up Operation**

Set the PLL registers at time t3 after setting the power from 0V to VDD at time t2. Set PLLEN=0 before PLL starts to operate. Then set PLLEN=1 at t4 to initialize PLL. Note that PLL generates a clock signal with the desired frequency only after Lock time has been passed. PLLEN goes high 1us after power, reference clock and all inputs are stable, that means t4-t2 should be more than 1us.



Fig. 2-5 PLL Start-up Operation

To change PLL config, you must set PLLEN=0 first. The other input pins are not allowed to be changed after PLL is locked.



Fig. 2-6 PLL Config Change Operation

### 2.14.1.2 Bypass Operation

Bypass mode functions only when PLL is operating (PLLEN=1). In bypass mode, the frequency of FOUT will be set to be equal to FIN. When PLL get locked (LOCK = 1), PLL generates a stable clock signal with desired target frequency.



Fig. 2-7 PLL Bypass Operation

### 2.14.1.3 Setting Guide on PLLEN and BYPASS

PLLEN is a reset signal of PLL. PLL enters the power down mode when PLLEN= 0.  
BYPASS enables the bypass mode of PLL. When BYPASS= 1, PLL enters the bypass mode and FOUT is equal to FIN.

## 2.14.2 Fractional PLL Usage

### 2.14.2.1 PLL Frequency Configuration

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.(x= D, G)

- If DSMPD = 1 (DSM is disabled, "integer mode")

$$\text{FOUTVCO} = (\text{FREF} / \text{REFDIV}) * \text{FBDIV}$$

$$\text{FOUTPOSTDIV} = \text{FOUTVCO} / (\text{POSTDIV1} * \text{POSTDIV2})$$

When FREF is 24MHz, and if 700MHz FOUTPOSTDIV is needed. The configuration can be:

```

DSMPD = 1
REFDIV = 6
FBDIV = 175
POSTDIV1=1
POSTDIV2=1

```

And then

$$\text{FOUTVCO} = (\text{FREF} / \text{REFDIV}) * \text{FBDIV} = 24/6*175=700$$

$$\text{FOUTPOSTDIV} = \text{FOUTVCO} / (\text{POSTDIV1} * \text{POSTDIV2}) = 700/1/1=700$$

- If DSMPD = 0 (DSM is enabled, "fractional mode")

$$\text{FOUTVCO} = (\text{FREF} / \text{REFDIV}) * (\text{FBDIV} + \text{FRAC} / (2^{24}))$$

FOUTPOSTDIV = FOUTVCO / (POSTDIV1\*POSTDIV2)

When FREF is 24MHz, and if 491.52MHz FOUTPOSTDIV is needed. The configuration can be:

```
DSMPD = 0  
REFDIV = 1  
FBDIV = 40  
FRAC = 24'hf5c28f  
POSTDIV1=2  
POSTDIV2=1
```

And then

$$\text{FOUTVCO} = (\text{FREF} / \text{REFDIV}) * (\text{FBDIV} + \text{FRAC} / (2^{24})) = 983.04$$

$$\text{FOUTPOSTDIV} = \text{FOUTVCO} / (\text{POSTDIV1} * \text{POSTDIV2}) = 983.04 / (2 * 1) = 491.52$$

- POSTDIV1=0, POSTDIV2=0 are unused. We should make sure that POSTDIV1>=POSTDIV2.

### 2.14.2.2 PLL Setting Consideration

- If the POSTDIV value is changed during operation, a short pulse (glitch) may occur on FOUTPOSTDIV. The minimum width of the short pulse will be equal to twice the period of the VCO. Therefore, if the circuitry clocked by the PLL is sensitive to short pulses, the new divide value should be re-timed so that it is synchronous with the rising edge of the output clock (FOUTPOSTDIV). Glitches cannot occur on any of the other outputs.
- 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 normal operating range for the VCO is described above in.
- 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.
- The feedback divider is not capable of dividing by all possible settings due to the use of a power-saving architecture. The following settings are valid for FBDIV:
  - DSMPD=1 (Integer Mode)
  - DSMPD=0 (Fractional Mode)
- The PD input places the PLL into the lowest power mode. In this case, all analog circuits are turned off and FREF will be "ignored". The FOUTPOSTDIV and FOUTVCO pins are forced to logic low (0V).
- The BYPASS pin controls FREF to be passed to the FOUTPOSTDIV when active high. However, the PLL continues to run as it normally would if bypass were low. This is a useful feature for PLL testing since the clock path can be verified without the PLL being required to work. Also, the effect that the PLL induced supply noise has on the output buffering can be evaluated. It is not recommended to switch between BYPASS mode and normal mode for regular chip operation since this may result in a glitch. Also, FOUTPOSTDIVPD should be set low if the PLL is to be used in BYPASS mode.

### 2.14.2.3 PLL Frequency Change And Lock Check

The PLL programming supports changed on-the-fly and the PLL will simply slew to the new frequency.

PLL lock state can be checked in CRU\_xPLL\_CON1[10] (x= D, G) register. The lock state is high when both original hardware PLL lock and PLL counter lock are high.

The max delay time is 500\*REFDIV/FREF.

PLL locking consists of three phases.

- Phase 1 is control voltage slewing. During this phase one of the clocks (reference or divide) is much faster than the other, and the PLL frequency adjusts almost continuously. When locking from power down, the divide clock is initially very slow and steadily increases frequency. It will take slightly longer for faster VCO settings when locking from power down, since the PLL must slew further.
- Phase 2 is small signal phase acquisition. During this phase, the internal up/down signals alternate semi-chaotically as the phase slowly adjusts until the two signals are aligned. The duration of this phase depends on the loop bandwidth and is faster with higher bandwidth. Bandwidth can be estimated as FREF / REFDIV / 20 for integer mode and FREF /REFDIV / 40 for fractional mode. The duration of small signal locking is about 1/Bandwidth.

- Phase 3 is the digital cycle count. After the last cycle slip is detected, an internal counter waits  $128 \text{ FREF} / \text{REFDIV}$  cycles before the lock signal goes high. This is frequently the dominant factor in lock time – especially for slower reference clock signals or large reference divide settings. This time can be calculated as  $128 * \text{REFDIV} / \text{FREF}$ .

### **2.14.3 Integer PLL Usage**

#### **2.14.3.1 PLL Frequency Configuration**

FBDIV, POSTDIV1, BYPASS can be configured by programming CRU\_xPLL\_CON0. DSMPD, REFDIV, POSTDIV2 can be configured by programming CRU\_xPLL\_CON1(x=A, C). DSMPD should always be set to 1 (CLKSSCG is power down), and REFDIV can only be 1 or 2.

$$\text{FOUTVCO} = (\text{FREF} / \text{REFDIV}) * \text{FBDIV}$$

$$\text{FOUTPOSTDIV} = \text{FOUTVCO} / (\text{POSTDIV1} * \text{POSTDIV2})$$

POSTDIV1=0, POSTDIV2=0 are unused.

We should make sure that  $\text{POSTDIV1} \geq \text{POSTDIV2}$ .

#### **2.14.3.2 PLL Frequency Change And Lock Check**

The PLL programming supports changed on-the-fly and the PLL will simply slew to the new frequency.

PLL lock state can be checked in CRU\_xPLL\_CON1[10] (x=A, C) register. The lock state is high when both original hardware PLL lock and PLL counter lock are high.

The max delay time is  $1500 * \text{REFDIV} / \text{FREF}$ .

### **2.14.4 Divider Usage**

CRU supports multi-dividers for different clock requirement.

- Divider free divider
- Fractional divider
- DivfreeDT50 divider(DT50)
- DivfreeNP5 divider(NP5)

#### **2.14.4.1 DivFree Divider Usage**

Using this divider,  $\text{freq\_out} = \text{freq\_src} / (n+1)$ .

#### **2.14.4.2 Fractional Divider Usage**

To get specific frequency, clocks of I2S, UART, MIPI and VICAP can be generated by fractional divider. Generally you should ensure that denominator is 20 times larger than numerator to generate precise clock frequency. So the fractional divider applies only to generate low frequency clock.

#### **2.14.4.3 DivfreeDT50 Divider Usage**

Some modules like EMMC, SDIO, SDMMC need clock of 50% duty cycle, divfreeDT50 can generate clock of 50% duty cycle even when divisor value is odd.

#### **2.14.4.4 DivFreeNP5 Divider Usage**

Some modules need special frequency can use this divider. Using this divider,  $\text{freq\_out} = \text{freq\_src} / (n+1.5)$ .

### **2.14.5 Global Software Reset**

Two global software resets are designed in the chip. These two software resets are self-de-asserted by hardware. Hold time of global software reset (glb\_srstn\_1, glb\_srstn\_2, wdt\_rstn, tsadc\_rstn) can be programmed up to 1ms.

- CRU\_GLB\_SRST\_FST\_VALUE[15:0] = 0xfd9 to assert the first global software reset glb\_srstn\_1
- CRU\_GLB\_SRST\_SND\_VALUE[15:0] = 0xea8 to assert the second global software reset glb\_srstn\_2
- glb\_srstn\_1 resets almost all logic except some registers just supporting hardware reset
- glb\_srstn\_2 resets almost all logic except GRFs and GPIOs

Reset for IP in PD\_PMU can be held if its reset\_hold\_enable in PMUGRF\_PMU\_SOC\_CON1 or PMUGRF\_PMU\_SOC\_CON2 is high even if glb\_srstn\_1 or glb\_srstn\_2 active.

### **2.14.6 SSCG Usage**

There are some scenes where SSCG should be enabled. One scene is in communication where a fixed frequency is required. Another scene is that the system requires a clock with

low long-term jitter. When SSCG is used, the PLL should be configured to fractional mode first for spread spectrum capability.

### **2.14.6.1 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:

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

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

- ssmod\_downspread = 1'b1, down spread mode is used. If ssmod\_spread = 5'd29, the maximum PLL frequency is the nominally programmed value  $F_{NOM}$ , and the minimum value is given by  $F_{NOM} * (1 - 0.029)$ .
- ssmod\_downspread = 1'b0, center spread mode is used. If ssmod\_spread = 5'd29, the maximum PLL frequency would be determined by  $F_{NOM} * (1 + 0.029)$  and the minimum frequency by  $F_{NOM} * (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 / (\text{Point number} * \text{REFDIV} * \text{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 * \text{REFDIV})$ .

When  $FREF=24MHz$  and  $\text{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 ssmod\_reset(CRU\_XPLL\_CON3[2])=1'b0

### **2.14.6.2 SSCG Use External Point Table**

In addition to the internal shape table, an external shape table can be used.

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\_SSCGTBL\_CON0~CRU\_SSCGTBL\_CON31.

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\_SSCGTBL\_CON0 ~ CRU\_SSCGTBL\_CON31)

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 is represented in the table by 8'b11111111, it is corresponded to minimum frequency.
- 0.5 is represented in the table by 8'b00111111.

- 0.5 is 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 equals 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 ssmod\_reset(CRU\_XPLL\_CON3[2])=1'b0

## 2.14.7 BIU Clock gating reliance

A part of biu clocks have a dependence on another biu clock in order to sharing the internal bus. When these clocks are in use, another biu clock must be opened, and cannot be gated. These clocks and the special clock on which they are relied are as following:

Table 2-3 BIU Clocks dependency

| Clocks which have dependency | The clock which can not be gated |
|------------------------------|----------------------------------|
| pclk_cpu_biu                 | hclk_cpu_biu<br>aclk_cpu_biu     |
| hclk_cpu_biu                 | aclk_cpu_biu                     |
| hclk_npu_biu                 | hclk_cpu_biu                     |
| pclk_npu_biu                 | hclk_npu_biu                     |
| hclk_vi_biu                  | hclk_cpu_biu                     |
| pclk_vi_biu                  | hclk_vi_biu                      |
| pclk_vi_rtc_biu              | hclk_vi_biu                      |
| pclk_ddr_biu                 | hclk_cpu_biu                     |
| hclk_peri_biu                | hclk_cpu_biu                     |
| pclk_peri_biu                | hclk_peri_biu                    |
| hclk_vo_biu                  | hclk_cpu_biu                     |
| pclk_vo_biu                  | hclk_vo_biu                      |
| aclk_vepu_cpm_biu            | aclk_vo_biu                      |
| hclk_vepu_biu                | hclk_cpu_biu                     |
| pclk_vepu_biu                | hclk_cpu_biu                     |
| hclk_pmu_biu                 | hclk_cpu_biu                     |
| pclk_pmu_biu                 | hclk_pmu_biu                     |
| pclk_cru_biu                 | hclk_cpu_biu                     |

## Chapter 3 System Debug

### 3.1 Overview

The chip uses the DAPLITE Technology to support real-time debug.

#### 3.1.1 Features

- Invasive debug with core halted
- SW-DP

#### 3.1.2 Debug Components Address Map

The following table shows the debug components address in memory map:

| Module  | Base Address |
|---------|--------------|
| DAP_ROM | 0xff200000   |

### 3.2 Block Diagram



Fig. 3-1 Debug system structure

### 3.3 Function Description

#### 3.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.

### 3.4 Register Description

Please refer to the document CoreSight\_DAPLite\_TRM.pdf for the debug detail description.

### 3.5 Interface Description

#### 3.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 connect either a Serial Wire Debug(SWJ) to JTAG probe to a target.



Fig. 3-2 DAP SWJ interface

### 3.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. 3-3 SW-DP acknowledgement timing

Table 3-1 DAP-Lite Interface Description

| Module pin  | Direction | Pad name                                                                   | IOMUX                                       |
|-------------|-----------|----------------------------------------------------------------------------|---------------------------------------------|
| jtag_tck_m0 | I         | HPMCU_JTAG_TCK_M1/A7_JTAG_TCK_M0/UART5_RX_M0/SDMMC0_D2/GPIO3_A7_u          | VCCIO4_IOC_GPIO3A_IOMUX_SEL_H[14:12] = 3'h3 |
| jtag_tm_sm0 | I/O       | HPMCU_JTAG_TMS_M1/A7_JTAG_TMS_M0/UART5_TX_M0/SDMMC0_D3/GPIO3_A6_u          | VCCIO4_IOC_GPIO3A_IOMUX_SEL_H[11:8] = 3'h3  |
| jtag_tck_m1 | I         | LPMCU_JTAG_TCK_M0/HPMCU_JTAG_TC_K_M0/UART2_TX_M1/A7_JTAG_TCK_M1/GPIO1_B2_d | VCCIO1_IOC_GPIO1B_IOMUX_SEL_L[11:8] = 3'h1  |
| jtag_tm_sm1 | I/O       | LPMCU_JTAG_TMS_M0/HPMCU_JTAG_TS_M0/UART2_RX_M1/A7_JTAG_TMS_M1/GPIO1_B3_u   | VCCIO1_IOC_GPIO1B_IOMUX_SEL_L[14:12] = 3'h1 |

By default, jtag\_tckm0 and jtag\_tmsm0 are forced to connect to corresponding io pad, we don't need to set IOMUX again.

## Chapter 4 General Register Files (GRF)

### 4.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.

### 4.2 Function Description

The function of general register file is:

- GPIO IOMUX control
- GPIO PAD control
- Common system control
- Record the system state

Table 4-1 GRF Address Mapping Table

| Name      | Address Base |
|-----------|--------------|
| PERI_GRF  | 0xFF000000   |
| VENC_GRF  | 0xFF010000   |
| NPU_GRF   | 0xFF018000   |
| PMU_GRF   | 0xFF020000   |
| DDR_GRF   | 0xFF030000   |
| CORE_GRF  | 0xFF040000   |
| VI_GRF    | 0xFF050000   |
| VO_GRF    | 0xFF060000   |
| GPIO0_IOC | 0xFF388000   |
| GPIO1_IOC | 0xFF538000   |
| GPIO2_IOC | 0xFF548000   |
| GPIO3_IOC | 0xFF558000   |
| GPIO4_IOC | 0xFF568000   |

### 4.3 PERI\_GRF Register Description

#### 4.3.1 Registers Summary

| Name                     | Offset | Size | Reset Value | Description                          |
|--------------------------|--------|------|-------------|--------------------------------------|
| PERI_GRF_PERI_CON0       | 0x0000 | W    | 0x00000000  | Peripheral system control register 0 |
| PERI_GRF_PERI_CON1       | 0x0004 | W    | 0x00002000  | Peripheral system control register 1 |
| PERI_GRF_PERI_STATUS     | 0x0010 | W    | 0x00000000  | Peripheral system status register    |
| PERI_GRF_EMMC_CON0       | 0x0020 | W    | 0x00000004  | EMMC control register 0              |
| PERI_GRF_EMMC_CON1       | 0x0024 | W    | 0x00000000  | EMMC control register 1              |
| PERI_GRF_USBOTG_CON0     | 0x0030 | W    | 0x00002000  | USB OTG control register 0           |
| PERI_GRF_USBOTG_CON1     | 0x0034 | W    | 0x00000100  | USB OTG control register 1           |
| PERI_GRF_USBOTG_STAT_US0 | 0x0040 | W    | 0x00000000  | USB OTG status register 0            |
| PERI_GRF_USBOTG_STAT_US1 | 0x0044 | W    | 0x00000000  | USB OTG status register 1            |
| PERI_GRF_USBOTG_STAT_US2 | 0x0048 | W    | 0x00000000  | USB OTG status register 2            |
| PERI_GRF_USBPHY_CON0     | 0x0050 | W    | 0x00000C52  | USB PHY control register 0           |
| PERI_GRF_USBPHY_CON1     | 0x0054 | W    | 0x00000080  | USB PHY control register 1           |
| PERI_GRF_USBPHY_CON2     | 0x0058 | W    | 0x00000000  | USB PHY control register 2           |

| Name                                    | Offset | Size | Reset Value | Description                               |
|-----------------------------------------|--------|------|-------------|-------------------------------------------|
| PERI_GRF_USBPHY_CON3                    | 0x005C | W    | 0x00000000  | USB PHY control register 3                |
| PERI_GRF_USBPHY_STAT_US                 | 0x0060 | W    | 0x00000000  | USB PHY status register                   |
| PERI_GRF_SARADC_CON                     | 0x0070 | W    | 0x00000000  | SARADC control register                   |
| PERI_GRF_PERI_MEM_CO_N                  | 0x0080 | W    | 0x00001015  | Peripheral system memory control register |
| PERI_GRF_BIU_CON0                       | 0x0090 | W    | 0x00000000  | BIU control register 0                    |
| PERI_GRF_BIU_CON1                       | 0x0094 | W    | 0x00000000  | BIU control register 1                    |
| PERI_GRF_BIU_STATUS0                    | 0x0098 | W    | 0x00000000  | BIU status register 0                     |
| PERI_GRF_BIU_STATUS1                    | 0x009C | W    | 0x00000000  | BIU status register 1                     |
| PERI_GRF_USBOTG_SIG_DETECT_CON          | 0x0100 | W    | 0x00000000  | USB OTG detection control register        |
| PERI_GRF_USBOTG_SIG_DETECT_STATUS       | 0x0104 | W    | 0x00000000  | USB OTG detection status register         |
| PERI_GRF_USBOTG_SIG_DETECT_CLR          | 0x0108 | W    | 0x00000000  | USB OTG detection clear register          |
| PERI_GRF_USBOTG_LINE_STATE_DETECT_CON   | 0x0110 | W    | 0x00030100  | USB OTG linestate control register        |
| PERI_GRF_USBOTG_DISC_CONNECT_DETECT_CON | 0x0114 | W    | 0x00030100  | USB OTG disconnect control register       |
| PERI_GRF_USBOTG_BVAL_ID_DETECT_CON      | 0x0118 | W    | 0x00030100  | USB OTG bvalid control register           |
| PERI_GRF_USBOTG_ID_DETECT_CON           | 0x011C | W    | 0x00030100  | USB OTG id control register               |

Notes: **Size:** **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 4.3.2 Detail Registers Description

#### PERI\_GRF\_PERI\_CON0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                        |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12 | RO   | 0x0         | reserved                                                                                                                           |
| 11    | RW   | 0x0         | uart5_cts_inv<br>Polarity selection for uart5_cts.<br>1'b0: Low active<br>1'b1: High active                                        |
| 10    | RW   | 0x0         | uart5_rts_inv<br>Polarity selection for uart5_rts.<br>1'b0: Low active<br>1'b1: High active                                        |
| 9     | RW   | 0x0         | uart4_cts_inv<br>Polarity selection for uart4_cts.<br>1'b0: Low active<br>1'b1: High active                                        |
| 8     | RW   | 0x0         | uart4_rts_inv<br>Polarity selection for uart4_rts.<br>1'b0: Low active<br>1'b1: High active                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | uart3_cts_inv<br>Polarity selection for uart3_cts.<br>1'b0: Low active<br>1'b1: High active |
| 6          | RW          | 0x0                | uart3_rts_inv<br>Polarity selection for uart3_rts.<br>1'b0: Low active<br>1'b1: High active |
| 5          | RW          | 0x0                | uart2_cts_inv<br>Polarity selection for uart2_cts.<br>1'b0: Low active<br>1'b1: High active |
| 4          | RW          | 0x0                | uart2_rts_inv<br>Polarity selection for uart2_rts.<br>1'b0: Low active<br>1'b1: High active |
| 3          | RW          | 0x0                | uart1_cts_inv<br>Polarity selection for uart1_cts.<br>1'b0: Low active<br>1'b1: High active |
| 2          | RW          | 0x0                | uart1_rts_inv<br>Polarity selection for uart1_rts.<br>1'b0: Low active<br>1'b1: High active |
| 1          | RW          | 0x0                | uart0_cts_inv<br>Polarity selection for uart0_cts.<br>1'b0: Low active<br>1'b1: High active |
| 0          | RW          | 0x0                | uart0_rts_inv<br>Polarity selection for uart0_rts.<br>1'b0: Low active<br>1'b1: High active |

**PERI GRF PERI CON1**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | wdt_ns_pause_en<br>No-secure WDT pause enable.<br>1'b0: Disable<br>1'b1: Enable                                                    |
| 13         | RW          | 0x1                | emmc_ram_clkgat_disable<br>EMMC ram clock gating control.<br>1'b0: Clock gating enable<br>1'b1: Clock gating disable               |
| 12         | RW          | 0x0                | trng_ns_RST_SYNC_bypass<br>Enable No-secure TRNG reset synchronization.<br>1'b0: Disable<br>1'b1: Enable                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | trng_ns_ctrl_reseed<br>Enable No-secure TRNG reseed operation.<br>1'b0: Disable<br>1'b1: Enable<br>When it is asserted, the No-secure TRNG responds by stopping any reseed operation that is currently underway and initiating a new reseed operation. |
| 10         | RW          | 0x0                | trng_ns_ctrl_zeroize<br>Enable No-secure TRNG zeroize operation.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                      |
| 9          | RW          | 0x0                | wdt_ns_glb_reset_en<br>No-secure WDT global reset enable.<br>1'b0: Disable. No-secure WDT reset output cannot reset SoC system.<br>1'b1: Enable. No-secure WDT reset output will reset SoC system.                                                     |
| 8          | RW          | 0x0                | dsm_ena<br>DSM enable.<br>1'b0: Disable<br>1'b1: Enable. Audio controller works with DSM.                                                                                                                                                              |
| 7          | RW          | 0x0                | acodec_ad2da_loop<br>ACODEC ad2da_loop enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                        |
| 6          | RW          | 0x0                | acodec_ena<br>ACODEC enable.<br>1'b0: Disable. Audio controller works with external ACODEC through PAD.<br>1'b1: Enable. Audio controller works with internal ACODEC.                                                                                  |
| 5          | RW          | 0x0                | i2s_mclk_oe_n<br>i2s_mclk output enable.<br>1'b0: Output disable<br>1'b1: Output enable                                                                                                                                                                |
| 4          | RW          | 0x0                | i2s_sdo3_oe_n<br>i2s_sdo3 output enable.<br>1'b0: Output disable<br>1'b1: Output enable                                                                                                                                                                |
| 3          | RW          | 0x0                | i2s_sdo2_oe_n<br>i2s_sdo2 output enable.<br>1'b0: Output disable<br>1'b1: Output enable                                                                                                                                                                |
| 2          | RW          | 0x0                | i2s_sdo1_oe_n<br>i2s_sdo1 output enable.<br>1'b0: Output disable<br>1'b1: Output enable                                                                                                                                                                |
| 1          | RW          | 0x0                | audio_tx_rx_sel<br>Audio transmit and receive selection.<br>1'b0: Transmit is selected<br>1'b1: Receive is selected                                                                                                                                    |
| 0          | RW          | 0x0                | i2s_sai_sel<br>Audio controller selection.<br>1'b0: I2S is selected as audio controller<br>1'b1: SAI selected as audio controller                                                                                                                      |

**PERI GRF PERI STATUS**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                                                                     |
| 21         | RO          | 0x0                | acodec_dac_master_en<br>ACODEC DAC master enable status.<br>1'b0: Inactive<br>1'b1: Active                   |
| 20         | RO          | 0x0                | acodec_adc_master_en<br>ACODEC ADC master enable status.<br>1'b0: Inactive<br>1'b1: Active                   |
| 19         | RO          | 0x0                | trng_s_ctrl_rand_vld<br>Secure TRNG serial random bit valid output.<br>1'b0: Inactive<br>1'b1: Active        |
| 18         | RO          | 0x0                | trng_s_ctrl_rand_bit<br>Secure TRNG serial random bit output.<br>1'b0: Inactive<br>1'b1: Active              |
| 17         | RO          | 0x0                | trng_s_ctrl_seeded<br>Secure TRNG reseeding/seeding completion output.<br>1'b0: Inactive<br>1'b1: Active     |
| 16         | RO          | 0x0                | trng_s_ctrl_reseeding<br>Secure TRNG reseeding activity output.<br>1'b0: Inactive<br>1'b1: Active            |
| 15         | RO          | 0x0                | trng_s_ctrl_reminder<br>Secure TRNG reseed reminder output.<br>1'b0: Inactive<br>1'b1: Active                |
| 14         | RO          | 0x0                | trng_s_ctrl_secure<br>Secure TRNG secure mode output.<br>1'b0: Inactive<br>1'b1: Active                      |
| 13         | RO          | 0x0                | trng_ns_ctrl_rand_vld<br>No-secure TRNG serial random bit valid output.<br>1'b0: Inactive<br>1'b1: Active    |
| 12         | RO          | 0x0                | trng_ns_ctrl_rand_bit<br>No-secure TRNG serial random bit output.<br>1'b0: Inactive<br>1'b1: Active          |
| 11         | RO          | 0x0                | trng_ns_ctrl_seeded<br>No-secure TRNG reseeding/seeding completion output.<br>1'b0: Inactive<br>1'b1: Active |
| 10         | RO          | 0x0                | trng_ns_ctrl_reseeding<br>No-secure TRNG reseeding activity output.<br>1'b0: Inactive<br>1'b1: Active        |
| 9          | RO          | 0x0                | trng_ns_ctrl_reminder<br>No-secure TRNG reseed reminder output.<br>1'b0: Inactive<br>1'b1: Active            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 8          | RO          | 0x0                | trng_ns_ctrl_secure<br>No-secure TRNG secure mode output.<br>1'b0: Inactive<br>1'b1: Active |
| 7          | RO          | 0x0                | stimer1_en_status<br>Secure TIMER1 active status.<br>1'b0: Inactive<br>1'b1: Active         |
| 6          | RO          | 0x0                | stimer0_en_status<br>Secure TIMER0 active status.<br>1'b0: Inactive<br>1'b1: Active         |
| 5          | RO          | 0x0                | timer5_en_status<br>TIMER5 active status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 4          | RO          | 0x0                | timer4_en_status<br>TIMER4 active status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 3          | RO          | 0x0                | timer3_en_status<br>TIMER3 active status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 2          | RO          | 0x0                | timer2_en_status<br>TIMER2 active status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 1          | RO          | 0x0                | timer1_en_status<br>TIMER1 active status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 0          | RO          | 0x0                | timer0_en_status<br>TIMER0 active status.<br>1'b0: Inactive<br>1'b1: Active                 |

**PERI GRF EMMC CON0**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                             |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                       |
| 12         | RW          | 0x0                | test_clkout_0_sel<br>EMMC test clock 0 output selection.<br>1'b0: Drive clock output to test clock 0<br>1'b1: Function clock output to test clock 0                                                                            |
| 11         | RW          | 0x0                | drv_sel<br>Selection for drive clock.<br>1'b0: Select clock delayed by phase shift<br>1'b1: Select clock delayed by phase shift and delay line<br>It can be modified when init_state=1 and should be stable when init_state=0. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:3       | RW          | 0x00               | drv_delaynum<br>Delay element number configuration for drive clock.<br>It can be modified when init_state=1 and should be stable when init_state=0.                                                         |
| 2:1        | RW          | 0x2                | drv_degree<br>Phase selection for drive clock.<br>2'h0: 0-degree<br>2'h1: 90-degree<br>2'h2: 180-degree<br>2'h3: 270-degree<br>It can be modified when init_state=1 and should be stable when init_state=0. |
| 0          | RW          | 0x0                | init_state<br>Enable initialization for clock source.<br>1'b0: Disable<br>1'b1: Enable<br>When init_state=1, the host clocks including drive clock and sample clock are inactive.                           |

**PERI GRF EMMC CON1**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                 |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                           |
| 12         | RW          | 0x0                | test_clkout_1_sel<br>EMMC test clock 1 output selection.<br>1'b0: Sample clock output to test clock 1<br>1'b1: Function clock output to test clock 1                                                                               |
| 11         | RW          | 0x0                | sample_sel<br>Selection for sample clock.<br>1'b0: Select clock delayed by phase shift<br>1'b1: Select clock delayed by phase shift and delay line<br>It can be modified when init_state=1 and should be stable when init_state=0. |
| 10:3       | RW          | 0x00               | sample_delaynum<br>Delay element number configuration for sample clock.<br>It can be modified when init_state=1 and should be stable when init_state=0.                                                                            |
| 2:1        | RW          | 0x0                | sample_degree<br>Phase selection for sample clock.<br>2'h0: 0-degree<br>2'h1: 90-degree<br>2'h2: 180-degree<br>2'h3: 270-degree<br>It can be modified when init_state=1 and should be stable when init_state=0.                    |
| 0          | RO          | 0x0                | reserved                                                                                                                                                                                                                           |

**PERI GRF USBOTG CON0**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15         | RW          | 0x0                | usb0tg_host_u2_port_disable<br>USB2.0 port disable control.<br>1'b0: Port enabled<br>1'b1: Port disabled, stops reporting connect/disconnect events the port and keeps the port in disabled state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14         | RW          | 0x0                | usb0tg_host_port_power_control_present<br>This indicates whether the host controller implementation includes port power control.<br>1'b0: Indicates that the port does not have port power switches<br>1'b1: Indicates that the port has port power switches                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13:8       | RW          | 0x20               | usb0tg_fadj_30mhz_reg<br>USB OTG fadj_30mhz_reg configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6          | RW          | 0x0                | usb0tg_hub_port_perm_attach<br>Indicates if the device attached to a downstream port is permanently attached or not.<br>1'b0: Not permanently attached<br>1'b1: Permanently attached                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4          | RW          | 0x0                | usb0tg_hub_port_overcurrent<br>Overcurrent indication of the root-hub ports.<br>1'b0: No overcurrent<br>1'b1: overcurrent                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:0        | RW          | 0x0                | usb0tg_bus_filter_bypass<br>The function of each bit is:<br>usb0tg_bus_filter_bypass[3]: Bypass the filter for utmiotg_iddig<br>usb0tg_bus_filter_bypass[2]: Bypass the filters for utmisrp_bvalid and utmisrp_sessend<br>usb0tg_bus_filter_bypass[1]: Bypass the filter for pipe3_PowerPresent all U3 ports<br>usb0tg_bus_filter_bypass[0]: Bypass the filter for utmiotg_vbusvalid all U2 ports<br>In non-OTG Host-only mode, internal bus filters are not needed.<br>Values:<br>1'b0: Bus filter(s) enabled<br>1'b1: Bus filter(s) disabled<br>It is expected that this signal is set or reset at power-on reset and is not changed during the normal operation of the core. |

**PERI GRF USBOTG CON1**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11:8       | RW          | 0x1                | usb0tg_host_num_u2_port<br>xHCI host USB2 Port number, default as 1.                                                               |
| 7:6        | RO          | 0x0                | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | usb0tg_host_legacy_smi_bar<br>Use this register to support SMI on BAR defined in xHCI spec.<br>SW must set this register, then clear this register to indicate Base Address Register written.            |
| 4          | RW          | 0x0                | usb0tg_host_legacy_smi_pci_cmd<br>Use this register to support SMI on PCI Command defined in xHCI spec.<br>SW must set this register, then clear this register to indicate PCI command register written. |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                 |
| 0          | RW          | 0x0                | usb0tg_pme_en<br>Enable the core to assert pme_generation.<br>1'b0: Disable<br>1'b1: Enable                                                                                                              |

**PERI GRF USBOTG STATUS0**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | usb0tg_logic_analyzer_trace_31_0<br>usb0tg_logic_analyzer_trace bit[31:0] status |

**PERI GRF USBOTG STATUS1**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | usb0tg_logic_analyzer_trace_63_32<br>usb0tg_logic_analyzer_trace bit[63:32] status |

**PERI GRF USBOTG STATUS2**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                              |
| 11:0       | RO          | 0x000              | usb0tg_host_current_belt<br>usb0tg_host_current_belt bit[11:0] status |

**PERI GRF USBPHY CON0**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                        |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                  |
| 13         | RW          | 0x0                | usb0tg_utmi_dischrgvbus<br>usb0tg_utmi_dischrgvbus configuration.                                                                                         |
| 12         | RW          | 0x0                | usb0tg_utmi_chrgvbus<br>usb0tg_utmi_chrgvbus configuration.                                                                                               |
| 11         | RW          | 0x1                | usb0tg_utmi_idpullup<br>usb0tg_utmi_idpullup configuration.                                                                                               |
| 10         | RW          | 0x1                | usb0tg_utmi_iddig<br>Software configuration for usb0tg_utmi_iddig.                                                                                        |
| 9          | RW          | 0x0                | usb0tg_utmi_iddig_sel<br>usb0tg_utmi_iddig selection.<br>1'b0: usb0tg_utmi_iddig comes from USB PHY<br>1'b1: usb0tg_utmi_iddig comes from USBPHY_CON0[10] |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | usbotg_utmi_dmpulldown<br>Software configuration for usbotg_utmi_dmpulldown when usbphy_sw_en is high. |
| 7          | RW          | 0x0                | usbotg_utmi_dppulldown<br>Software configuration for usbotg_utmi_dppulldown when usbphy_sw_en is high. |
| 6          | RW          | 0x1                | usbotg_utmi_termselect<br>Software configuration for usbotg_utmi_termselect when usbphy_sw_en is high. |
| 5:4        | RW          | 0x1                | usbotg_utmi_xcvrselect<br>Software configuration for usbotg_utmi_xcvrselect when usbphy_sw_en is high. |
| 3:2        | RW          | 0x0                | usbotg_utmi_opmode<br>Software configuration for usbotg_utmi_opmode when usbphy_sw_en is high.         |
| 1          | RW          | 0x1                | usbotg_utmi_suspend_n<br>Software configuration for usbotg_utmi_suspend_n when usbphy_sw_en is high.   |
| 0          | RW          | 0x0                | usbphy_sw_en<br>USB PHY software configuration enable.<br>1'b0: Disable<br>1'b1: Enable                |

**PERI\_GRF\_USBPHY\_CON1**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                         |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                   |
| 11         | RW          | 0x0                | usbotg_utmi_drvvbus<br>Software configuration for usbotg_utmi_drvvbus.                                                                                                     |
| 10         | RW          | 0x0                | usbotg_utmi_drvvbus_sel<br>usbotg_utmi_drvvbus selection.<br>1'b0: usbotg_utmi_drvvbus comes from USB PHY<br>1'b1: usbotg_utmi_drvvbus comes from PERI_GRF_USBPHY_CON1[11] |
| 9          | RW          | 0x0                | usbotg_utmi_fs_se0<br>Software configuration for usbotg_utmi_fs_se0.                                                                                                       |
| 8          | RW          | 0x0                | usbotg_utmi_fs_data<br>Software configuration for usbotg_utmi_fs_data.                                                                                                     |
| 7          | RW          | 0x1                | usbotg_utmi_fs_oe<br>Software configuration for usbotg_utmi_fs_oe.                                                                                                         |
| 6          | RW          | 0x0                | usbotg_utmi_fs_xver_own<br>Software configuration for usbotg_utmi_fs_xver_own.                                                                                             |
| 5:3        | RO          | 0x0                | reserved                                                                                                                                                                   |
| 2          | RW          | 0x0                | usbotg_utmi_suspend_n<br>Software configuration for usbotg_utmi_suspend_n.                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | usbotg_utmi_suspend_n_sel<br>usbotg_utmi_suspend_n selection.<br>2'b00: ~usbotg_utmi_suspend_com_n &<br>~usbotg_utmi_l1_suspend_com_n<br>2'b01: PERI_GRF_USBPHY_CON1[2]<br>2'b10: ~usbotg_utmi_suspend_com_n &<br>~usbotg_utmi_l1_suspend_com_n<br>2'b11: ~usbotg_utmi_suspend_n & ~usbotg_utmi_l1_suspend_n |

**PERI\_GRF\_USBPHY\_CON2**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                        |
| 15         | RW          | 0x0                | usbotg_utmi_bvalid_sel<br>usbotg_utmi_bvalid selection.<br>1'b0: usbotg_utmi_bvalid comes from USB PHY<br>1'b1: usbotg_utmi_bvalid comes from<br>PERI_GRF_USBPHY_CON2[14] |
| 14         | RW          | 0x0                | usbotg_utmi_bvalid<br>Software configuration for usbotg_utmi_bvalid.                                                                                                      |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                  |
| 12         | RW          | 0x0                | usbphy_vdm_src_en<br>Software configuration for usbphy_vdm_src_en.                                                                                                        |
| 11         | RW          | 0x0                | usbphy_vdp_src_en<br>Software configuration for usbphy_vdp_src_en.                                                                                                        |
| 10         | RW          | 0x0                | usbphy_rdm_pdwn_en<br>Software configuration for usbphy_rdm_pdwn_en.                                                                                                      |
| 9          | RW          | 0x0                | usbphy_idp_src_en<br>Software configuration for usbphy_idp_src_en.                                                                                                        |
| 8          | RW          | 0x0                | usbphy_idm_sink_en<br>Software configuration for usbphy_idm_sink_en.                                                                                                      |
| 7          | RW          | 0x0                | usbphy_idp_sink_en<br>Software configuration for usbphy_idp_sink_en.                                                                                                      |
| 6:0        | RO          | 0x00               | reserved                                                                                                                                                                  |

**PERI\_GRF\_USBPHY\_CON3**

Address: Operational Base + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:10      | RO          | 0x00               | reserved                                                                                                                           |
| 9:8        | RW          | 0x0                | usbphy_bc_weakpulldown_tune<br>Software configuration for usbphy_bc_weakpulldown_tune.                                             |
| 7:6        | RW          | 0x0                | usbphy_bc_weakpullup_tune<br>Software configuration for usbphy_bc_weakpullup_tune.                                                 |
| 5          | RW          | 0x0                | usbphy_bc_weakpulldown_en<br>Software configuration for usbphy_bc_weakpulldown_en.                                                 |
| 4          | RW          | 0x0                | usbphy_bc_weakpullup_en<br>Software configuration for usbphy_bc_weakpullup_en.                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | usbphy_force_dcp_det<br>Software configuration for usbphy_force_dcp_det.         |
| 2          | RW          | 0x0                | usbphy_force_cp_det<br>Software configuration for usbphy_force_cp_det.           |
| 1          | RW          | 0x0                | usbphy_force_dp_attached<br>Software configuration for usbphy_force_dp_attached. |
| 0          | RW          | 0x0                | usbphy_charge_det_byp<br>Software configuration for usbphy_charge_det_byp.       |

**PERI GRF USBPHY STATUS**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                      |
| 16         | RO          | 0x0                | usbphy_dp_floatdet<br>usbphy_dp_floatdet status, high active.                 |
| 15         | RO          | 0x0                | usbphy_dm_floatdet<br>usbphy_dm_floatdet status, high active.                 |
| 14         | RO          | 0x0                | usbphy_dp_attached<br>usbphy_dp_attached status, high active.                 |
| 13         | RO          | 0x0                | usbphy_cp_detected<br>usbphy_cp_detected status, high active.                 |
| 12         | RO          | 0x0                | usbphy_dcp_detected<br>usbphy_dcp_detected status, high active.               |
| 11         | RO          | 0x0                | usbotg_phy_ls_fs_rcv<br>usbotg_phy_ls_fs_rcv status, high active.             |
| 10         | RO          | 0x0                | usbotg_utmi_avalid<br>usbotg_utmi_avalid status, high active.                 |
| 9          | RO          | 0x0                | usbotg_utmi_bvalid<br>usbotg_utmi_bvalid status, high active.                 |
| 8          | RO          | 0x0                | usbotg_utmi_fs_xver_own<br>usbotg_utmi_fs_xver_own status, high active.       |
| 7          | RO          | 0x0                | usbotg_utmi_hostdisconnect<br>usbotg_utmi_hostdisconnect status, high active. |
| 6          | RO          | 0x0                | usbotg_utmi_iddig<br>usbotg_utmi_iddig status, high active.                   |
| 5:4        | RO          | 0x0                | usbotg_utmi_linestate<br>usbotg_utmi_linestate status, high active.           |
| 3          | RO          | 0x0                | usbotg_utmi_sessend<br>usbotg_utmi_sessend status, high active.               |
| 2          | RO          | 0x0                | usbotg_utmi_vbusvalid<br>usbotg_utmi_vbusvalid status, high active.           |
| 1          | RO          | 0x0                | usbotg_utmi_vmi<br>usbotg_utmi_vmi status, high active.                       |
| 0          | RO          | 0x0                | usbotg_utmi_vpi<br>usbotg_utmi_vpi status, high active.                       |

**PERI GRF SARADC CON**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:0       | RW          | 0x0000             | saradc_ana_reg<br>SARADC ana_reg configuration                                                                                     |

**PERI\_GRF\_PERI\_MEM\_CON**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RW          | 0x1                | peri_mem_cfg_uhdspra<br>[1:0]: RTSEL<br>[3:2]: WTSEL                                                                               |
| 11:6       | RW          | 0x00               | peri_mem_cfg_uhddpra<br>[1:0]: RTSEL<br>[3:2]: WTSEL<br>[5:4]: PTSEL                                                               |
| 5:0        | RW          | 0x15               | peri_mem_cfg_rom<br>[1:0]: RTSEL<br>[3:2]: PTSEL<br>[5:4]: TRB                                                                     |

**PERI\_GRF\_BIU\_CONO**

Address: Operational Base + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                  |
| 15         | RW          | 0x0                | vo_to_vepu_stall<br>Response type when BIU_VO or BIU_VEPU in idle state and VO access VEPU.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted    |
| 14         | RW          | 0x0                | vi_to_peri_stall<br>Response type when BIU_VI or BIU_PERI in idle state and VI access PERI.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted    |
| 13         | RW          | 0x0                | vepu_to_cru_stall<br>Response type when BIU_VEPU or BIU_CRU in idle state and VEPU access CRU.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |
| 12         | RW          | 0x0                | vepu_to_ddr_stall<br>Response type when BIU_VEPU or BIU_DDR in idle state and VEPU access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |
| 11         | RW          | 0x0                | shrm_to_npu_stall<br>Response type when BIU_SHRM or BIU_NPU in idle state and SHRM access NPU.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |
| 10         | RW          | 0x0                | peri_to_ddr_stall<br>Response type when BIU_PERI or BIU_DDR in idle state and PERI access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | npu_to_vepu_stall<br>Response type when BIU_NPU or BIU_VEPU in idle state and NPU access VEPU.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted          |
| 8          | RW          | 0x0                | cpu_to_ddr_reg_stall<br>Response type when BIU_CPU or BIU_DDR_REG in idle state and CPU access DDR_REG.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |
| 7          | RW          | 0x0                | npu_to_ddr_stall<br>Response type when BIU_NPU or BIU_DDR in idle state and NPU access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted             |
| 6          | RW          | 0x0                | ddr_to_shrm_stall<br>Response type when BIU_SHRM or BIU_DDR in idle state and DDR access SHRM.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted          |
| 5          | RW          | 0x0                | ddr_to_peri_stall<br>Response type when BIU_DDR or BIU_PERI in idle state and DDR access PERI.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted          |
| 4          | RW          | 0x0                | cru_to_pmu_stall<br>Response type when BIU_CRU or BIU_PMU in idle state and CRU access PMU.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted             |
| 3          | RW          | 0x0                | cpu_to_vi_stall<br>Response type when BIU_CPU or BIU_VI in idle state and CPU access VI.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted                |
| 2          | RW          | 0x0                | cpu_to_vo_stall<br>Response type when BIU_CPU or BIU_VO in idle state and CPU access VO.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted                |
| 1          | RW          | 0x0                | cpu_to_npu_stall<br>Response type when BIU_CPU or BIU_NPU in idle state and CPU access NPU.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted             |
| 0          | RW          | 0x0                | cpu_to_ddr_stall<br>Response type when BIU_CPU or BIU_DDR in idle state and CPU access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted             |

**PERI GRF BIU CON1**

Address: Operational Base + offset (0x0094)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                     |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                              |
| 15:4  | RO   | 0x000       | reserved                                                                                                                                                                                                                                        |
| 3     | RW   | 0x0         | cpu_to_npu_srv_stall<br>Response type when BIU_CPU or BIU_NPU in idle state and CPU access NPU_SRV.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted                                        |
| 2     | RW   | 0x0         | dma_to_other_slv_stall<br>Response type when DMA access other slave.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted                                                                       |
| 1     | RW   | 0x0         | veppu_vepu_stall<br>Response type when BIU_VEPU_PP or BIU_VEPU in idle state and VEPUPP_VEPUP in idle state and VEPUPP_VEPUP access VEPUP.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted |
| 0     | RW   | 0x0         | venc_to_vepu_stall<br>Response type when BIU_VENC or BIU_VEPUP in idle state and VENC access VEPUP.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the NIU idle state is de-asserted                                        |

**PERI GRF BIU STATUS0**

Address: Operational Base + offset (0x0098)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 18:0  | RO   | 0x000000    | active_status<br>BIU access active status, high active.<br>[ 0 ]: cpu_to_ddr_active<br>[ 1 ]: cpu_to_npu_active<br>[ 2 ]: cpu_to_vo_active<br>[ 3 ]: cpu_to_vi_active<br>[ 4 ]: cru_to_pmu_active<br>[ 5 ]: ddr_to_peri_active<br>[ 6 ]: ddr_to_shrm_active<br>[ 7 ]: npu_to_ddr_active<br>[ 8 ]: cpu_to_ddr_reg_active<br>[ 9 ]: npu_to_vepu_active<br>[10]: peri_to_ddr_active<br>[11]: shrm_to_npu_active<br>[12]: vepu_to_ddr_active<br>[13]: vepu_to_cru_active<br>[14]: vi_to_peri_active<br>[15]: vo_to_vepu_active<br>[16]: venc_to_vepu_active<br>[17]: veppu_vepu_active<br>[18]: dma_to_other_slv_active |

**PERI GRF BIU STATUS1**

Address: Operational Base + offset (0x009C)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:16 | RO   | 0x0000      | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 15         | RO          | 0x0                | decom_nopendingtrans<br>No pending transfer status for DECOM.<br>1'b0: Inactive<br>1'b1: Active     |
| 14         | RO          | 0x0                | usb0tg_nopendingtrans<br>No pending transfer status for USBOTG.<br>1'b0: Inactive<br>1'b1: Active   |
| 13         | RO          | 0x0                | dmac_nopendingtrans<br>No pending transfer status for DMAC.<br>1'b0: Inactive<br>1'b1: Active       |
| 12         | RO          | 0x0                | crypto_nopendingtrans<br>No pending transfer status for CRYPTO.<br>1'b0: Inactive<br>1'b1: Active   |
| 11         | RO          | 0x0                | ive_wr_nopendingtrans<br>No pending transfer status for IVE_WR.<br>1'b0: Inactive<br>1'b1: Active   |
| 10         | RO          | 0x0                | ive_rd_nopendingtrans<br>No pending transfer status for IVE_RD.<br>1'b0: Inactive<br>1'b1: Active   |
| 9          | RO          | 0x0                | vop_nopendingtrans<br>No pending transfer status for VOP.<br>1'b0: Inactive<br>1'b1: Active         |
| 8          | RO          | 0x0                | vicap_nopendingtrans<br>No pending transfer status for VICAP.<br>1'b0: Inactive<br>1'b1: Active     |
| 7          | RO          | 0x0                | vepu_pp_nopendingtrans<br>No pending transfer status for VEPU_PP.<br>1'b0: Inactive<br>1'b1: Active |
| 6          | RO          | 0x0                | venc_nopendingtrans<br>No pending transfer status for VENC.<br>1'b0: Inactive<br>1'b1: Active       |
| 5          | RO          | 0x0                | rga_wr_nopendingtrans<br>No pending transfer status for RGA_WR.<br>1'b0: Inactive<br>1'b1: Active   |
| 4          | RO          | 0x0                | rga_rd_nopendingtrans<br>No pending transfer status for RGA_RD.<br>1'b0: Inactive<br>1'b1: Active   |
| 3          | RO          | 0x0                | npu_nopendingtrans<br>No pending transfer status for NPU.<br>1'b0: Inactive<br>1'b1: Active         |
| 2          | RO          | 0x0                | mac_nopendingtrans<br>No pending transfer status for GMAC.<br>1'b0: Inactive<br>1'b1: Active        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | isp_nopendingtrans<br>No pending transfer status for ISP.<br>1'b0: Inactive<br>1'b1: Active |
| 0          | RO          | 0x0                | cpu_nopendingtrans<br>No pending transfer status for CPU.<br>1'b0: Inactive<br>1'b1: Active |

**PERI GRF USBOTG SIG DETECT CON**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | otg_disconnect_fall_irq_en<br>otg_disconnect falling edge irq enable.<br>1'b0: Disable<br>1'b1: Enable                             |
| 6          | RW          | 0x0                | otg_disconnect_rise_irq_en<br>otg_disconnect rising edge irq enable.<br>1'b0: Disable<br>1'b1: Enable                              |
| 5          | RW          | 0x0                | otg_id_fall_irq_en<br>otg_id falling edge irq enable.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 4          | RW          | 0x0                | otg_id_rise_irq_en<br>otg_id rising edge irq enable.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 3          | RW          | 0x0                | otg_bvalid_fall_irq_en<br>otg_bvalid falling edge irq enable.<br>1'b0: Disable<br>1'b1: Enable                                     |
| 2          | RW          | 0x0                | otg_bvalid_rise_irq_en<br>otg_bvalid rising edge irq enable.<br>1'b0: Disable<br>1'b1: Enable                                      |
| 1          | RO          | 0x0                | reserved                                                                                                                           |
| 0          | RW          | 0x0                | otg_linestate_irq_en<br>otg_linestate change irq enable.<br>1'b0: Disable<br>1'b1: Enable                                          |

**PERI GRF USBOTG SIG DETECT STATUS**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                             |
| 7          | RO          | 0x0                | otg_disconnect_fall_irq<br>otg_disconnect falling edge irq status.<br>1'b0: Inactive<br>1'b1: Active |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | otg_disconnect_rise_irq<br>otg_disconnect rising edge irq status.<br>1'b0: Inactive<br>1'b1: Active |
| 5          | RO          | 0x0                | otg_id_fall_irq<br>otg_id falling edge irq status.<br>1'b0: Inactive<br>1'b1: Active                |
| 4          | RO          | 0x0                | otg_id_rise_irq<br>otg_id rising edge irq status.<br>1'b0: Inactive<br>1'b1: Active                 |
| 3          | RO          | 0x0                | otg_bvalid_fall_irq<br>otg_bvalid falling edge irq status.<br>1'b0: Inactive<br>1'b1: Active        |
| 2          | RO          | 0x0                | otg_bvalid_rise_irq<br>otg_bvalid rising edge irq status.<br>1'b0: Inactive<br>1'b1: Active         |
| 1          | RO          | 0x0                | reserved                                                                                            |
| 0          | RO          | 0x0                | otg_linestate_irq<br>otg_linestate change irq status.<br>1'b0: Inactive<br>1'b1: Active             |

**PERI GRF USBOTG SIG DETECT CLR**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | otg_disconnect_fall_irq_clr<br>otg_disconnect falling edge irq clear. Write 1 to clear irq status.                                 |
| 6          | RW          | 0x0                | otg_disconnect_rise_irq_clr<br>otg_disconnect rising edge irq clear. Write 1 to clear irq status.                                  |
| 5          | RW          | 0x0                | otg_id_fall_irq_clr<br>otg_id falling edge irq clear. Write 1 to clear irq status.                                                 |
| 4          | RW          | 0x0                | otg_id_rise_irq_clr<br>otg_id rising edge irq clear. Write 1 to clear irq status.                                                  |
| 3          | RW          | 0x0                | otg_bvalid_fall_irq_clr<br>otg_bvalid falling edge irq clear. Write 1 to clear irq status.                                         |
| 2          | RW          | 0x0                | otg_bvalid_rise_irq_clr<br>otg_bvalid rising edge irq clear. Write 1 to clear irq status.                                          |
| 1          | RO          | 0x0                | reserved                                                                                                                           |
| 0          | WO          | 0x0                | otg_linestate_irq_clr<br>otg_linestate change irq clear. Write 1 to clear irq status.                                              |

**PERI GRF USBOTG LINESTATE DETECT CON**

Address: Operational Base + offset (0x0110)

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

| Bit  | Attr | Reset Value | Description                                                        |
|------|------|-------------|--------------------------------------------------------------------|
| 19:0 | RW   | 0x30100     | linestate_detect_con<br>OTG linestate filter time control register |

**PERI GRF USBOTG DISCONNECT DETECT CON**

Address: Operational Base + offset (0x0114)

| Bit   | Attr | Reset Value | Description                                                          |
|-------|------|-------------|----------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                             |
| 19:0  | RW   | 0x30100     | disconnect_detect_con<br>OTG disconnect filter time control register |

**PERI GRF USBOTG BVALID DETECT CON**

Address: Operational Base + offset (0x0118)

| Bit   | Attr | Reset Value | Description                                                  |
|-------|------|-------------|--------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                     |
| 19:0  | RW   | 0x30100     | bvalid_detect_con<br>OTG bvalid filter time control register |

**PERI GRF USBOTG ID DETECT CON**

Address: Operational Base + offset (0x011C)

| Bit   | Attr | Reset Value | Description                                          |
|-------|------|-------------|------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                             |
| 27:0  | RW   | 0x0030100   | id_detect_con<br>OTG id filter time control register |

## 4.4 VENC\_GRF Register Description

### 4.4.1 Registers Summary

| Name                         | Offset | Size | Reset Value | Description |
|------------------------------|--------|------|-------------|-------------|
| VENC_GRF_VENC_MEMCFG_UHDSPRA | 0x0000 | W    | 0x00000001  |             |
| VENC_GRF_UART2RX_LO_W_DLY    | 0x0004 | W    | 0xFFFFFFFF  |             |
| VENC_GRF_CIF_IO_WRAPPER      | 0x0008 | W    | 0x00000000  |             |
| VENC_GRF_VOP_IO_WRAPPER      | 0x000C | W    | 0x00000000  |             |
| VENC_GRF_VCCIO6_VD_STATUS    | 0x0010 | W    | 0x00000000  |             |

Notes: **S**-ize: **B**- Byte (8 bits) access, **H****W**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **D****W**-Double WORD (64 bits) access

### 4.4.2 Detail Registers Description

#### VENC\_GRF\_VENC\_MEMCFG\_UHDSPRA

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3:2        | RW          | 0x0                | wtsel<br>Timing adjustment setting for debug purpose                                                                              |
| 1:0        | RW          | 0x1                | rtsel<br>Timing adjustment setting for debug purpose                                                                              |

**VENC GRF UART2RX LOW DLY**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:0       | RW          | 0xffffffff         | uart2rx_low_dly<br>uart2_rx low count |

**VENC GRF CIF IO WRAPPER**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                          |
| 0          | RW          | 0x0                | cif_clk_inv_sel_m1<br>cif invert clk select for m1                                                                                |

**VENC GRF VOP IO WRAPPER**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                       |
| 15:3       | RO          | 0x0000             | reserved                                                                                                                                                |
| 2          | RW          | 0x0                | Lcd_clk_inv_sel<br>Lcd invert clk select                                                                                                                |
| 1:0        | RW          | 0x3                | io_bypass_sel<br>2'b00: Use two flip-flop pipe in VOP LCD IO in vccio6.<br>2'b11: Bypass two flip-flop pipe in VOP LCD IO in vccio6.<br>Other: Reserved |

**VENC GRF VCCIO6 VD STATUS**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                          |
| 0          | RW          | 0x0                | vccio6_vd<br>Indicates vccio6 voltage status, vccio6_vd = 1 when VCCIO > 2.19v. vccio6_vd = 0 when VCCIO < 2.02v. |

## 4.5 NPU\_GRF Register Description

### 4.5.1 Registers Summary

| Name           | Offset | Size | Reset Value | Description              |
|----------------|--------|------|-------------|--------------------------|
| NPUGRF_NPU_MEM | 0x0000 | W    | 0x00000001  | NPU memory configuration |
| NPUGRF_NPU_QOS | 0x0004 | W    | 0x00000000  | NPU Qos configuration    |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 4.5.2 Detail Registers Description

#### NPUGRF\_NPU\_MEM

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4  | RO   | 0x000       | reserved                                                                                                                         |
| 3:2   | RW   | 0x0         | wtsel<br>Configuration for wtsel for memory for RKNN.                                                                            |
| 1:0   | RW   | 0x1         | rtsel<br>Configuration for rtsel for memory for RKNN.                                                                            |

#### NPUGRF\_NPU\_QOS

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                         |
| 3    | RW   | 0x0         | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 2:0  | RW   | 0x0         | aw_qos<br>Aw Qos for RKNN.                                                                                                       |

## 4.6 PMU\_GRF Register Description

### 4.6.1 Registers Summary

| Name                   | Offset | Size | Reset Value | Description                        |
|------------------------|--------|------|-------------|------------------------------------|
| PMU_GRF_SOC_CON0       | 0x0000 | W    | 0x0000301C  | PMU System control register 0      |
| PMU_GRF_SOC_CON1       | 0x0004 | W    | 0x00000000  | PMU System control register 1      |
| PMU_GRF_SOC_CON2       | 0x0008 | W    | 0x00000000  | PMU System control register 2      |
| PMU_GRF_SOC_CON3       | 0x000C | W    | 0x00000000  | PMU System control register 3      |
| PMU_GRF_SOC_CON4       | 0x0010 | W    | 0x00000000  | PMU System control register 4      |
| PMU_GRF_SOC_CON5       | 0x0014 | W    | 0x00000000  | PMU System control register 5      |
| PMU_GRF_SOC_STATUS     | 0x0020 | W    | 0x00000012  | PMU System status register         |
| PMU_GRF_PMUIO_CON      | 0x0030 | W    | 0x00000004  | PMUIO voltage control register     |
| PMU_GRF_MEM_CON        | 0x0040 | W    | 0x00000001  | PMU System memory control register |
| PMU_GRF_OS_REG0        | 0x0200 | W    | 0x00000000  | OS register 0                      |
| PMU_GRF_OS_REG1        | 0x0204 | W    | 0x00000000  | OS register 1                      |
| PMU_GRF_OS_REG2        | 0x0208 | W    | 0x00000000  | OS register 2                      |
| PMU_GRF_OS_REG3        | 0x020C | W    | 0x00000000  | OS register 3                      |
| PMU_GRF_OS_REG4        | 0x0210 | W    | 0x00000000  | OS register 4                      |
| PMU_GRF_OS_REG5        | 0x0214 | W    | 0x00000000  | OS register 5                      |
| PMU_GRF_OS_REG6        | 0x0218 | W    | 0x00000000  | OS register 6                      |
| PMU_GRF_OS_REG7        | 0x021C | W    | 0x00000000  | OS register 7                      |
| PMU_GRF_OS_REG8        | 0x0220 | W    | 0x00000000  | OS register 9                      |
| PMU_GRF_OS_REG9        | 0x0224 | W    | 0x00000000  | OS register 9                      |
| PMU_GRF_OS_REG10       | 0x0228 | W    | 0x00000000  | OS register 10                     |
| PMU_GRF_OS_REG11       | 0x022C | W    | 0x00000000  | OS register 11                     |
| PMU_GRF_RSTFUNC_STATUS | 0x0230 | W    | 0x00000000  | System reset status register       |
| PMU_GRF_RSTFUNC_CLR    | 0x0234 | W    | 0x00000000  | System reset status clear register |

Notes:  
**Size:** **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 4.6.2 Detail Registers Description

#### PMU\_GRF\_SOC\_CON0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable    |
| 15    | RO   | 0x0         | reserved                                                                                                                             |
| 14    | RW   | 0x0         | upctl_a_sysreq_cfg<br>Enable for DDRCTL AXI hardware low-power request by software.<br>1'b0: Disable<br>1'b1: Enable                 |
| 13    | RW   | 0x1         | ddrc_a_gating_en<br>Enable DDRCTL's AXI-clock auto clock gating for DDR fail safe.<br>1'b0: Disable<br>1'b1: Enable                  |
| 12    | RW   | 0x1         | sref_a_enter_en<br>Enable DDR self-refresh mode for AXI-clock domain by hardware for DDR fail safe.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | ddrphy_bufferen_sel1<br>DDR PHY bufferen selection 1.<br>1'b0: bufferen determined by ddrphy_bufferen_sel0<br>1'b1: bufferen comes from hwlp_ddrphy_bufferen |
| 10         | RW          | 0x0                | ddrphy_bufferen_core<br>1'b0: Enable DDRPHY io retention<br>1'b1: Disable DDRPHY io retention                                                                |
| 9          | RW          | 0x0                | ddrphy_bufferen_sel0<br>DDRPHY bufferen selection 0.<br>1'b0: bufferen comes from PMU or DDR_FAIL_SAFE<br>1'b1: bufferen comes from ddrphy_bufferen_core     |
| 8          | RW          | 0x0                | upctl_c_sysreq_cfg<br>Enable for DDRCTL hardware low-power clock request by software.<br>1'b0: Disable<br>1'b1: Enable                                       |
| 7          | RO          | 0x0                | reserved                                                                                                                                                     |
| 6          | RW          | 0x0                | ddr_io_ret_cfg<br>1'b0: DDR IO retention managed by hardware automatically<br>1'b1: Enable DDR IO retention manually                                         |
| 5          | RW          | 0x0                | ddr_io_ret_de_req<br>Enable DDR IO exit retention mode by hardware for DDR fail safe.<br>1'b0: Disable<br>1'b1: Enable                                       |
| 4          | RW          | 0x1                | ddrc_c_gating_en<br>Enable DDRCTL's core-clock auto clock gating for DDR fail safe.<br>1'b0: Disable<br>1'b1: Enable                                         |
| 3          | RW          | 0x1                | sref_c_enter_en<br>Enable DDR self-refresh mode for core-clock domain by hardware for DDR fail safe.<br>1'b0: Disable<br>1'b1: Enable                        |
| 2          | RW          | 0x1                | ddrio_ret_en<br>Enable DDR IO enter retention mode by hardware for DDR fail safe.<br>1'b0: Disable<br>1'b1: Enable                                           |
| 1          | RW          | 0x0                | wdt_reset_trigger_en<br>Enable WDT reset trigger for DDR fail safe.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 0          | RW          | 0x0                | tsadc_shut_reset_trigger_en<br>Enable TSADC shut reset trigger for DDR fail safe.<br>1'b0: Disable<br>1'b1: Enable                                           |

**PMU\_GRF\_SOC\_CON1**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | rtc_clk_32k_h_clamp_n<br>Clamp enable for rtc_clk_32k_h from RTC high drive path.<br>1'b0: Clamp enable, rtc_clk_32k_h is inactive to PMU system.<br>1'b1: Clamp disable, rtc_clk_32k_h is active to PMU system.<br>When RTC is off, this bit should be set to 0. |
| 14         | RW          | 0x0                | rtc_32k_sel<br>32K clock source selection.<br>1'b0: 32K clock from RTC nomal path<br>1'b1: 32K clock from RTC high drive path                                                                                                                                     |
| 13         | RW          | 0x0                | pmuwdt_mcu_reset_en<br>PMU WDT reset LPMCU enable.<br>1'b0: Disable. PMU WDT reset output cannot reset LPMCU.<br>1'b1: Enable. PMU WDT reset output will just reset LPMCU.                                                                                        |
| 12         | RW          | 0x0                | pmuwdt_glb_reset_en<br>PMU WDT global reset enable.<br>1'b0: Disable. PMU WDT reset output cannot reset SoC system.<br>1'b1: Enable. PMU WDT reset output will reset SoC system.                                                                                  |
| 11         | RW          | 0x0                | pmuwdt_pause_en<br>PMU WDT pause enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                         |
| 10         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                          |
| 9          | RW          | 0x0                | lpmcu_soft_irq<br>LPMCU software interrupt.<br>1'b0: No interrupt<br>1'b0: Valid interrupt                                                                                                                                                                        |
| 8          | RW          | 0x0                | pmusram_clkgat_disable<br>Disable auto clock gating for PMU SRAM.<br>1'b0: Enable auto clock gating. PMU SRAM clock is auto gated if there is no access.<br>1'b1: Disable auto clock gating. PMU SRAM clock is not auto gated if there is no access.              |
| 7          | RW          | 0x0                | pwm6_switch_ena<br>PWM6 output source swith enable.<br>1'b0: Disable, PWM6 output source is from PWM module.<br>1'b1: Enable, PWM6 output source is from PMU module.                                                                                              |
| 6          | RW          | 0x0                | pwm5_switch_ena<br>PWM5 output source swith enable.<br>1'b0: Disable, PWM5 output source is from PWM module.<br>1'b1: Enable, PWM5 output source is from PMU module.                                                                                              |
| 5          | RW          | 0x0                | pwm3_switch_ena<br>PWM3 output source swith enable.<br>1'b0: Disable, PWM3 output source is from PWM module.<br>1'b1: Enable, PWM3 output source is from PMU module.                                                                                              |
| 4          | RW          | 0x0                | pwm2_switch_ena<br>PWM2 output source swith enable.<br>1'b0: Disable, PWM2 output source is from PWM module.<br>1'b1: Enable, PWM2 output source is from PMU module.                                                                                              |
| 3          | RW          | 0x0                | pwm1_switch_ena<br>PWM1 output source swith enable.<br>1'b0: Disable, PWM1 output source is from PWM module.<br>1'b1: Enable, PWM1 output source is from PMU module.                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | pmic_sleep_m1_pol<br>pmic_sleep_m1 polarity.<br>1'b0: pmic_sleep_m1 is equal to PMIC_SLEEP.<br>1'b1: pmic_sleep_m1 is equal to the inverse value of PMIC_SLEEP. |
| 1          | RW          | 0x0                | pmic_sleep_m0_pol<br>pmic_sleep_m0 polarity.<br>1'b0: pmic_sleep_m0 is equal to PMIC_SLEEP.<br>1'b1: pmic_sleep_m0 is equal to the inverse value of PMIC_SLEEP. |
| 0          | RW          | 0x0                | pmic_sleep_sel<br>PMIC_SLEEP source selection.<br>1'b0: npor_out2chip_RST, from reset pulse generator.<br>1'b1: pmu_sleep, from PMU block.                      |

**PMU GRF SOC CON2**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:0       | RW          | 0x0000             | out2chip_RST_init<br>out2chip_RST width configuration.                                                                            |

**PMU GRF SOC CON3**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable     |
| 15:12      | RO          | 0x0                | reserved                                                                                                                              |
| 11:0       | RW          | 0x000              | pmupvtm_clkout_div<br>Divider for PMU PVTM output clock to generate 32KHz clock.<br>Frequency is divided by (pmupvtm_clkout_div*4+1). |

**PMU GRF SOC CON4**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable              |
| 15         | RW          | 0x0                | resetn_ddr_fail_safe_hold_ena<br>Hold resetn_ddr_fail_safe. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable |
| 14         | RW          | 0x0                | presetn_pmu_pvtm_hold_ena<br>Hold presetn_pmu_pvtm. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | presetn_pmu_wdt_hold_ena<br>Hold presetn_pmu_wdt. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable               |
| 12         | RW          | 0x0                | presetn_pmu_sgrf_hold_ena<br>Hold presetn_pmu_sgrf. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable             |
| 11         | RW          | 0x0                | presetn_pmu_sgrf_remap_hold_ena<br>Hold presetn_pmu_sgrf_remap. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable |
| 10         | RW          | 0x0                | presetn_pmu_mailbox_hold_ena<br>Hold presetn_pmu_mailbox. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable       |
| 9          | RW          | 0x0                | presetn_pmu_ioc_hold_ena<br>Hold presetn_pmu_ioc. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable               |
| 8          | RW          | 0x0                | presetn_pmu_hptimer_hold_ena<br>Hold presetn_pmu_hptimer. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable       |
| 7          | RW          | 0x0                | presetn_pmu_cru_hold_ena<br>Hold presetn_pmu_cru. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable               |
| 6:5        | RO          | 0x0                | reserved                                                                                                                                           |
| 4          | RW          | 0x0                | presetn_pmu_biu_hold_ena<br>Hold presetn_pmu_biu. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable               |
| 3          | RW          | 0x0                | presetn_i2c1_hold_ena<br>Hold presetn_i2c1. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable                     |
| 2          | RW          | 0x0                | hresetn_pmu_sram_hold_ena<br>Hold phresetn_pmu_sram. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable            |
| 1          | RW          | 0x0                | hresetn_pmu_biu_hold_ena<br>Hold hresetn_pmu_biu. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | dbresetn_pmu_gpio0_hold_ena<br>Hold dbresetn_pmu_gpio0. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable |

**PMU\_GRF\_SOC\_CONS**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                  |
| 15:9       | RO          | 0x00               | reserved                                                                                                                                           |
| 8          | RW          | 0x0                | tresetn_pmu_wdt_hold_ena<br>Hold tresetn_pmu_wdt. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable               |
| 7          | RW          | 0x0                | tresetn_lpmcu_cpu_hold_ena<br>Hold tresetn_lpmcu_cpu. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable           |
| 6          | RW          | 0x0                | resetn_pmupvtm_hold_ena<br>Hold resetn_pmupvtm. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable                 |
| 5          | RW          | 0x0                | resetn_lpmcu_hold_ena<br>Hold resetn_lpmcu. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable                     |
| 4          | RW          | 0x0                | resetn_lpmcu_pwrup_hold_ena<br>Hold resetn_lpmcu_pwrup. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable         |
| 3          | RW          | 0x0                | resetn_lpmcu_cpu_hold_ena<br>Hold resetn_lpmcu_cpu. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable             |
| 2          | RW          | 0x0                | resetn_pmu_hptimer_hold_ena<br>Hold resetn_pmu_hptimer. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable         |
| 1          | RW          | 0x0                | resetn_pmu_32k_hptimer_hold_ena<br>Hold resetn_pmu_32k_hptimer. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | resetn_i2c1_hold_ena<br>Hold resetn_i2c1. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable |

**PMU\_GRF\_SOC\_STATUS**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                            |
| 4          | RO          | 0x1                | npor_powergood<br>NPOR power state.<br>1'b0: Power badl state<br>1'b1: Power good state                             |
| 3          | RO          | 0x0                | core_standbywfi2<br>CORE L2 standbywfi state.<br>1'b0: CORE L2 in normal state<br>1'b1: CORE L2 in standbywfi state |
| 2          | RO          | 0x0                | core_standbywfi<br>CORE standbywfi state.<br>1'b0: CORE in normal state<br>1'b1: CORE in standbywfi state           |
| 1          | RO          | 0x1                | lpmcu_RST_out<br>LPMCU Non-DN reset from debug module.<br>1'b0: Reset state<br>1'b1: Normal state                   |
| 0          | RO          | 0x0                | lpmcu_wfi_halted<br>LPMCU wfi halted state.<br>1'b0: LPMCU in normal state<br>1'b1: LPMCU in wfi state              |

**PMU\_GRF\_PMUIO\_CON**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x0                | poc_pmui0_iddq<br>For IDDQ testing                                                                                                |
| 2          | RW          | 0x1                | poc_pmui0_cle<br>PMUIO clamping receiver. Set to 1 for 3.3v operation.                                                            |
| 1          | RW          | 0x0                | poc_pmui0_sel25<br>Set to 1 for PMUIO VDDO=2.5v operation.                                                                        |
| 0          | RW          | 0x0                | poc_pmui0_sel18<br>Set to 1 for PMUIO VDDO=1.8v operation.                                                                        |

**PMU\_GRF\_MEM\_CON**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 15:4       | RO          | 0x000              | reserved                                        |
| 3:0        | RW          | 0x1                | mem_cfg_uhdspra<br>[1:0]: RTSEL<br>[3:2]: WTSEL |

**PMU GRF OS REG0**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG1**

Address: Operational Base + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG2**

Address: Operational Base + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG3**

Address: Operational Base + offset (0x020C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG4**

Address: Operational Base + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG5**

Address: Operational Base + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG6**

Address: Operational Base + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG7**

Address: Operational Base + offset (0x021C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG8**

Address: Operational Base + offset (0x0220)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG9**

Address: Operational Base + offset (0x0224)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG10**

Address: Operational Base + offset (0x0228)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF OS REG11**

Address: Operational Base + offset (0x022C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RW          | 0x00000000         | os_reg<br>OS register |

**PMU GRF RSTFUNC STATUS**

Address: Operational Base + offset (0x0230)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                             |
| 3          | RO          | 0x0                | ddr_fail_safe_src_stat<br>Reset state.<br>When high, ddr_fail_safe is active.        |
| 2          | RO          | 0x0                | tsadc_shut_reset_src_stat<br>Reset state.<br>When high, reset by TSADC shut trigger. |
| 1          | RO          | 0x0                | wdt_reset_src_stat<br>Reset state.<br>When high, reset by WDT trigger.               |
| 0          | RO          | 0x0                | first_reset_src_stat<br>Reset state.<br>When high, reset by first reset trigger.     |

**PMU GRF RSTFUNC CLR**

Address: Operational Base + offset (0x0234)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                            |
| 3          | WO          | 0x0                | ddr_fail_safe_src_clr<br>Clear bit for ddr_fail_safe.<br>1'b1: Clear enable<br>1'b0: Clear disable                  |
| 2          | WO          | 0x0                | tsadc_shut_reset_src_clr<br>Clear bit for reset by tsadc shut trigger.<br>1'b1: Clear enable<br>1'b0: Clear disable |
| 1          | WO          | 0x0                | wdt_reset_src_clr<br>Clear bit for reset by wdt trigger.<br>1'b1: Clear enable<br>1'b0: Clear disable               |

| Bit | Attr | Reset Value | Description                                                                                                     |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------|
| 0   | WO   | 0x0         | first_reset_src_clr<br>Clear bit for reset by first reset trigger.<br>1'b1: Clear enable<br>1'b0: Clear disable |

## 4.7 DDR\_GRF Register Description

### 4.7.1 Registers Summary

| Name              | Offset | Size | Reset Value | Description               |
|-------------------|--------|------|-------------|---------------------------|
| DDRGRF CON0       | 0x0000 | W    | 0x00000080  | DDR GRF Config Register 0 |
| DDRGRF CON1       | 0x0004 | W    | 0x00002400  | DDR GRF Config Register 1 |
| DDRGRF CON2       | 0x0008 | W    | 0x000003FF  | DDR GRF Config Register 2 |
| DDRGRF CON3       | 0x000C | W    | 0x00000001  | DDR GRF Config Register 3 |
| DDRGRF STATUS0    | 0x0100 | W    | 0x00000000  | DDR GRF Status Register 0 |
| DDRGRF STATUS1    | 0x0104 | W    | 0x00000000  | DDR GRF Status Register 1 |
| DDRGRF STATUS2    | 0x0108 | W    | 0x00000000  | DDR GRF Status Register 2 |
| DDRGRF STATUS3    | 0x010C | W    | 0x00000000  | DDR GRF Status Register 3 |
| DDRGRF STATUS4    | 0x0110 | W    | 0x00000000  | DDR GRF Status Register 4 |
| DDRGRF STATUS5    | 0x0114 | W    | 0x00000000  | DDR GRF Status Register 5 |
| DDRGRF STATUS6    | 0x0118 | W    | 0x00000000  | DDR GRF Status Register 6 |
| DDRGRF STATUS7    | 0x011C | W    | 0x00000000  | DDR GRF Status Register 7 |
| DDRGRF STATUS8    | 0x0120 | W    | 0x0000001F  | DDR GRF Status Register 8 |
| DDRGRF STATUS9    | 0x0124 | W    | 0x00000000  | DDR GRF Status Register 9 |
| DDRGRF PHY_STATUS | 0x0160 | W    | 0x00000000  | DDR PHY Status Register   |

Notes:  
**B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 4.7.2 Detail Registers Description

#### DDRGRF CON0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | RW   | 0x0000      | write_enable<br>Write enable for lower 15bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                       |
| 16:15 | RO   | 0x0         | reserved                                                                                                                                                |
| 14    | RW   | 0x0         | grf_con_awpoison_0<br>Connected to the UMCTL2's input signal, awpoison_0. The awpoison_0 is a off-band signal to indicate an invalid write transaction. |
| 13    | RW   | 0x0         | grf_con_awurgent_0<br>Connected to the UMCTL2's input AXI write urgent signal, awurgent_0.                                                              |
| 12    | RW   | 0x0         | grf_con_arpoison_0<br>Connected to the UMCTL2's input signal, arpoison_0. The arpoison_0 is a sideband signal to indicate an invalid read transaction.  |
| 11    | RW   | 0x0         | grf_con_arurgent_0<br>Connected to the UMCTL2's input AXI read urgent signal, arurgent_0.                                                               |
| 10    | RW   | 0x0         | grf_con_pa_wmask<br>Connected to the UMCTL2's input write port mask signal, pa_wmask                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x0                | grf_con_pa_rmask<br>Connected to UMCTL2's input read port mask signal, pa_rmask                                                                                                                                                      |
| 7          | RW          | 0x1                | grf_con_dfi_init_complete<br>When grf_con_dfi_init_complete_sel==1'b1, this signal is selected as UMCTL2's input signal, dfi_init_complete.                                                                                          |
| 6          | RW          | 0x0                | grf_con_dfi_init_complete_sel<br>1'b0: UMCTL2's input signal, dfi_init_complete, is generated by DDR PHY.<br>1'b1: UMCTL2's input signal, dfi_init_complete, is connected from grf_con_dfi_init_complete.                            |
| 5          | RW          | 0x0                | grf_con_dfi_init_start<br>When grf_con_dfi_init_start_sel==1'b1, this signal is selected as DDR PHY's input signal, dfi_init_start.                                                                                                  |
| 4          | RW          | 0x0                | grf_con_dfi_init_start_sel<br>1'b0: DDR PHY's input signal, dfi_init_start, is generated by HW lowpower module, dfi_ctl module or UMCTL2.<br>1'b1: DDR PHY's input signal, dfi_init_start, is connected from grf_con_dfi_init_start. |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                             |
| 0          | RW          | 0x0                | grf_con_upctl_slverr_enable<br>1'b0: Disable DDRC apb pslverr<br>1'b1: Enable DDRC apb pslverr                                                                                                                                       |

**DDRGRF\_CON1**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RW          | 0x0000             | write_enable<br>Write enable for lower 14bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                               |
| 17:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                        |
| 13         | RW          | 0x1                | grf_con_hwlp_ddrphy_io_ret_en<br>Reserved                                                                                                                                                                                                                       |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                        |
| 11:8       | RW          | 0x4                | grf_con_ddrc_auto_sr_dly<br>When SDRAM is in self-refresh state whose type is indicated by grf_con_selfref_type2_en, the core clk of UMCTL2 will be gated after grf_con_ddrc_auto_sr_dly clocks.                                                                |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                        |
| 5          | RW          | 0x0                | grf_con_upctl2_pdsrlp_cg_en<br>Reserved                                                                                                                                                                                                                         |
| 4          | RW          | 0x0                | grf_con_upctl2_sysreq_cg_en<br>1'b0: Core clk of UMCTL2 is allowed to be gated when csysreq_ddrc^csysack_ddrc==1.<br>1'b1: Core clk of UMCTL2 would not be gated when csysreq_ddrc^csysack_ddrc==1.                                                             |
| 3          | RW          | 0x0                | grf_con_selfref_type2_en<br>1'b0: Only allowed core clk of UMCTL2 to be gated when SDRAM's self-refresh is caused by automatic self-refresh.<br>1'b1: Allowed core clk of UMCTL2 to be gated when SDRAM's self-refresh is not caused by automatic self-refresh. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | grf_con_upctl2_core_cg_en<br>1'b0: Do not gate core clk of UMCTL2<br>1'b1: Gate core clk of UMCTL2 unless following two case:<br>Case1: grf_con_upctl2_apb_cg_en==1'b1 and the psel of UMCTL2 is asserted<br>Case2: grf_con_upctl2_sysreq_cg_en==1'b1 and csysreq_ddrc^csysack_ddrc==1 |
| 1          | RW          | 0x0                | grf_con_upctl2_apb_cg_en<br>1'b0: Axi clk and core clk of UMCTL2 is allowed to be gated when psel of UMCTL2 is asserted.<br>1'b1: Axi clk and core clk of UMCTL2 would not be gated when psel of UMCTL2 is asserted.                                                                   |
| 0          | RW          | 0x0                | grf_con_upctl2_axi_cg_en<br>1'b0: Do not gate axi clk of UMCTL2<br>1'b1: Gate axi clk of UMCTL2 unless grf_con_upctl2_apb_cg_en==1'b1 and the psel of UMCTL2 is asserted.                                                                                                              |

**DDRGRF CON2**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RW          | 0x0000             | write_enable<br>Write enable for lower 15bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable                                                       |
| 16:15      | RO          | 0x0                | reserved                                                                                                                                                                               |
| 14         | RW          | 0x0                | interconnect_mem_ckg_disable<br>Indicates whether to enable the clock gating function of the msch memory.<br>1'b0: Enable clock gating function<br>1'b1: Disable clock gating function |
| 13         | RW          | 0x0                | grf_con_lpddr45_en<br>Should set to 0 as lpddr4/lpddr5 is not supported.                                                                                                               |
| 12         | RW          | 0x0                | grf_con_awautopre_0<br>Connected to the UMCTL2's input signal, awautopre_0. The awautopre_0 is AXI auto-precharge signal for write command.                                            |
| 11         | RW          | 0x0                | grf_con_arautopre_0<br>Connected to the UMCTL2's input signal, arautopre_0. The arautopre_0 is AXI auto-precharge signal for read command.                                             |
| 10         | RO          | 0x0                | reserved                                                                                                                                                                               |
| 9:0        | RW          | 0x3ff              | grf_con_ddr_clk_gate<br>The clock gate signals for clocks inside DDRC and Arbiter block. Each bit corresponds to a clock.                                                              |

**DDRGRF CON3**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RW          | 0x0000             | write_enable<br>Write enable for lower 12bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 19:12      | RO          | 0x0                | reserved                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | grf_con_csysreq_axi_hwlp<br>1'b0: The hardware low power request signal of AXI block, csysreq_0, is not related to HW low power module.<br>1'b1: The hardware low power request signal of AXI block, csysreq_0, can be generated by HW low power module. |
| 10         | RW          | 0x0                | grf_con_csysreq_ddrc_hwlp<br>1'b0: The hardware low power request signal of DDRC, csysreq_ddrc, is not related to HW low power module.<br>1'b1: The hardware low power request signal of DDRC, csysreq_ddrc, can be generated by HW low power module.    |
| 9          | RW          | 0x0                | grf_con_csysreq_axi_pmu<br>1'b0: The hardware low power request signal of AXI block, csysreq_0, is not related to PMU.<br>1'b1: The hardware low power request signal of AXI block, csysreq_0, can be generated by PMU.                                  |
| 8          | RW          | 0x0                | grf_con_csysreq_ddrc_pmu<br>1'b0: The hardware low power request signal of DDRC, csysreq_ddrc, is not related to PMU.<br>1'b1: The hardware low power request signal of DDRC, csysreq_ddrc, can be generated by PMU.                                     |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                 |
| 3:0        | RW          | 0x1                | grf_shrm_mem_cfg_uhdspra<br>[1:0]: Connected to system sram's input signal, RTSEL.<br>[3:2]: Connected to system sram's input signal, WTSEL.                                                                                                             |

**DDRGRF\_STATUS0**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | grf_st_mrr_data0_31_0<br>The low 32 bit of multi-purpose register 0 (MPR0) read data. The width of MPR read data is equal to 64 bit. |

**DDRGRF\_STATUS1**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                               |
| 0          | RO          | 0x0                | grf_st_mrr_data0_63_32<br>The high 32 bit of multi-purpose register 0 (MPR0) read data. The width of MPR read data is equal to 64 bit. |

**DDRGRF\_STATUS2**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                             |
| 0          | RO          | 0x0                | grf_st_mrr_data1_31_0<br>The low 32 bit of multi-purpose register 1 (MPR1) read data. The width of MPR read data is equal to 64 bit. |

**DDRGRF\_STATUS3**

Address: Operational Base + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                               |
| 0          | RO          | 0x0                | grf_st_mrr_data1_63_32<br>The high 32 bit of multi-purpose register 1 (MPR1) read data. The width of MPR read data is equal to 64 bit. |

**DDRGRF\_STATUS4**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                             |
| 0          | RO          | 0x0                | grf_st_mrr_data2_31_0<br>The low 32 bit of multi-purpose register 2 (MPR2) read data. The width of MPR read data is equal to 64 bit. |

**DDRGRF\_STATUS5**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                               |
| 0          | RO          | 0x0                | grf_st_mrr_data2_63_32<br>The high 32 bit of multi-purpose register 2 (MPR2) read data. The width of MPR read data is equal to 64 bit. |

**DDRGRF\_STATUS6**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                             |
| 0          | RO          | 0x0                | grf_st_mrr_data3_31_0<br>The low 32 bit of multi-purpose register 3 (MPR3) read data. The width of MPR read data is equal to 64 bit. |

**DDRGRF\_STATUS7**

Address: Operational Base + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                               |
| 0          | RO          | 0x0                | grf_st_mrr_data3_63_32<br>The high 32 bit of multi-purpose register 3 (MPR3) read data. The width of MPR read data is equal to 64 bit. |

**DDRGRF\_STATUS8**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                             |
| 15         | RO          | 0x0                | vi_port_probe_mainstatalarm<br>Reserved                                                                              |
| 14         | RO          | 0x0                | vi_port_probe_maintracealarm<br>Reserved                                                                             |
| 13         | RO          | 0x0                | vepu_port_probe_mainstatalarm<br>Reserved                                                                            |
| 12         | RO          | 0x0                | vepu_port_probe_maintracealarm<br>Reserved                                                                           |
| 11         | RO          | 0x0                | cpu_port_probe_mainstatalarm<br>Reserved                                                                             |
| 10         | RO          | 0x0                | cpu_port_probe_maintracealarm<br>Reserved                                                                            |
| 9          | RO          | 0x0                | npu_port_probe_mainstatalarm<br>Reserved                                                                             |
| 8          | RO          | 0x0                | npu_port_probe_maintracealarm<br>Reserved                                                                            |
| 7:6        | RO          | 0x0                | grf_st_stat_ddrc_reg_selfref_type<br>Current self-refresh status and type. Equivalent to STAT.selfref_type register. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 5          | RO          | 0x0                | cactive_axi<br>State of AXI low-power clock active, cactive_axi                    |
| 4          | RO          | 0x1                | csysack_axi<br>State of AXI low-power request acknowledge, csysack_axi             |
| 3          | RO          | 0x1                | csysreq_axi<br>State of AXI low-power request, csysreq_axi                         |
| 2          | RO          | 0x1                | cactive_ddrc<br>State of DDRC hardware low-power clock active, cactive_ddrc        |
| 1          | RO          | 0x1                | csysack_ddrc<br>State of DDRC hardware low-power request acknowledge, cactive_ddrc |
| 0          | RO          | 0x1                | csysreq_ddrc<br>State of DDRC hardware low-power request, csysreq_ddrc             |

**DDRGDF STATUS9**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 31:23      | RO          | 0x000              | reserved                                                                                                             |
| 22:16      | RO          | 0x00               | grf_st_wr_credit_cnt<br>Value of wr_credit_cnt. It indicates the number of available write CAM slots.                |
| 15         | RO          | 0x0                | reserved                                                                                                             |
| 14:8       | RO          | 0x00               | grf_st_hpr_credit_cnt<br>Value of hpr_credit_cnt. It Indicates the number of available High priority read CAM slots. |
| 7          | RO          | 0x0                | reserved                                                                                                             |
| 6:0        | RO          | 0x00               | grf_st_lpr_credit_cnt<br>Value of lpr_credit_cnt. It indicates the number of available Low priority read CAM slots.  |

**DDRGDF PHY STATUS**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                      |
| 0          | RO          | 0x0                | ddr_cmd_plllock<br>PLL lock state of DDR PHY.<br>1'b0: Lock<br>1'b1: Not lock |

**4.8 CORE\_GRF Register Description****4.8.1 Registers Summary**

| <b>Name</b>             | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                 |
|-------------------------|---------------|-------------|--------------------|------------------------------------|
| CORE_GRF_PVTPLL_CON0_L  | 0x0000        | W           | 0x00000000         | pvtpll control register0 low part  |
| CORE_GRF_PVTPLL_CON0_H  | 0x0004        | W           | 0x00000000         | pvtpll control register0 high part |
| CORE_GRF_PVTPLL_CON1    | 0x0008        | W           | 0x00000018         |                                    |
| CORE_GRF_PVTPLL_CON2    | 0x000C        | W           | 0x00000004         |                                    |
| CORE_GRF_PVTPLL_CON3    | 0x0010        | W           | 0x00000000         |                                    |
| CORE_GRF_PVTPLL_OSC_CNT | 0x0018        | W           | 0x00000000         |                                    |

| Name                           | Offset | Size | Reset Value | Description |
|--------------------------------|--------|------|-------------|-------------|
| CORE_GRF_PVTPLL_OSC_CNT_AVG    | 0x001C | W    | 0x00000000  |             |
| CORE_GRF_CACHE_PERI_ADDR_START | 0x0024 | W    | 0x00000000  |             |
| CORE_GRF_CACHE_PERI_ADDR_END   | 0x0028 | W    | 0x00000000  |             |
| CORE_GRF MCU CACHE_MISC        | 0x002C | W    | 0x00000000  |             |
| CORE_GRF MCU CACHE_STATUS      | 0x0030 | W    | 0x00000000  |             |
| CORE_GRF CPU STATUS            | 0x0034 | W    | 0x00000000  |             |
| CORE_GRF CPU CONO              | 0x0038 | W    | 0x00000C01  |             |
| CORE_GRF_CORE_MEMCF_G_UHDSPRA  | 0x003C | W    | 0x00000001  |             |

Notes:  
**S**ize: **B**- Byte (8 bits) access, **H**W- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

#### 4.8.2 Detail Registers Description

##### CORE\_GRF\_PVTPLL\_CONO\_L

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15    | RW   | 0x0         | bypass<br>1'b1: Not support glitch-free frequency switch<br>1'b0: Support glitch-free frequency switch                            |
| 14:13 | RW   | 0x0         | clk_div_osc<br>Frequency division factor for osc_clk                                                                              |
| 12:11 | RW   | 0x0         | clk_div_ref<br>Frequency division factor for ref_clk                                                                              |
| 10:8  | RW   | 0x0         | osc_ring_sel<br>Osc ring channel select                                                                                           |
| 7:3   | RO   | 0x00        | reserved                                                                                                                          |
| 2     | RW   | 0x0         | out_polar<br>1'b1: Need to increase when out = 1<br>1'b0: Need to increase when out = 0                                           |
| 1     | RW   | 0x0         | osc_en<br>1'b1: Osc_ring enable<br>1'b0: Osc_ring disable                                                                         |
| 0     | RW   | 0x0         | start<br>1'b1: Pvtpll monitor start<br>1'b0: Pvtpll monitor doesn't start                                                         |

##### CORE\_GRF\_PVTPLL\_CONO\_H

Address: Operational Base + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7  | RO   | 0x000       | reserved                                                                                                                          |
| 6:0   | RW   | 0x00        | ring_length_sel<br>Osc ring inverter length select                                                                                |

**CORE GRF PVTPLL CON1**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:0       | RW          | 0x000000018        | cal_cnt<br>Frequency measurement period |

**CORE GRF PVTPLL CON2**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:16      | RW          | 0x0000             | ckg_val<br>Clk gating interval control count value |
| 15:0       | RW          | 0x0004             | threshold<br>Count differency threshold value      |

**CORE GRF PVTPLL CONS**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                          |
|------------|-------------|--------------------|---------------------------------------------|
| 31:0       | RW          | 0x00000000         | ref_cnt<br>Target reference frequency value |

**CORE GRF PVTPLL OSC CNT**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:0       | RW          | 0x00000000         | osc_clk_cnt_val<br>Osc_clk counter value |

**CORE GRF PVTPLL OSC CNT AVG**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                               |
| 0          | RW          | 0x0                | osc_clk_cnt_ave_value<br>Osc_clk counter average value |

**CORE GRF CACHE PERI ADDR START**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                   |
| 19:0       | RW          | 0x00000            | peri_addr_start<br>Cache periphral high 20-bit base address,the address should be put in low 20-bit when configure the reg |

**CORE GRF CACHE PERI ADDR END**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                     |
| 19:0       | RW          | 0x00000            | periphral_addr_end<br>Cache periphral high 20-bit end address,the address should be put in low 20-bit when configure the reg |

**CORE GRF MCU CACHE MISC**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x0                | scr1_soft_irq<br>mcu software irq                                                                                                 |
| 2:1        | RW          | 0x0                | cache_slv_memattr<br>cache slave memory attribute                                                                                 |
| 0          | RW          | 0x0                | cache_flush_req<br>cache flush request                                                                                            |

**CORE GRF MCU CACHE STATUS**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                          |
| 3          | RW          | 0x0                | ndm_RST_N_out<br>Non-debug module reset output    |
| 2          | RW          | 0x0                | wfi_halted<br>mcu is in wfi state.                |
| 1          | RW          | 0x0                | cache_flush_ack<br>cache flush ack                |
| 0          | RW          | 0x0                | cache_idle<br>cache is in idle state, high active |

**CORE GRF CPU STATUS**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                               |
| 6          | RW          | 0x0                | jtagnsw<br>High if JTAG selected, low if SWD selected SWJ-DP           |
| 5          | RW          | 0x0                | jtagtop<br>Indicates TAP in TLR,RTI,Sel-DR or Sel-IR states for SWJ-DP |
| 4          | RW          | 0x0                | evento_rising_edge<br>Indicates an event output                        |
| 3          | RW          | 0x0                | standbywfil2<br>L2 memory system is in wfi state.                      |
| 2          | RW          | 0x0                | smpnamp<br>It signals SMP mode or AMP mode for core.                   |
| 1          | RW          | 0x0                | standbywfi<br>Core is in wfi state.                                    |
| 0          | RW          | 0x0                | standbywfe<br>Core is in wfe state.                                    |

**CORE GRF CPU CON0**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                          |
| 16         | RW          | 0x0                | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| Bit | Attr | Reset Value | Description                                                                                                                                                                           |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | RW   | 0x0         | wakeup_int_pmu_sel<br>It is used to select the interrupt source<br>1'b1: select interrupt from IPs directly<br>1'b0: select interrupt from GIC output                                 |
| 14  | RW   | 0x0         | po_srst_wfien<br>wfi enable for core power-on softrst                                                                                                                                 |
| 13  | RW   | 0x0         | srst_wfien<br>wfi enable for core softrst                                                                                                                                             |
| 12  | RW   | 0x0         | evento_clr<br>Clear the event output status to 1'b0                                                                                                                                   |
| 11  | RW   | 0x1         | dbgselfaddrv<br>Debug self-address offset valid                                                                                                                                       |
| 10  | RW   | 0x1         | dbgromaddrv<br>Debug ROM physical address valid                                                                                                                                       |
| 9   | RW   | 0x0         | eventi<br>Event input for processor wake-up from WFE state.                                                                                                                           |
| 8   | RW   | 0x0         | l2rstdisable<br>Disable automatic L2 cache invalidate at reset                                                                                                                        |
| 7   | RW   | 0x0         | l1rstdisable<br>Disable automatic data cache,instruction cache and TLB invalidate at reset                                                                                            |
| 6:3 | RO   | 0x0         | reserved                                                                                                                                                                              |
| 2   | RW   | 0x0         | cfgte<br>Controls process state for exception handling(TE bit) at reset<br>1'b1: Thumb instruction set for exception handling<br>1'b0: ARM instruction set for exception handling     |
| 1   | RW   | 0x0         | cfgend<br>Controls endianness during dta exception handling(EE-bit) at reset<br>1'b1: Big-endian data during exception handling<br>1'b0: Little-endian data during exception handling |
| 0   | RW   | 0x1         | vinithi<br>Sets the base address of the vector table<br>1'b1: A vector table base address of 0xFFFF0000<br>1'b0: A vector table base address of 0x00000000                            |

**CORE\_GRF CORE\_MEMCFG\_UHDSPRA**

Address: Operational Base + offset (0x003C)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4  | RO   | 0x000       | reserved                                                                                                                          |
| 3:2   | RW   | 0x0         | wtsel<br>Timing adjustment setting for debug purpose                                                                              |
| 1:0   | RW   | 0x1         | rtsel<br>Timing adjustment setting for debug purpose                                                                              |

**4.9 VI\_GRF Register Description****4.9.1 Registers Summary**

| Name                           | Offset | Size | Reset Value | Description |
|--------------------------------|--------|------|-------------|-------------|
| VI_GRF_VI_MISC_CON0            | 0x0000 | W    | 0x00000080  |             |
| VI_GRF_VI_SDMMC_CON0           | 0x0004 | W    | 0x00000004  |             |
| VI_GRF_VI_SDMMC_CON1           | 0x0008 | W    | 0x00000000  |             |
| VI_GRF_VI_STATUS_CON4          | 0x0010 | W    | 0x00000000  |             |
| VI_GRF_VI_CSIPHY_CON5          | 0x0014 | W    | 0x00000000  |             |
| VI_GRF_VI_CSIPHY_STATUS        | 0x0018 | W    | 0x00000000  |             |
| VI_GRF_VI_MEMCFG_UH_DSPRA      | 0x001C | W    | 0x00000001  |             |
| VI_GRF_SDMMC_DET_CNT           | 0x0024 | W    | 0x00000000  |             |
| VI_GRF_SDMMC_SIG_DETECT_CON    | 0x0028 | W    | 0x00000000  |             |
| VI_GRF_SDMMC_SIG_DETECT_STATUS | 0x002C | W    | 0x00000000  |             |
| VI_GRF_SDMMC_STATUS_CLR        | 0x0030 | W    | 0x00000000  |             |
| VI_GRF_SDMMC_DET_FLT_CON       | 0x0034 | W    | 0x00000000  |             |
| VI_GRF_CIF_CON                 | 0x0038 | W    | 0x00000000  |             |

Notes:Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

#### 4.9.2 Detail Registers Description

##### VI\_GRF\_VI\_MISC\_CON0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                 |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable                                         |
| 15:9  | RO   | 0x00        | reserved                                                                                                                                    |
| 8     | RW   | 0x0         | sdmmc_detn_io_pol<br>Indicates SDMMC detectn io pin polar<br>1'b0: Low active<br>1'b1: High active                                          |
| 7     | RW   | 0x1         | sdmmc_ram_clkgat_disable<br>SDMMC ram hardware clk gating disable<br>1'b0: Gate SDMMC ram clk when idle<br>1'b1: SDMMC ram clk is always on |
| 6     | RW   | 0x0         | rtc_clamp_en<br>Rtc clamp enable                                                                                                            |
| 5     | RW   | 0x0         | isp_shutter_trig<br>Mechanical shutter external trigger pulse                                                                               |
| 4     | RO   | 0x0         | reserved                                                                                                                                    |
| 3     | RW   | 0x0         | isp_fl_trig<br>Flash light external trigger pulse                                                                                           |
| 2     | RW   | 0x0         | vicap_lvds_sel_2lane<br>Vicap lvds select the lane0 and lane1.                                                                              |
| 1     | RO   | 0x0         | reserved                                                                                                                                    |
| 0     | RW   | 0x0         | csi2host0_ppi_sel_2lane<br>Csi2host0 ppi select the lane0 and lane1.                                                                        |

**VI\_GRF\_VI\_SDMMC\_CON0**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable        |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                 |
| 12         | RW          | 0x0                | test_clkout_0_sel<br>clk output to io for debug<br>1'b1: cclk_in<br>1'b0: cclk_drv                                                       |
| 11         | RW          | 0x0                | drv_sel<br>cclk_in_drv source select:<br>1'b0: just use clk after phase_shift<br>1'b1: use clk after phase_shift and delayline           |
| 10:3       | RW          | 0x00               | drv_delaynum<br>The element number in delayline for cclk_in_drv                                                                          |
| 2:1        | RW          | 0x2                | drv_degree<br>SDMMC driver clock phase for phase shift:<br>2'b00: 0 degree<br>2'b01: 90 degree<br>2'b10: 180 degree<br>2'b11: 270 degree |
| 0          | RW          | 0x0                | init_state<br>Soft initial state for phase shift                                                                                         |

**VI\_GRF\_VI\_SDMMC\_CON1**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable        |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                 |
| 12         | RW          | 0x0                | test_clkout_1_sel<br>clk output to io for debug<br>1'b1: cclk_in<br>1'b0: cclk_sample                                                    |
| 11         | RW          | 0x0                | sample_sel<br>cclk_in_sample source select:<br>1'b0: just use clk after phase_shift<br>1'b1: use clk after phase_shift and delayline     |
| 10:3       | RW          | 0x00               | sample_delaynum<br>The element number used in delayline for cclk_in_sample                                                               |
| 2:1        | RW          | 0x0                | sample_degree<br>SDMMC sample clk phase for phase shift<br>2'b00: 0 degree<br>2'b01: 90 degree<br>2'b10: 180 degree<br>2'b11: 270 degree |
| 0          | RO          | 0x0                | reserved                                                                                                                                 |

**VI\_GRF\_VI\_STATUS\_CON4**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                          |
| 5          | RW          | 0x0                | vccio4_vd<br>Indicates vccio6 voltage status, vccio4_vd = 1 when VCCIO > 2.19v. vccio4_vd = 0 when VCCIO < 2.02v. |
| 4          | RW          | 0x0                | rtc_ext_off_o<br>Indicates the chip power off,high active                                                         |
| 3          | RW          | 0x0                | rtc_dig_ldo_rdy<br>Power on reset when low, reset deassert when high.                                             |
| 2          | RW          | 0x0                | isp_flash_trig<br>Hold signal for flash light                                                                     |
| 1          | RW          | 0x0                | isp_prelight_trig<br>Hold signal for prelight                                                                     |
| 0          | RW          | 0x0                | isp_shutter_open<br>Hold signal for shutter open                                                                  |

**VI GRF VI CSIPHY CONS**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:12      | RO          | 0x0                | reserved                                                                                                                          |
| 11         | RW          | 0x0                | rxbyteclkhs_1_inv_sel<br>It is used to select invert rxbyteclkhs_1.                                                               |
| 10         | RW          | 0x0                | enable_ck_1<br>D-PHY clk lane1 enable signal                                                                                      |
| 9          | RW          | 0x0                | rxbyteclkhs_0_inv_sel<br>It is used to select invert rxbyteclkhs.                                                                 |
| 8          | RW          | 0x0                | enable_ck<br>D-PHY clk lane enable signal, high active                                                                            |
| 7:4        | RW          | 0x0                | lane_enable<br>Enable lane module, This active high signal forces the lane module out of shutdown.                                |
| 3:0        | RW          | 0x0                | force_rx_mode<br>Force lane module into receive mode/wait for stop state.                                                         |

**VI GRF VI CSIPHY STATUS**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                 |
| 22:19      | RW          | 0x0                | csiphy_err_control<br>Contorl error<br>This active high signal is asserted when an incorrect line state sequence is detected. For example, if a turnaround request or escape mode request is immediately followed by a Stop state instead of the required Bridge state, this signal is asserted and remains asserted until the next change in line state |
| 18         | RW          | 0x0                | csiphy_direction<br>Transmit/Receive direction<br>This signal is used to indicate the current direction of the Lane interconnects. When pin_direction =0, the Lane is in transmit mode. When pin_direction =1, the Lane is in receive mode                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17         | RW          | 0x0                | csiphy_ulpssactivenotclk_1<br>ULP state(not) active<br>This active low signal is asserted to indicate that the Lane is in ULP state                                                       |
| 16         | RW          | 0x0                | csiphy_ulpssactivenotclk<br>ULP state(not) active<br>This active low signal is asserted to indicate that the Lane is in ULP state                                                         |
| 15         | RW          | 0x0                | csiphy_errcontentionlp1_3<br>LP1 contention error<br>This active high signal is asserted when the Lane Module detects a contention situation on a line while trying to drive the line low |
| 14         | RW          | 0x0                | csiphy_errcontentionlp0_3<br>LP0 contention error<br>This active high signal is asserted when the Lane Module detects a contention situation on a line while trying to drive the line low |
| 13         | RW          | 0x0                | csiphy_errcontentionlp1_2<br>LP1 contention error<br>This active high signal is asserted when the Lane Module detects a contention situation on a line while trying to drive the line low |
| 12         | RW          | 0x0                | csiphy_errcontentionlp0_2<br>LP0 contention error<br>This active high signal is asserted when the Lane Module detects a contention situation on a line while trying to drive the line low |
| 11         | RW          | 0x0                | csiphy_errcontentionlp1_1<br>LP1 contention error<br>This active high signal is asserted when the Lane Module detects a contention situation on a line while trying to drive the line low |
| 10         | RW          | 0x0                | csiphy_errcontentionlp0_1<br>LP0 contention error<br>This active high signal is asserted when the Lane Module detects a contention situation on a line while trying to drive the line low |
| 9          | RW          | 0x0                | csiphy_errcontentionlp1_0<br>LP1 contention error<br>This active high signal is asserted when the Lane Module detects a contention situation on a line while trying to drive the line low |
| 8          | RW          | 0x0                | csiphy_errcontentionlp0_0<br>LP0 contention error<br>This active high signal is asserted when the Lane Module detects a contention situation on a line while trying to drive the line low |
| 7:4        | RW          | 0x0                | csiphy_rxskewcalhs<br>High speed receive skew calibration<br>This optional active high signal indicates that the high speed deskew burst is being received                                |
| 3:0        | RW          | 0x0                | csiphy_ulpssactivenot<br>ULP state(not) active<br>This active low signal is asserted to indicate that the lane is in ULP state                                                            |

**VI GRF VI MEMCFG UHDSPRA**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3:2        | RW          | 0x0                | wtsel<br>Timing adjustment setting for debug purpose                                                                              |
| 1:0        | RW          | 0x1                | rtsel<br>Timing adjustment setting for debug purpose                                                                              |

**VI GRF SDMMC DET CNT**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                           |
| 21:0       | RW          | 0x0000000          | detect_cnt<br>SDMMC detect pin filter counter, in the unit of pclk |

**VI GRF SDMMC SIG DETECT CON**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                          |
| 1          | RW          | 0x0                | sig_detect_fall_en<br>Enable SDMMC detect pin falling edge irq<br>1'b0: Disable<br>1'b1: Enable                                   |
| 0          | RW          | 0x0                | sig_detect_rise_en<br>Enable SDMMC detect pin rising edge irq<br>1'b0: Disable<br>1'b1: Enable                                    |

**VI GRF SDMMC SIG DETECT STATUS**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                            |
| 1          | RW          | 0x0                | sig_detect_fall_irq<br>SDMMC detect pin falling edge irq status<br>1'b0: Not active<br>1'b1: Active |
| 0          | RW          | 0x0                | sig_detect_rise_irq<br>SDMMC detect pin rising edge irq status<br>1'b0: Not active<br>1'b1: Active  |

**VI GRF SDMMC STATUS CLR**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                          |
| 2          | RW          | 0x0                | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | sig_detect_fall_clr<br>SDMMC detect pin falling edge irq clear<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | sig_detect_rise_clr<br>SDMMC detect pin rising edge irq clear<br>1'b0: Disable<br>1'b1: Enable  |

**VI GRF SDMMC DET FLT CON**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | dtn_flt_dly<br>Delay counter setting after sdcard plug out. Counted by 24M clock. |

**VI GRF CIF CON**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:11      | RO          | 0x00               | reserved                                                                                                                          |
| 10:3       | RW          | 0x00               | clk_delaynum_m0<br>Indicates the delayline number of m0.                                                                          |
| 2          | RW          | 0x0                | datapath<br>It is used to select data from delayline or pipeline.                                                                 |
| 1          | RW          | 0x0                | clk_inv_sel_m0<br>It is used to select clkin or invert clkin of m0.                                                               |
| 0          | RW          | 0x0                | m0m1_sel<br>It is used to select io group m0 or io group m1.                                                                      |

**4.10 VO\_GRF Register Description****4.10.1 Registers Summary**

| <b>Name</b>                | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                |
|----------------------------|---------------|-------------|--------------------|-----------------------------------|
| VOGRF_GMAC_CON0            | 0x0000        | W           | 0x00000000         | GMAC controller configuration     |
| VOGRF_GMAC_CLK_CON         | 0x0004        | W           | 0x00000000         | GMAC clock configuration          |
| VOGRF_GMAC_ST              | 0x0008        | W           | 0x00000000         | GMAC status                       |
| VOGRF_TSADC_CON            | 0x000C        | W           | 0x00000000         | TSADC PHY configuration           |
| VOGRF OTP_CON              | 0x0010        | W           | 0x00000000         | OTP controller lock configuration |
| VOGRF_RGA_NOC              | 0x0014        | W           | 0x00000000         | RGA Qos configuration             |
| VOGRF_VO_MEM               | 0x0018        | W           | 0x00000001         | VO memory configuration           |
| VOGRF_SDIO_CON0            | 0x001C        | W           | 0x00000004         | SDIO configuration                |
| VOGRF_SDIO_CON1            | 0x0020        | W           | 0x00000000         | SDIO configuration                |
| VOGRF_SDIO_RAM_CLHG_AT_DIS | 0x0024        | W           | 0x00000000         | SDIO configuration                |
| VOGRF_MACPHY_CON0          | 0x0028        | W           | 0x00000000         | MAC PHY configuration             |
| VOGRF_MACPHY_CON1          | 0x002C        | W           | 0x00000000         | MAC PHY configuration             |
| VOGRF_VOP_QOS              | 0x0030        | W           | 0x00000000         | VOP Qos configuration             |

| Name                   | Offset | Size | Reset Value | Description               |
|------------------------|--------|------|-------------|---------------------------|
| VOGRF_VOP_PIPE_BYPAS_S | 0x0034 | W    | 0x00000001  | VOP IO PIPE configuration |

Notes:*Size:* **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

#### 4.10.2 Detail Registers Description

##### VOGRF\_GMAC\_CONO

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:1  | RO   | 0x0000      | reserved                                                                                                                         |
| 0     | RW   | 0x0         | sbd_flowctrl<br>Sideband signal to transmit control packet or active backpressure.                                               |

##### VOGRF\_GMAC\_CLK\_CON

Address: Operational Base + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:5  | RO   | 0x000       | reserved                                                                                                                         |
| 4     | RW   | 0x0         | clk_gmac_50_o_sel<br>1'b1: Select tx clock from CRU<br>1'b0: Select tx clock from PHY                                            |
| 3:2   | RW   | 0x0         | rmii_txclk_sel<br>Mac clock divide sel.<br>2'b00: 2.5Mhz<br>2'b01: 25Mhz<br>Others: Reserved                                     |
| 1     | RW   | 0x0         | rmii_gate_en<br>If this bit set to 1'b1, this bit will gate RMII clk.                                                            |
| 0     | RW   | 0x0         | rmii_mode<br>If using RMII mode, set this bit to 1'b1, otherwise set this bit to 1'b0.                                           |

##### VOGRF\_GMAC\_ST

Address: Operational Base + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                                                                                                                                                                |
| 4    | RO   | 0x0         | macphy_dpx_led<br>Duplex or Collision LED<br>This signal represents Duplex LED in full Duplex mode and Collision LED in Half Duplex mode,<br>1'b1: Full duplex<br>1'b0: Half duplex<br>Flash: Collision |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 3          | RO          | 0x0                | macphy_spd_led<br>Speed LED<br>1'b1: 100Mbps<br>1'b0: 10Mbps                                                  |
| 2          | RO          | 0x0                | macphy_link_led<br>Link or Activity LED<br>1'b1: Link up<br>1'b0: Link down<br>Flash: Activity                |
| 1:0        | RO          | 0x0                | mac_speed_o<br>Mac Speed indication.<br>2'b00: 1000Mbps<br>2'b01: 2500Mbps<br>2'b10: 10Mbps<br>2'b11: 100Mbps |

**VOGRF\_TSADC\_CON**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:9       | RO          | 0x00               | reserved                                                                                                                         |
| 8          | RW          | 0x0                | tsadc_tsen_en<br>TSADC enable register.<br>1'b1: Enable<br>1'b0: Disable                                                         |
| 7:0        | RW          | 0x00               | tsadc_ana_reg<br>TSADC configure registers.                                                                                      |

**VOGRF\_OTP\_CON**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable       |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                               |
| 1          | RW          | 0x0                | otpc_s_lock<br>GRF control OTP secure controller lock. This is controlled by VOSGRF_OTPC_CON[0].<br>1'b1: Lock<br>1'b0: Not lock       |
| 0          | RW          | 0x0                | otpc_ns_lock<br>GRF control OTP none secure controller lock. This is controlled by VOSGRF_OTPC_CON[0].<br>1'b1: Lock<br>1'b0: Not lock |

**VOGRF\_RGA\_NOC**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:3       | RO          | 0x0000             | reserved                                                                                                                         |
| 2:0        | RW          | 0x0                | rga_aw_qos<br>This is used to set RGA Aw_Qos for NOC.                                                                            |

**VOGRF VO MEM**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:3       | RO          | 0x0000             | reserved                                                                                                                         |
| 2          | RW          | 0x0                | wtesl<br>Configuration for wtsel for memory for RGA/VOP/GMAC.                                                                    |
| 1:0        | RW          | 0x1                | rtsel<br>Configuration for rtsel for memory for RGA/VOP/GMAC.                                                                    |

**VOGRF SDIO CON0**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable         |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                 |
| 12         | RW          | 0x0                | test_clkout_0_sel<br>1'b0: Cclk_drv<br>1'b1: Cclk_in                                                                                     |
| 11         | RW          | 0x0                | drvsel<br>cclk_in_drv source select:<br>1'b0: Just use clock after phase_shift<br>1'b1: Use clock after phase_shift and delay line       |
| 10:3       | RW          | 0x00               | drv_delaynum<br>The element number in delay line for cclk_in_drv.                                                                        |
| 2:1        | RW          | 0x2                | drv_degree<br>SDMMC driver clock phase for phase shift:<br>2'b00: 0 degree<br>2'b01: 90 degree<br>2'b10: 180 degree<br>2'b11: 270 degree |
| 0          | RW          | 0x0                | init_state<br>Soft initial state for phase shift.                                                                                        |

**VOGRF SDIO CON1**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:13      | RO          | 0x0                | reserved                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | test_clkout_1_sel<br>1'b0: Cclk_drv<br>1'b1: Cclk_in                                                                                        |
| 11         | RW          | 0x0                | sample_sel<br>cclk_in_sample source select:<br>1'b0: Just use clock after phase_shift<br>1'b1: Use clock after phase_shift and delay line   |
| 10:3       | RW          | 0x00               | sample_delaynum<br>The element number in delay line for cclk_in_drv.                                                                        |
| 2:1        | RW          | 0x0                | sample_degree<br>SDMMC sample clock phase for phase shift:<br>2'b00: 0 degree<br>2'b01: 90 degree<br>2'b10: 180 degree<br>2'b11: 270 degree |
| 0          | RO          | 0x0                | reserved                                                                                                                                    |

**VOGRF SDIO RAM CLHGAT DIS**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                         |
| 0          | RW          | 0x0                | ram_clkgate_disable<br>Disable SDIO memory clock gate.<br>1'b1: Disable<br>1'b0: Enable                                          |

**VOGRF MACPHY CON0**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                               |
| 15         | RW          | 0x0                | led_pol<br>Reserved                                                                                                                                                            |
| 14:10      | RW          | 0x00               | id<br>PHY Address                                                                                                                                                              |
| 9:7        | RW          | 0x0                | clksel<br>Reference clock select, only support 3'h6.                                                                                                                           |
| 6:5        | RW          | 0x0                | xmii_sel<br>SMI and MII/RMII interface selection<br>2'b00: Internal SMI and MII<br>2'b01: External SMI and MII<br>2'b10: Internal SMI and RMII<br>2'b11: External SMI and RMII |
| 4          | RW          | 0x0                | fxen<br>Reserved                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x0                | mode<br>Operation mode selection<br>2'b00: Normal mode<br>2'b01: Sim mode (not used)<br>2'b10: AFE test mode<br>2'b11: Reserved |
| 1          | RW          | 0x0                | shutdown<br>Analog block shutdown<br>1'b1: Shutdown<br>1'b0: Power up                                                           |
| 0          | RW          | 0x0                | smi_sel<br>Reserved                                                                                                             |

**VOGRF MACPHY CON1**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                         |
| 3:0        | RW          | 0x0                | bgs<br>Band Gap Selection.                                                                                                       |

**VOGRF VOP QOS**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:10      | RO          | 0x00               | reserved                                                                                                                         |
| 9          | RW          | 0x0                | vop_arqos_sel<br>1'b1: Sel grf_vop_ar_qos<br>1'b0: Sel VOP controller in bit[2:1] and vop_arqos_bit0 in bit[0].                  |
| 8          | RW          | 0x0                | vop_awqos_sel<br>1'b1: Sel grf_vop_aw_qos<br>1'b0: Sel VOP controller in bit[2:1] and vop_awqos_bit0 in bit[0].                  |
| 7          | RW          | 0x0                | vop_arqos_bit0<br>This is the supplement for VOP Ar_Qos in bit 0, this only used when vop_arqos_sel=1'b0.                        |
| 6          | RW          | 0x0                | vop_awqos_bit0<br>This is the supplement for VOP Aw_Qos in bit 0, this only used when vop_awqos_sel=1'b0.                        |
| 5:3        | RW          | 0x0                | grf_vop_aw_qos<br>GRF control Aw_Qos for VOP, this only used when vop_awqos_sel=1'b1.                                            |
| 2:0        | RW          | 0x0                | grf_vop_ar_qos<br>GRF control Ar_Qos for VOP, this only used when vop_arqos_sel=1'b1.                                            |

**VOGRF VOP PIPE BYPASS**

Address: Operational Base + offset (0x0034)

| Bit   | Attr | Reset Value | Description                                                                                                                                               |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bit, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                          |
| 15:1  | RO   | 0x0000      | reserved                                                                                                                                                  |
| 1:0   | RW   | 0x3         | vop_pipe_bypass<br>2'b00: Use two flip-flop pipe in VOP LCD IO in vccio5.<br>2'b11: Bypass two flip-flop pipe in VOP LCD IO in vccio5.<br>Other: Reserved |

## 4.11 GPIO0\_IOC Register Description

### 4.11.1 Registers Summary

| Name                                 | Offset | Size | Reset Value | Description                                         |
|--------------------------------------|--------|------|-------------|-----------------------------------------------------|
| <u>GPIO0_IOC_GPIO0A_IOM_UX_SEL_L</u> | 0x0000 | W    | 0x00000000  | GPIO0A iomux configuration register 0               |
| <u>GPIO0_IOC_GPIO0A_IOM_UX_SEL_H</u> | 0x0004 | W    | 0x00000000  | GPIO0A iomux configuration register 1               |
| <u>GPIO0_IOC_GPIO0A_DS0</u>          | 0x0010 | W    | 0x00000101  | GPIO0A drive strength register 0                    |
| <u>GPIO0_IOC_GPIO0A_DS1</u>          | 0x0014 | W    | 0x00000101  | GPIO0A drive strength register 1                    |
| <u>GPIO0_IOC_GPIO0A_DS2</u>          | 0x0018 | W    | 0x00000101  | GPIO0A drive strength register 2                    |
| <u>GPIO0_IOC_GPIO0A_DS3</u>          | 0x001C | W    | 0x00000001  | GPIO0A drive strength register 3                    |
| <u>GPIO0_IOC_GPIO0A_IE</u>           | 0x0030 | W    | 0x0000007F  | GPIO0A input enable register                        |
| <u>GPIO0_IOC_GPIO0A_P</u>            | 0x0038 | W    | 0x00002A68  | GPIO0A pull up and pull down configuration register |
| <u>GPIO0_IOC_GPIO0A_SUS</u>          | 0x0040 | W    | 0x00000000  | GPIO0A keeper configuration register                |
| <u>GPIO0_IOC_GPIO0A_SL</u>           | 0x0048 | W    | 0x00003FFF  | GPIO0A skew rate register                           |
| <u>GPIO0_IOC_GPIO0A_IE_S_MT</u>      | 0x0058 | W    | 0x0000007F  | GPIO0A Schmitt trigger register                     |
| <u>GPIO0_IOC_GPIO0A_OD</u>           | 0x0068 | W    | 0x00000000  | GPIO0A open drain register                          |

Notes:Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 4.11.2 Detail Registers Description

#### GPIO0\_IOC\_GPIO0A\_IOMUX\_SEL\_L

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15    | RO   | 0x0         | reserved                                                                                                                          |
| 14:12 | RW   | 0x0         | gpio0a3_sel<br>3'h0: GPIO0A3<br>3'h1: PMIC_SLEEP_M1<br>Others: Reserved                                                           |
| 11    | RO   | 0x0         | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RW          | 0x0                | gpio0a2_sel<br>3'h0: GPIO0A2<br>3'h1: PWM3_IR_M0<br>3'h3: TEST_CLK7_OUT<br>Others: Reserved                                   |
| 7          | RO          | 0x0                | reserved                                                                                                                      |
| 6:4        | RW          | 0x0                | gpio0a1_sel<br>3'h0: GPIO0A1<br>3'h1: UART0_TX_M0<br>3'h2: PWM2_M0<br>3'h3: TEST_CLK6_OUT<br>Others: Reserved                 |
| 3          | RO          | 0x0                | reserved                                                                                                                      |
| 2:0        | RW          | 0x0                | gpio0a0_sel<br>3'h0: GPIO0A0<br>3'h1: UART0_RX_M0<br>3'h2: CLK_32K<br>3'h3: CLK_REF_OUT<br>3'h4: RTC_CLKO<br>Others: Reserved |

**GPIO0\_IOC\_GPIO0A\_IOMUX\_SEL\_H**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:11      | RO          | 0x00               | reserved                                                                                                                         |
| 10:8       | RW          | 0x0                | gpio0a6_sel<br>3'h0: GPIO0A6<br>3'h1: I2C1_SDA_M0<br>3'h2: UART1_CTSN_M0<br>3'h3: PWM6_M0<br>Others: Reserved                    |
| 7          | RO          | 0x0                | reserved                                                                                                                         |
| 6:4        | RW          | 0x0                | gpio0a5_sel<br>3'h0: GPIO0A5<br>3'h1: I2C1_SCL_M0<br>3'h2: UART1_RTSN_M0<br>3'h3: PWM5_M0<br>Others: Reserved                    |
| 3          | RO          | 0x0                | reserved                                                                                                                         |
| 2:0        | RW          | 0x0                | gpio0a4_sel<br>3'h0: GPIO0A4<br>3'h1: PMIC_SLEEP_M0<br>3'h2: PWM1_M0<br>Others: Reserved                                         |

**GPIO0\_IOC\_GPIO0A\_DS0**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x01               | gpio0a1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x01               | gpio0a0_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO0 IOC GPIO0A DS1**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x01               | gpio0a3_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x01               | gpio0a2_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO0 IOC GPIO0A DS2**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x01               | gpio0a5_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x01               | gpio0a4_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO0 IOC GPIO0A DS3**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:6       | RO          | 0x000              | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x01               | gpio0a6_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO0 IOC GPIO0A IE**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                          |
| 6          | RW          | 0x1                | gpio0a6_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 5          | RW          | 0x1                | gpio0a5_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 4          | RW          | 0x1                | gpio0a4_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 3          | RW          | 0x1                | gpio0a3_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 2          | RW          | 0x1                | gpio0a2_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 1          | RW          | 0x1                | gpio0a1_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 0          | RW          | 0x1                | gpio0a0_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |

**GPIO0 IOC GPIO0A P**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 13         | RW          | 0x1                | gpio0a6_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 12         | RW          | 0x0                | gpio0a6_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |
| 11         | RW          | 0x1                | gpio0a5_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 10         | RW          | 0x0                | gpio0a5_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |
| 9          | RW          | 0x1                | gpio0a4_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 8          | RW          | 0x0                | gpio0a4_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |
| 7          | RW          | 0x0                | gpio0a3_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 6          | RW          | 0x1                | gpio0a3_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |
| 5          | RW          | 0x1                | gpio0a2_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 4          | RW          | 0x0                | gpio0a2_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |
| 3          | RW          | 0x1                | gpio0a1_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x0                | gpio0a1_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |
| 1          | RW          | 0x0                | gpio0a0_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | gpio0a0_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |

**GPIO0 IOC GPIO0A SUS**

Address: Operational Base + offset (0x0040)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7  | RO   | 0x000       | reserved                                                                                                                          |
| 6     | RW   | 0x0         | gpio0a6_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 5     | RW   | 0x0         | gpio0a5_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 4     | RW   | 0x0         | gpio0a4_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 3     | RW   | 0x0         | gpio0a3_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 2     | RW   | 0x0         | gpio0a2_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 1     | RW   | 0x0         | gpio0a1_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 0     | RW   | 0x0         | gpio0a0_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |

**GPIO0 IOC GPIO0A SL**

Address: Operational Base + offset (0x0048)

| Bit   | Attr | Reset Value | Description                                                                                                                                                   |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                      |
| 13:12 | RW   | 0x3         | gpio0a6_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 11:10 | RW   | 0x3         | gpio0a5_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x3                | gpio0a4_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 7:6        | RW          | 0x3                | gpio0a3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 5:4        | RW          | 0x3                | gpio0a2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 3:2        | RW          | 0x3                | gpio0a1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 1:0        | RW          | 0x3                | gpio0a0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

**GPIO0 IOC GPIO0A IE SMT**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                          |
| 6          | RW          | 0x1                | gpio0a6_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 5          | RW          | 0x1                | gpio0a5_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 4          | RW          | 0x1                | gpio0a4_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 3          | RW          | 0x1                | gpio0a3_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 2          | RW          | 0x1                | gpio0a2_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 1          | RW          | 0x1                | gpio0a1_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 0          | RW          | 0x1                | gpio0a0_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable |

**GPIO0\_IOC\_GPIO0A\_OD**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                          |
| 6          | RW          | 0x0                | gpio0a6_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 5          | RW          | 0x0                | gpio0a5_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 4          | RW          | 0x0                | gpio0a4_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 3          | RW          | 0x0                | gpio0a3_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 2          | RW          | 0x0                | gpio0a2_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 1          | RW          | 0x0                | gpio0a1_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 0          | RW          | 0x0                | gpio0a0_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |

**4.12 GPIO1\_IOC Register Description**

| <b>Name</b>                          | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>        |
|--------------------------------------|---------------|-------------|--------------------|---------------------------|
| <u>GPIO1_IOC_GPIO1A_IOM_UX_SEL_L</u> | 0x0000        | W           | 0x00000000         | GPIO1 iomux configuration |
| <u>GPIO1_IOC_GPIO1A_IOM_UX_SEL_H</u> | 0x0004        | W           | 0x00000000         | GPIO1 iomux configuration |
| <u>GPIO1_IOC_GPIO1B_IOM_UX_SEL_L</u> | 0x0008        | W           | 0x00000000         | GPIO1 iomux configuration |
| <u>GPIO1_IOC_GPIO1C_IOM_UX_SEL_L</u> | 0x0010        | W           | 0x00000000         | GPIO1 iomux configuration |
| <u>GPIO1_IOC_GPIO1C_IOM_UX_SEL_H</u> | 0x0014        | W           | 0x00000000         | GPIO1 iomux configuration |
| <u>GPIO1_IOC_GPIO1D_IOM_UX_SEL_L</u> | 0x0018        | W           | 0x00000000         | GPIO1 iomux configuration |
| <u>GPIO1_IOC_GPIO1A_DS0</u>          | 0x0080        | W           | 0x00000101         | GPIO1 drive strength      |
| <u>GPIO1_IOC_GPIO1A_DS1</u>          | 0x0084        | W           | 0x00000103         | GPIO1 drive strength      |

| Name                      | Offset | Size | Reset Value | Description                               |
|---------------------------|--------|------|-------------|-------------------------------------------|
| GPIO1 IOC GPIO1A DS2      | 0x0088 | W    | 0x00000001  | GPIO1 drive strength                      |
| GPIO1 IOC GPIO1B DS0      | 0x0090 | W    | 0x00000301  | GPIO1 drive strength                      |
| GPIO1 IOC GPIO1B DS1      | 0x0094 | W    | 0x00000101  | GPIO1 drive strength                      |
| GPIO1 IOC GPIO1C DS0      | 0x00A0 | W    | 0x00000707  | GPIO1 drive strength                      |
| GPIO1 IOC GPIO1C DS1      | 0x00A4 | W    | 0x00000707  | GPIO1 drive strength                      |
| GPIO1 IOC GPIO1C DS2      | 0x00A8 | W    | 0x00000707  | GPIO1 drive strength                      |
| GPIO1 IOC GPIO1C DS3      | 0x00AC | W    | 0x00000707  | GPIO1 drive strength                      |
| GPIO1 IOC GPIO1D DS0      | 0x00B0 | W    | 0x00000707  | GPIO1 drive strength                      |
| GPIO1 IOC GPIO1D DS1      | 0x00B4 | W    | 0x00000F07  | GPIO1 drive strength                      |
| GPIO1 IOC GPIO1A IE       | 0x0180 | W    | 0x0000001F  | GPIO1 input enable                        |
| GPIO1 IOC GPIO1B IE       | 0x0184 | W    | 0x0000000F  | GPIO1 input enable                        |
| GPIO1 IOC GPIO1C IE       | 0x0188 | W    | 0x000000FF  | GPIO1 input enable                        |
| GPIO1 IOC GPIO1D IE       | 0x018C | W    | 0x0000000F  | GPIO1 input enable                        |
| GPIO1 IOC GPIO1A P        | 0x01C0 | W    | 0x000002AA  | GPIO1 pull up and pull down configuration |
| GPIO1 IOC GPIO1B P        | 0x01C4 | W    | 0x000000AA  | GPIO1 pull up and pull down configuration |
| GPIO1 IOC GPIO1C P        | 0x01C8 | W    | 0x0000AAAA  | GPIO1 pull up and pull down configuration |
| GPIO1 IOC GPIO1D P        | 0x01CC | W    | 0x000000AA  | GPIO1 pull up and pull down configuration |
| GPIO1 IOC GPIO1A SUS      | 0x0200 | W    | 0x00000000  | GPIO1 keeper configuration                |
| GPIO1 IOC GPIO1B SUS      | 0x0204 | W    | 0x00000000  | GPIO1 keeper configuration                |
| GPIO1 IOC GPIO1C SUS      | 0x0208 | W    | 0x00000000  | GPIO1 keeper configuration                |
| GPIO1 IOC GPIO1D SUS      | 0x020C | W    | 0x00000000  | GPIO1 keeper configuration                |
| GPIO1 IOC GPIO1A SL       | 0x0240 | W    | 0x000003FF  | GPIO1 skew rate                           |
| GPIO1 IOC GPIO1B SL       | 0x0244 | W    | 0x000000FF  | GPIO1 skew rate                           |
| GPIO1 IOC GPIO1C SL       | 0x0248 | W    | 0x0000FFFF  | GPIO1 skew rate                           |
| GPIO1 IOC GPIO1D SL       | 0x024C | W    | 0x000000FF  | GPIO1 skew rate                           |
| GPIO1 IOC GPIO1A IE SMT   | 0x0280 | W    | 0x0000001F  | GPIO1 Schmitt trigger                     |
| GPIO1 IOC GPIO1B IE SMT   | 0x0284 | W    | 0x0000000F  | GPIO1 Schmitt trigger                     |
| GPIO1 IOC GPIO1C IE SMT   | 0x0288 | W    | 0x000000FF  | GPIO1 Schmitt trigger                     |
| GPIO1 IOC GPIO1D IE SMT   | 0x028C | W    | 0x0000000F  | GPIO1 Schmitt trigger                     |
| GPIO1 IOC GPIO1A OD       | 0x02C0 | W    | 0x00000000  | GPIO1 open drain                          |
| GPIO1 IOC GPIO1B OD       | 0x02C4 | W    | 0x00000000  | GPIO1 open drain                          |
| GPIO1 IOC GPIO1C OD       | 0x02C8 | W    | 0x00000000  | GPIO1 open drain                          |
| GPIO1 IOC GPIO1D OD       | 0x02CC | W    | 0x00000000  | GPIO1 open drain                          |
| GPIO1 IOC FORCE JTAG UART | 0x02F4 | W    | 0x00000001  | GPIO1 force jtag                          |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

#### 4.12.1 Detail Registers Description

##### GPIO1 IOC GPIO1A IOMUX SEL\_L

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 15         | RO          | 0x0                | reserved                                                                                                |
| 14:12      | RW          | 0x0                | gpio1a3_sel<br>3'h0: GPIO<br>3'h1: UART1_TX_M0<br>3'h2: I2C0_SCL_M0                                     |
| 11         | RO          | 0x0                | reserved                                                                                                |
| 10:8       | RW          | 0x0                | gpio1a2_sel<br>3'h0: GPIO<br>3'h1: PWM0_M0<br>3'h2: AVS_ARM<br>3'h3: VICAP_D0_M1                        |
| 7          | RO          | 0x0                | reserved                                                                                                |
| 6:4        | RW          | 0x0                | gpio1a1_sel<br>3'h0: GPIO<br>3'h1: UART3_RX_M0<br>3'h2: I2C2_SDA_M0<br>3'h3: PMU_DEBUG<br>3'h4: PWM4_M0 |
| 3          | RO          | 0x0                | reserved                                                                                                |
| 2:0        | RW          | 0x0                | gpio1a0_sel<br>3'h0: GPIO<br>3'h1: UART3_TX_M0<br>3'h2: I2C2_SCL_M0<br>3'h3: PWM7_IR_M0                 |

**GPIO1 IOC GPIO1A IOMUX SEL\_H**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:3       | RO          | 0x0000             | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio1a4_sel<br>3'h0: GPIO<br>3'h1: UART1_RX_M0<br>3'h2: I2C0_SDA_M0                                                               |

**GPIO1 IOC GPIO1B IOMUX SEL\_L**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RO          | 0x0                | reserved                                                                                                                          |
| 14:12      | RW          | 0x0                | gpio1b3_sel<br>3'h0: GPIO<br>3'h1: A7_JTAG_TMS_M1<br>3'h2: UART2_RX_M1<br>3'h3: HPMCU_JTAG_TMS_M0<br>3'h4: LPMCU_JTAG_TMS_M0      |
| 11         | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RW          | 0x0                | gpio1b2_sel<br>3'h0: GPIO<br>3'h1: A7_JTAG_TCK_M1<br>3'h2: UART2_TX_M1<br>3'h3: HPMCU_JTAG_TCK_M0<br>3'h4: LPMCU_JTAG_TCK_M0 |
| 7          | RO          | 0x0                | reserved                                                                                                                     |
| 6:4        | RW          | 0x0                | gpio1b1_sel<br>3'h0: GPIO<br>3'h1: UART4_TX_M0<br>3'h2: PWM7_IR_M1<br>3'h3: SPI1_CS1N_M0<br>3'h4: VICAP_D1_M1                |
| 3          | RO          | 0x0                | reserved                                                                                                                     |
| 2:0        | RW          | 0x0                | gpio1b0_sel<br>3'h0: GPIO<br>3'h1: UART4_RX_M0<br>3'h2: PWM3_IR_M1                                                           |

**GPIO1\_IOC GPIO1C\_IOMUX\_SEL\_L**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                 |
| 15         | RO          | 0x0                | reserved                                                                                                                                          |
| 14:12      | RW          | 0x0                | gpio1c3_sel<br>3'h0: GPIO<br>3'h1: LCD_D4<br>3'h2: VICAP_D5_M1<br>3'h3: PWM6_M2<br>3'h4: I2C4_SDA_M1<br>3'h5: SDMMC1_CMD_M1<br>3'h6: SPI0_MISO_M0 |
| 11         | RO          | 0x0                | reserved                                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio1c2_sel<br>3'h0: GPIO<br>3'h1: LCD_D5<br>3'h2: VICAP_D4_M1<br>3'h3: PWM5_M2<br>3'h4: I2C4_SCL_M1<br>3'h5: SDMMC1_CLK_M1<br>3'h6: SPI0_MOSI_M0 |
| 7          | RO          | 0x0                | reserved                                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio1c1_sel<br>3'h0: GPIO<br>3'h1: LCD_D6<br>3'h2: VICAP_D3_M1<br>3'h3: PWM4_M2<br>3'h4: SPI0_CLK_M0<br>3'h5: SDMMC1_D0_M1                        |
| 3          | RO          | 0x0                | reserved                                                                                                                                          |

| Bit | Attr | Reset Value | Description                                                                                                                 |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| 2:0 | RW   | 0x0         | gpio1c0_sel<br>3'h0: GPIO<br>3'h1: LCD_D7<br>3'h2: VICAP_D2_M1<br>3'h3: PWM2_M2<br>3'h4: SPI0_CS0N_M0<br>3'h5: SDMMC1_D1_M1 |

**GPIO1 IOC GPIO1C IOMUX SEL\_H**

Address: Operational Base + offset (0x0014)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15    | RO   | 0x0         | reserved                                                                                                                          |
| 14:12 | RW   | 0x0         | gpio1c7_sel<br>3'h0: GPIO<br>3'h1: LCD_D0<br>3'h2: VICAP_D9_M1<br>3'h3: PWM11_IR_M1<br>3'h4: UART4_CTSN_M1                        |
| 11    | RO   | 0x0         | reserved                                                                                                                          |
| 10:8  | RW   | 0x0         | gpio1c6_sel<br>3'h0: GPIO<br>3'h1: LCD_D1<br>3'h2: VICAP_D8_M1<br>3'h3: PWM10_M1<br>3'h4: UART4_RTSN_M1                           |
| 7     | RO   | 0x0         | reserved                                                                                                                          |
| 6:4   | RW   | 0x0         | gpio1c5_sel<br>3'h0: GPIO<br>3'h1: LCD_D2<br>3'h2: VICAP_D7_M1<br>3'h3: PWM9_M1<br>3'h4: UART4_TX_M1<br>3'h5: SDMMC1_D2_M1        |
| 3     | RO   | 0x0         | reserved                                                                                                                          |
| 2:0   | RW   | 0x0         | gpio1c4_sel<br>3'h0: GPIO<br>3'h1: LCD_D3<br>3'h2: VICAP_D6_M1<br>3'h3: PWM8_M1<br>3'h4: UART4_RX_M1<br>3'h5: SDMMC1_D3_M1        |

**GPIO1 IOC GPIO1D IOMUX SEL\_L**

Address: Operational Base + offset (0x0018)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15    | RO   | 0x0         | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:12      | RW          | 0x0                | gpio1d3_sel<br>3'h0: GPIO<br>3'h1: LCD_CLK<br>3'h2: VICAP_CLKOUT_M1<br>3'h3: I2C3_SCL_M1<br>3'h4: UART5_TX_M1<br>3'h5: PWM11_IR_M2<br>3'h6: Reserved<br>3'h7: DSMAUDIO_N  |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                  |
| 10:8       | RW          | 0x0                | gpio1d2_sel<br>3'h0: GPIO<br>3'h1: LCD_VSYNC<br>3'h2: VICAP_VSYNC_M1<br>3'h3: I2C3_SDA_M1<br>3'h4: UART5_RX_M1<br>3'h5: SPI0_CS1N_M0<br>3'h6: PWM0_M1<br>3'h7: DSMAUDIO_P |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                  |
| 6:4        | RW          | 0x0                | gpio1d1_sel<br>3'h0: GPIO<br>3'h1: LCD_HSYNC<br>3'h2: VICAP_HSYNC_M1<br>3'h3: PWM10_M2<br>3'h4: UART5_CTSN_M1<br>3'h5: UART3_RX_M1                                        |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                  |
| 2:0        | RW          | 0x0                | gpio1d0_sel<br>3'h0: GPIO<br>3'h1: LCD_DEN<br>3'h2: VICAP_CLKIN_M1<br>3'h3: PWM3_IR_M2<br>3'h4: UART5_RTSN_M1<br>3'h5: UART3_TX_M1                                        |

**GPIO1 IOC GPIO1A DS0**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x01               | gpio1a1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x01               | gpio1a0_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1A DS1**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x01               | gpio1a3_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x03               | gpio1a2_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1A DS2**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:6       | RO          | 0x000              | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x01               | gpio1a4_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1B DS0**

Address: Operational Base + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x03               | gpio1b1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x01               | gpio1b0_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1B DS1**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x01               | gpio1b3_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x01               | gpio1b2_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1C DS0**

Address: Operational Base + offset (0x00A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x07               | gpio1c1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x07               | gpio1c0_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1C DS1**

Address: Operational Base + offset (0x00A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x07               | gpio1c3_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x07               | gpio1c2_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1C DS2**

Address: Operational Base + offset (0x00A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x07               | gpio1c5_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x07               | gpio1c4_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1C DS3**

Address: Operational Base + offset (0x00AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x07               | gpio1c7_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x07               | gpio1c6_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1D DS0**

Address: Operational Base + offset (0x00B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x07               | gpio1d1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x07               | gpio1d0_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1D DS1**

Address: Operational Base + offset (0x00B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x0f               | gpio1d3_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x07               | gpio1d2_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO1 IOC GPIO1A IE**

Address: Operational Base + offset (0x0180)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:5       | RO          | 0x000              | reserved                                                                                                                          |
| 4          | RW          | 0x1                | gpio1a4_ie<br>GPIO1A4 IE control<br>Active High input buffer enable                                                               |
| 3          | RW          | 0x1                | gpio1a3_ie<br>GPIO1A3 IE control<br>Active High input buffer enable                                                               |
| 2          | RW          | 0x1                | gpio1a2_ie<br>GPIO1A2 IE control<br>Active High input buffer enable                                                               |
| 1          | RW          | 0x1                | gpio1a1_ie<br>GPIO1A1 IE control<br>Active High input buffer enable                                                               |
| 0          | RW          | 0x1                | gpio1a0_ie<br>GPIO1A0 IE control<br>Active High input buffer enable                                                               |

**GPIO1 IOC GPIO1B IE**

Address: Operational Base + offset (0x0184)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x1                | gpio1b3_ie<br>GPIO1B3 IE control<br>Active High input buffer enable                                                               |
| 2          | RW          | 0x1                | gpio1b2_ie<br>GPIO1B2 IE control<br>Active High input buffer enable                                                               |
| 1          | RW          | 0x1                | gpio1b1_ie<br>GPIO1B1 IE control<br>Active High input buffer enable                                                               |
| 0          | RW          | 0x1                | gpio1b0_ie<br>GPIO1B0 IE control<br>Active High input buffer enable                                                               |

**GPIO1 IOC GPIO1C IE**

Address: Operational Base + offset (0x0188)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8  | RO   | 0x00        | reserved                                                                                                                          |
| 7     | RW   | 0x1         | gpio1c7_ie<br>GPIO1C7 IE control<br>Active High input buffer enable                                                               |
| 6     | RW   | 0x1         | gpio1c6_ie<br>GPIO1C6 IE control<br>Active High input buffer enable                                                               |
| 5     | RW   | 0x1         | gpio1c5_ie<br>GPIO1C5 IE control<br>Active High input buffer enable                                                               |
| 4     | RW   | 0x1         | gpio1c4_ie<br>GPIO1C4 IE control<br>Active High input buffer enable                                                               |
| 3     | RW   | 0x1         | gpio1c3_ie<br>GPIO1C3 IE control<br>Active High input buffer enable                                                               |
| 2     | RW   | 0x1         | gpio1c2_ie<br>GPIO1C2 IE control<br>Active High input buffer enable                                                               |
| 1     | RW   | 0x1         | gpio1c1_ie<br>GPIO1C1 IE control<br>Active High input buffer enable                                                               |
| 0     | RW   | 0x1         | gpio1c0_ie<br>GPIO1C0 IE control<br>Active High input buffer enable                                                               |

**GPIO1 IOC GPIO1D IE**

Address: Operational Base + offset (0x018C)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4  | RO   | 0x000       | reserved                                                                                                                          |
| 3     | RW   | 0x1         | gpio1d3_ie<br>GPIO1D4 IE control<br>Active High input buffer enable                                                               |
| 2     | RW   | 0x1         | gpio1d2_ie<br>GPIO1D2 IE control<br>Active High input buffer enable                                                               |
| 1     | RW   | 0x1         | gpio1d1_ie<br>GPIO1D1 IE control<br>Active High input buffer enable                                                               |
| 0     | RW   | 0x1         | gpio1d0_ie<br>GPIO1D0 IE control<br>Active High input buffer enable                                                               |

**GPIO1 IOC GPIO1A P**

Address: Operational Base + offset (0x01C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:10      | RO          | 0x00               | reserved                                                                                                                          |
| 9          | RW          | 0x1                | gpio1a4_pd<br>Active High. Weak pull down for pad.                                                                                |
| 8          | RW          | 0x0                | gpio1a4_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 7          | RW          | 0x1                | gpio1a3_pd<br>Active High. Weak pull down for pad.                                                                                |
| 6          | RW          | 0x0                | gpio1a3_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 5          | RW          | 0x1                | gpio1a2_pd<br>Active High. Weak pull down for pad.                                                                                |
| 4          | RW          | 0x0                | gpio1a2_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 3          | RW          | 0x1                | gpio1a1_pd<br>Active High. Weak pull down for pad.                                                                                |
| 2          | RW          | 0x0                | gpio1a1_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 1          | RW          | 0x1                | gpio1a0_pd<br>Active High. Weak pull down for pad.                                                                                |
| 0          | RW          | 0x0                | gpio1a0_pu<br>Active High. Weak pull up for pad.                                                                                  |

**GPIO1\_IOC\_GPIO1B\_P**

Address: Operational Base + offset (0x01C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio1b3_pd<br>Active High. Weak pull down for pad.                                                                                |
| 6          | RW          | 0x0                | gpio1b3_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 5          | RW          | 0x1                | gpio1b2_pd<br>Active High. Weak pull down for pad.                                                                                |
| 4          | RW          | 0x0                | gpio1b2_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 3          | RW          | 0x1                | gpio1b1_pd<br>Active High. Weak pull down for pad.                                                                                |
| 2          | RW          | 0x0                | gpio1b1_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 1          | RW          | 0x1                | gpio1b0_pd<br>Active High. Weak pull down for pad.                                                                                |
| 0          | RW          | 0x0                | gpio1b0_pu<br>Active High. Weak pull up for pad.                                                                                  |

**GPIO1\_IOC\_GPIO1C\_P**

Address: Operational Base + offset (0x01C8)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x1                | gpio1c7_pd<br>Active High. Weak pull down for pad.                                                                                |
| 14         | RW          | 0x0                | gpio1c7_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 13         | RW          | 0x1                | gpio1c6_pd<br>Active High. Weak pull down for pad.                                                                                |
| 12         | RW          | 0x0                | gpio1c6_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 11         | RW          | 0x1                | gpio1c5_pd<br>Active High. Weak pull down for pad.                                                                                |
| 10         | RW          | 0x0                | gpio1c5_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 9          | RW          | 0x1                | gpio1c4_pd<br>Active High. Weak pull down for pad.                                                                                |
| 8          | RW          | 0x0                | gpio1c4_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 7          | RW          | 0x1                | gpio1c3_pd<br>Active High. Weak pull down for pad.                                                                                |
| 6          | RW          | 0x0                | gpio1c3_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 5          | RW          | 0x1                | gpio1c2_pd<br>Active High. Weak pull down for pad.                                                                                |
| 4          | RW          | 0x0                | gpio1c2_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 3          | RW          | 0x1                | gpio1c1_pd<br>Active High. Weak pull down for pad.                                                                                |
| 2          | RW          | 0x0                | gpio1c1_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 1          | RW          | 0x1                | gpio1c0_pd<br>Active High. Weak pull down for pad.                                                                                |
| 0          | RW          | 0x0                | gpio1c0_pu<br>Active High. Weak pull up for pad.                                                                                  |

**GPIO1 IOC GPIO1D P**

Address: Operational Base + offset (0x01CC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio1d3_pd<br>Active High. Weak pull down for pad.                                                                                |
| 6          | RW          | 0x0                | gpio1d3_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 5          | RW          | 0x1                | gpio1d2_pd<br>Active High. Weak pull down for pad.                                                                                |
| 4          | RW          | 0x0                | gpio1d2_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 3          | RW          | 0x1                | gpio1d1_pd<br>Active High. Weak pull down for pad.                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 2          | RW          | 0x0                | gpio1d1_pu<br>Active High. Weak pull up for pad.   |
| 1          | RW          | 0x1                | gpio1d0_pd<br>Active High. Weak pull down for pad. |
| 0          | RW          | 0x0                | gpio1d0_pu<br>Active High. Weak pull up for pad.   |

**GPIO1 IOC GPIO1A SUS**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:5       | RO          | 0x000              | reserved                                                                                                                          |
| 4          | RW          | 0x0                | gpio1a4_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 3          | RW          | 0x0                | gpio1a3_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 2          | RW          | 0x0                | gpio1a2_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 1          | RW          | 0x0                | gpio1a1_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 0          | RW          | 0x0                | gpio1a0_sus<br>Active High. Weak pull keeper for pad.                                                                             |

**GPIO1 IOC GPIO1B SUS**

Address: Operational Base + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x0                | gpio1b3_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 2          | RW          | 0x0                | gpio1b2_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 1          | RW          | 0x0                | gpio1b1_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 0          | RW          | 0x0                | gpio1b0_sus<br>Active High. Weak pull keeper for pad.                                                                             |

**GPIO1 IOC GPIO1C SUS**

Address: Operational Base + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x0                | gpio1c7_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 6          | RW          | 0x0                | gpio1c6_sus<br>Active High. Weak pull keeper for pad.                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 5          | RW          | 0x0                | gpio1c5_sus<br>Active High. Weak pull keeper for pad. |
| 4          | RW          | 0x0                | gpio1c4_sus<br>Active High. Weak pull keeper for pad. |
| 3          | RW          | 0x0                | gpio1c3_sus<br>Active High. Weak pull keeper for pad. |
| 2          | RW          | 0x0                | gpio1c2_sus<br>Active High. Weak pull keeper for pad. |
| 1          | RW          | 0x0                | gpio1c1_sus<br>Active High. Weak pull keeper for pad. |
| 0          | RW          | 0x0                | gpio1c0_sus<br>Active High. Weak pull keeper for pad. |

**GPIO1 IOC GPIO1D SUS**

Address: Operational Base + offset (0x020C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x0                | gpio1d3_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 2          | RW          | 0x0                | gpio1d2_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 1          | RW          | 0x0                | gpio1d1_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 0          | RW          | 0x0                | gpio1d0_sus<br>Active High. Weak pull keeper for pad.                                                                             |

**GPIO1 IOC GPIO1A SL**

Address: Operational Base + offset (0x0240)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:10      | RO          | 0x00               | reserved                                                                                                                                                      |
| 9:8        | RW          | 0x3                | gpio1a4_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 7:6        | RW          | 0x3                | gpio1a3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 5:4        | RW          | 0x3                | gpio1a2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 3:2        | RW          | 0x3                | gpio1a1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x3                | gpio1a0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

**GPIO1\_IOC\_GPIO1B\_SL**

Address: Operational Base + offset (0x0244)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                      |
| 7:6        | RW          | 0x3                | gpio1b3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 5:4        | RW          | 0x3                | gpio1b2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 3:2        | RW          | 0x3                | gpio1b1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 1:0        | RW          | 0x3                | gpio1b0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

**GPIO1\_IOC\_GPIO1C\_SL**

Address: Operational Base + offset (0x0248)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                                                                                                                      |
| 17:16      | RW          | 0x0                | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:14      | RW          | 0x3                | gpio1c7_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 13:12      | RW          | 0x3                | gpio1c6_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 11:10      | RW          | 0x3                | gpio1c5_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 9:8        | RW          | 0x3                | gpio1c4_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6        | RW          | 0x3                | gpio1c3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 5:4        | RW          | 0x3                | gpio1c2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 3:2        | RW          | 0x3                | gpio1c1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 1:0        | RW          | 0x3                | gpio1c0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

**GPIO1 IOC GPIO1D SL**

Address: Operational Base + offset (0x024C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                      |
| 7:6        | RW          | 0x3                | gpio1d3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 5:4        | RW          | 0x3                | gpio1d2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 3:2        | RW          | 0x3                | gpio1d1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 1:0        | RW          | 0x3                | gpio1d0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

**GPIO1 IOC GPIO1A IE SMT**

Address: Operational Base + offset (0x0280)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:5       | RO          | 0x000              | reserved                                                                                                                          |
| 4          | RW          | 0x1                | gpio1a4_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 3          | RW          | 0x1                | gpio1a3_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 2          | RW          | 0x1                | gpio1a2_smt<br>Active High. Receiver enable for Schmitt trigger. |
| 1          | RW          | 0x1                | gpio1a1_smt<br>Active High. Receiver enable for Schmitt trigger. |
| 0          | RW          | 0x1                | gpio1a0_smt<br>Active High. Receiver enable for Schmitt trigger. |

**GPIO1 IOC GPIO1B IE SMT**

Address: Operational Base + offset (0x0284)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x1                | gpio1b3_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 2          | RW          | 0x1                | gpio1b2_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 1          | RW          | 0x1                | gpio1b1_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 0          | RW          | 0x1                | gpio1b0_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |

**GPIO1 IOC GPIO1C IE SMT**

Address: Operational Base + offset (0x0288)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio1c7_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 6          | RW          | 0x1                | gpio1c6_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 5          | RW          | 0x1                | gpio1c5_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 4          | RW          | 0x1                | gpio1c4_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 3          | RW          | 0x1                | gpio1c3_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 2          | RW          | 0x1                | gpio1c2_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 1          | RW          | 0x1                | gpio1c1_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 0          | RW          | 0x1                | gpio1c0_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |

**GPIO1 IOC GPIO1D IE SMT**

Address: Operational Base + offset (0x028C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x1                | gpio1d3_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 2          | RW          | 0x1                | gpio1d2_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 1          | RW          | 0x1                | gpio1d1_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 0          | RW          | 0x1                | gpio1d0_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |

**GPIO1 IOC GPIO1A OD**

Address: Operational Base + offset (0x02C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:5       | RO          | 0x000              | reserved                                                                                                                          |
| 4          | RW          | 0x0                | gpio1a4_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 3          | RW          | 0x0                | gpio1a3_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 2          | RW          | 0x0                | gpio1a2_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 1          | RW          | 0x0                | gpio1a1_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 0          | RW          | 0x0                | gpio1a0_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |

**GPIO1 IOC GPIO1B OD**

Address: Operational Base + offset (0x02C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x0                | gpio1b3_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 2          | RW          | 0x0                | gpio1b2_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 1          | RW          | 0x0                | gpio1b1_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | gpio1b0_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO |

**GPIO1 IOC GPIO1C OD**

Address: Operational Base + offset (0x02C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x0                | gpio1c7_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 6          | RW          | 0x0                | gpio1c6_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 5          | RW          | 0x0                | gpio1c5_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 4          | RW          | 0x0                | gpio1c4_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 3          | RW          | 0x0                | gpio1c3_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 2          | RW          | 0x0                | gpio1c2_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 1          | RW          | 0x0                | gpio1c1_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 0          | RW          | 0x0                | gpio1c0_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |

**GPIO1 IOC GPIO1D OD**

Address: Operational Base + offset (0x02CC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x0                | gpio1d3_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 2          | RW          | 0x0                | gpio1d2_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 1          | RW          | 0x0                | gpio1d1_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |

| Bit | Attr | Reset Value | Description                                                                      |
|-----|------|-------------|----------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | gpio1d0_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO |

**GPIO1\_IOC\_FORCE\_JTAG\_UART**

Address: Operational Base + offset (0x02F4)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:1  | RO   | 0x0000      | reserved                                                                                                                          |
| 0     | RW   | 0x1         | jtag_uart_auto_switch_en<br>This bit is used to enable uart auto-switch to a7_jtag_m1,active high.                                |

**4.13 GPIO2\_IOC Register Description****4.13.1 Registers Summary**

| Name                                 | Offset | Size | Reset Value | Description                                       |
|--------------------------------------|--------|------|-------------|---------------------------------------------------|
| <u>GPIO2_IOC_GPIO2A_IOM_UX_SEL_L</u> | 0x0020 | W    | 0x00000000  | VCCIO5_GPIO2A iomux configuration                 |
| <u>GPIO2_IOC_GPIO2A_IOM_UX_SEL_H</u> | 0x0024 | W    | 0x00000000  | VCCIO5_GPIO2A iomux configuration                 |
| <u>GPIO2_IOC_GPIO2B_IOM_UX_SEL_L</u> | 0x0028 | W    | 0x00000000  | VCCIO5_GPIO2B iomux configuration                 |
| <u>GPIO2_IOC_GPIO2A_DS0</u>          | 0x00C0 | W    | 0x00000707  | VCCIO5_GPIO2A drive strength                      |
| <u>GPIO2_IOC_GPIO2A_DS1</u>          | 0x00C4 | W    | 0x0000070F  | VCCIO5_GPIO2A drive strength                      |
| <u>GPIO2_IOC_GPIO2A_DS2</u>          | 0x00C8 | W    | 0x00000007  | VCCIO5_GPIO2A drive strength                      |
| <u>GPIO2_IOC_GPIO2A_DS3</u>          | 0x00CC | W    | 0x00000700  | VCCIO5_GPIO2A drive strength                      |
| <u>GPIO2_IOC_GPIO2B_DS0</u>          | 0x00D0 | W    | 0x00000707  | VCCIO5_GPIO2B drive strength                      |
| <u>GPIO2_IOC_GPIO2A_IE</u>           | 0x0190 | W    | 0x000000FF  | VCCIO5_GPIO2A input enable                        |
| <u>GPIO2_IOC_GPIO2B_IE</u>           | 0x0194 | W    | 0x00000003  | VCCIO5_GPIO2B input enable                        |
| <u>GPIO2_IOC_GPIO2A_P</u>            | 0x01D0 | W    | 0x0000AAAA  | VCCIO5_GPIO2A pull up and pull down configuration |
| <u>GPIO2_IOC_GPIO2B_P</u>            | 0x01D4 | W    | 0x0000000A  | VCCIO5_GPIO2B pull up and pull down configuration |
| <u>GPIO2_IOC_GPIO2A_SUS</u>          | 0x0210 | W    | 0x00000000  | VCCIO5_GPIO2A keeper configuration                |
| <u>GPIO2_IOC_GPIO2B_SUS</u>          | 0x0214 | W    | 0x00000000  | VCCIO5_GPIO2B keeper configuration                |
| <u>GPIO2_IOC_GPIO2A_SL</u>           | 0x0250 | W    | 0x0000FFFF  | VCCIO5_GPIO2A skew rate                           |
| <u>GPIO2_IOC_GPIO2B_SL</u>           | 0x0254 | W    | 0x0000000F  | VCCIO5_GPIO2B skew rate                           |
| <u>GPIO2_IOC_GPIO2A_IE_SMT</u>       | 0x0290 | W    | 0x000000FF  | VCCIO5_GPIO2A Schmitt trigger                     |
| <u>GPIO2_IOC_GPIO2B_IE_SMT</u>       | 0x0294 | W    | 0x00000003  | VCCIO5_GPIO2B Schmitt trigger                     |
| <u>GPIO2_IOC_GPIO2A_OD</u>           | 0x02D0 | W    | 0x00000000  | VCCIO5_GPIO2A open drain                          |
| <u>GPIO2_IOC_GPIO2B_OD</u>           | 0x02D4 | W    | 0x00000000  | VCCIO5_GPIO2B open drain                          |
| <u>GPIO2_IOC_VCCIO5_POC</u>          | 0x0300 | W    | 0x00000000  | VCCIO5 voltage detect                             |

Notes:Size:**B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**-Double WORD (64 bits) access

**4.13.2 Detail Registers Description**

**GPIO2 IOC GPIO2A IOMUX SEL\_L**

Address: Operational Base + offset (0x0020)

| Bit   | Attr | Reset Value | Description                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15    | RO   | 0x0         | reserved                                                                                                                         |
| 14:12 | RW   | 0x0         | gpio2a3_sel<br>3'h0: GPIO<br>3'h1: SDMMC1_CMD_M0<br>3'h2: I2S0_SDO3_SDI1<br>3'h3: LCD_D11                                        |
| 11    | RO   | 0x0         | reserved                                                                                                                         |
| 10:8  | RW   | 0x0         | gpio2a2_sel<br>3'h0: GPIO<br>3'h1: SDMMC1_CLK_M0<br>3'h2: I2S0_MCLK<br>3'h3: LCD_D10                                             |
| 7     | RO   | 0x0         | reserved                                                                                                                         |
| 6:4   | RW   | 0x0         | gpio2a1_sel<br>3'h0: GPIO<br>3'h1: SDMMC1_D0_M0<br>3'h2: I2S0_LRCK<br>3'h3: LCD_D9<br>3'h4: UART1_RTSN_M1<br>3'h5: I2C4_SCL_M0   |
| 3     | RO   | 0x0         | reserved                                                                                                                         |
| 2:0   | RW   | 0x0         | gpio2a0_sel<br>3'h0: GPIO<br>3'h1: SDMMC1_D1_M0<br>3'h2: I2S0_SCLK<br>3'h3: LCD_D8<br>3'h4: UART1_CTSN_M1<br>4'h5: I2C4_SDA_M0   |

**GPIO2 IOC GPIO2A IOMUX SEL\_H**

Address: Operational Base + offset (0x0024)

| Bit   | Attr | Reset Value | Description                                                                                                                                                |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable                           |
| 15    | RO   | 0x0         | reserved                                                                                                                                                   |
| 14:12 | RW   | 0x0         | gpio2a7_sel<br>3'h0: GPIO<br>3'h1: UART0_CTSN_M1<br>3'h2: I2S0_SDO1_SDI3<br>3'h3: LCD_D15<br>3'h4: PWM4_M1<br>3'h5: I2C3_SDA_M0<br>3'h6: PRELIGHT_TRIG_OUT |
| 11    | RO   | 0x0         | reserved                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RW          | 0x0                | gpio2a6_sel<br>3'h0: GPIO<br>3'h1: UART0_RTSN_M1<br>3'h2: I2S0_SDO2_SD12<br>3'h3: LCD_D14<br>3'h4: PWM2_M1<br>3'h5: I2C3_SCL_M0<br>3'h6: FLASH_TRIG_OUT |
| 7          | RO          | 0x0                | reserved                                                                                                                                                |
| 6:4        | RW          | 0x0                | gpio2a5_sel<br>3'h0: GPIO<br>3'h1: SDMMC1_D2_M0<br>3'h2: I2S0_SDIO<br>3'h3: LCD_D13<br>3'h4: UART1_RX_M1                                                |
| 3          | RO          | 0x0                | reserved                                                                                                                                                |
| 2:0        | RW          | 0x0                | gpio2a4_sel<br>3'h0: GPIO<br>3'h1: SDMMC1_D3_M0<br>3'h2: I2S0_SDO0<br>3'h3: LCD_D12<br>3'h4: UART1_TX_M1                                                |

**GPIO2\_IOC\_GPIO2B\_IOMUX\_SEL\_L**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                         |
| 6:4        | RW          | 0x0                | gpio2b1_sel<br>3'h0: GPIO<br>3'h1: UART0_TX_M1<br>3'h2: I2C1_SDA_M1<br>3'h3: LCD_D17<br>3'h4: PWM6_M1<br>3'h5: TEST_CLK5_OUT     |
| 3          | RO          | 0x0                | reserved                                                                                                                         |
| 2:0        | RW          | 0x0                | gpio2b0_sel<br>3'h0: GPIO<br>3'h1: UART0_RX_M1<br>3'h2: I2C1_SCL_M1<br>3'h3: LCD_D16<br>3'h4: PWM5_M1<br>3'h5: TEST_CLK4_OUT     |

**GPIO2\_IOC\_GPIO2A\_DS0**

Address: Operational Base + offset (0x00C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x07               | gpio2a1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x07               | gpio2a0_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO2 IOC GPIO2A DS1**

Address: Operational Base + offset (0x00C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x07               | gpio2a3_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x0f               | gpio2a2_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO2 IOC GPIO2A DS2**

Address: Operational Base + offset (0x00C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x00               | gpio2a5_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x07               | gpio2a4_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO2 IOC GPIO2A DS3**

Address: Operational Base + offset (0x00CC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x07               | gpio2a7_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x00               | gpio2a6_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO2 IOC GPIO2B DS0**

Address: Operational Base + offset (0x00D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x07               | gpio2b1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x07               | gpio2b0_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO2 IOC GPIO2A IE**

Address: Operational Base + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                         |
| 7          | RW          | 0x1                | gpio2a7_ie<br>GPIO2A7 IE control<br>Active High, input buffer enable                                                             |
| 6          | RW          | 0x1                | gpio2a6_ie<br>GPIO2A6 IE control<br>Active High, input buffer enable                                                             |
| 5          | RW          | 0x1                | gpio2a5_ie<br>GPIO2A5 IE control<br>Active High, input buffer enable                                                             |
| 4          | RW          | 0x1                | gpio2a4_ie<br>GPIO2A4 IE control<br>Active High, input buffer enable                                                             |
| 3          | RW          | 0x1                | gpio2a3_ie<br>GPIO2A3 IE control<br>Active High, input buffer enable                                                             |
| 2          | RW          | 0x1                | gpio2a2_ie<br>GPIO2A2 IE control<br>Active High, input buffer enable                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 1          | RW          | 0x1                | gpio2a1_ie<br>GPIO2A1 IE control<br>Active High, input buffer enable |
| 0          | RW          | 0x1                | gpio2a0_ie<br>GPIO2A0 IE control<br>Active High, input buffer enable |

**GPIO2\_IOC\_GPIO2B\_IE**

Address: Operational Base + offset (0x0194)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                         |
| 1          | RW          | 0x1                | gpio2b1_ie<br>GPIO2B1 IE control<br>Active High, input buffer enable                                                             |
| 0          | RW          | 0x1                | gpio2b0_ie<br>GPIO2B0 IE control<br>Active High, input buffer enable                                                             |

**GPIO2\_IOC\_GPIO2A\_P**

Address: Operational Base + offset (0x01D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x1                | gpio2a7_pd<br>Active High. Weak pull down for pad.                                                                               |
| 14         | RW          | 0x0                | gpio2a7_pu<br>Active High. Weak pull up for pad.                                                                                 |
| 13         | RW          | 0x1                | gpio2a6_pd<br>Active High. Weak pull down for pad.                                                                               |
| 12         | RW          | 0x0                | gpio2a6_pu<br>Active High. Weak pull up for pad.                                                                                 |
| 11         | RW          | 0x1                | gpio2a5_pd<br>Active High. Weak pull down for pad.                                                                               |
| 10         | RW          | 0x0                | gpio2a5_pu<br>Active High. Weak pull up for pad.                                                                                 |
| 9          | RW          | 0x1                | gpio2a4_pd<br>Active High. Weak pull down for pad.                                                                               |
| 8          | RW          | 0x0                | gpio2a4_pu<br>Active High. Weak pull up for pad.                                                                                 |
| 7          | RW          | 0x1                | gpio2a3_pd<br>Active High. Weak pull down for pad.                                                                               |
| 6          | RW          | 0x0                | gpio2a3_pu<br>Active High. Weak pull up for pad.                                                                                 |
| 5          | RW          | 0x1                | gpio2a2_pd<br>Active High. Weak pull down for pad.                                                                               |
| 4          | RW          | 0x0                | gpio2a2_pu<br>Active High. Weak pull up for pad.                                                                                 |
| 3          | RW          | 0x1                | gpio2a1_pd<br>Active High. Weak pull down for pad.                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 2          | RW          | 0x0                | gpio2a1_pu<br>Active High. Weak pull up for pad.   |
| 1          | RW          | 0x1                | gpio2a0_pd<br>Active High. Weak pull down for pad. |
| 0          | RW          | 0x0                | gpio2a0_pu<br>Active High. Weak pull up for pad.   |

**GPIO2 IOC GPIO2B\_P**

Address: Operational Base + offset (0x01D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                         |
| 3          | RW          | 0x1                | gpio2b1_pd<br>Active High. Weak pull down for pad.                                                                               |
| 2          | RW          | 0x0                | gpio2b1_pu<br>Active High. Weak pull up for pad.                                                                                 |
| 1          | RW          | 0x1                | gpio2b0_pd<br>Active High. Weak pull down for pad.                                                                               |
| 0          | RW          | 0x0                | gpio2b0_pu<br>Active High. Weak pull up for pad.                                                                                 |

**GPIO2 IOC GPIO2A\_SUS**

Address: Operational Base + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                         |
| 7          | RW          | 0x0                | gpio2a7_sus<br>Active High. Weak pull keeper for pad.                                                                            |
| 6          | RW          | 0x0                | gpio2a6_sus<br>Active High. Weak pull keeper for pad.                                                                            |
| 5          | RW          | 0x0                | gpio2a5_sus<br>Active High. Weak pull keeper for pad.                                                                            |
| 4          | RW          | 0x0                | gpio2a4_sus<br>Active High. Weak pull keeper for pad.                                                                            |
| 3          | RW          | 0x0                | gpio2a3_sus<br>Active High. Weak pull keeper for pad.                                                                            |
| 2          | RW          | 0x0                | gpio2a2_sus<br>Active High. Weak pull keeper for pad.                                                                            |
| 1          | RW          | 0x0                | gpio2a1_sus<br>Active High. Weak pull keeper for pad.                                                                            |
| 0          | RW          | 0x0                | gpio2a0_sus<br>Active High. Weak pull keeper for pad.                                                                            |

**GPIO2 IOC GPIO2B\_SUS**

Address: Operational Base + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                         |
| 1          | RW          | 0x0                | gpio2b1_sus<br>Active High. Weak pull keeper for pad.                                                                            |
| 0          | RW          | 0x0                | gpio2b0_sus<br>Active High. Weak pull keeper for pad.                                                                            |

**GPIO2 IOC GPIO2A SL**

Address: Operational Base + offset (0x0250)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable                              |
| 15:14      | RW          | 0x3                | gpio2a7_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 13:12      | RW          | 0x3                | gpio2a6_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 11:10      | RW          | 0x3                | gpio2a5_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 9:8        | RW          | 0x3                | gpio2a4_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 7:6        | RW          | 0x3                | gpio2a3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 5:4        | RW          | 0x3                | gpio2a2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 3:2        | RW          | 0x3                | gpio2a1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 1:0        | RW          | 0x3                | gpio2a0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

**GPIO2 IOC GPIO2B SL**

Address: Operational Base + offset (0x0254)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable                              |
| 15:4       | RO          | 0x000              | reserved                                                                                                                                                      |
| 3:2        | RW          | 0x3                | gpio2b1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 1:0        | RW          | 0x3                | gpio2b0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

**GPIO2 IOC GPIO2A IE SMT**

Address: Operational Base + offset (0x0290)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                         |
| 7          | RW          | 0x1                | gpio2a7_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                 |
| 6          | RW          | 0x1                | gpio2a6_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                 |
| 5          | RW          | 0x1                | gpio2a5_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                 |
| 4          | RW          | 0x1                | gpio2a4_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                 |
| 3          | RW          | 0x1                | gpio2a3_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                 |
| 2          | RW          | 0x1                | gpio2a2_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                 |
| 1          | RW          | 0x1                | gpio2a1_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                 |
| 0          | RW          | 0x1                | gpio2a0_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                 |

**GPIO2 IOC GPIO2B IE SMT**

Address: Operational Base + offset (0x0294)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                         |
| 1          | RW          | 0x1                | gpio2b1_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                 |
| 0          | RW          | 0x1                | gpio2b0_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                 |

**GPIO2 IOC GPIO2A OD**

Address: Operational Base + offset (0x02D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                         |
| 7          | RW          | 0x0                | gpio2a7_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                 |
| 6          | RW          | 0x0                | gpio2a6_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                 |
| 5          | RW          | 0x0                | gpio2a5_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                 |
| 4          | RW          | 0x0                | gpio2a4_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                 |
| 3          | RW          | 0x0                | gpio2a3_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                 |
| 2          | RW          | 0x0                | gpio2a2_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                 |
| 1          | RW          | 0x0                | gpio2a1_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                 |
| 0          | RW          | 0x0                | gpio2a0_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                 |

**GPIO2 IOC GPIO2B OD**

Address: Operational Base + offset (0x02D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                         |
| 1          | RW          | 0x0                | gpio2b1_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                 |
| 0          | RW          | 0x0                | gpio2b0_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                 |

**GPIO2 IOC VCCIO5 POC**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                               |
| 5          | RO          | 0x0                | vccio5_voldet<br>VCCIO5 voltage detection.<br>1'b0: VDDO is 1.8v<br>1'b1: VDDO is 3.3v |
| 4:0        | RO          | 0x00               | reserved                                                                               |

## 4.14 GPIO3\_IOC Register Description

### 4.14.1 Registers Summary

| Name                          | Offset | Size | Reset Value | Description                                       |
|-------------------------------|--------|------|-------------|---------------------------------------------------|
| GPIO3_IOC_GPIO3A_IOM_UX_SEL_L | 0x0040 | W    | 0x00000000  | GPIO3A iomux configuration                        |
| GPIO3_IOC_GPIO3A_IOM_UX_SEL_H | 0x0044 | W    | 0x00001B00  | GPIO3A iomux configuration                        |
| GPIO3_IOC_GPIO3B_IOM_UX_SEL_L | 0x0048 | W    | 0x00000000  | GPIO3B iomux configuration                        |
| GPIO3_IOC_GPIO3B_IOM_UX_SEL_H | 0x004C | W    | 0x00000000  | GPIO3B iomux configuration                        |
| GPIO3_IOC_GPIO3C_IOM_UX_SEL_L | 0x0050 | W    | 0x00000000  | GPIO3C iomux configuration                        |
| GPIO3_IOC_GPIO3C_IOM_UX_SEL_H | 0x0054 | W    | 0x00000000  | GPIO3C iomux configuration                        |
| GPIO3_IOC_GPIO3D_IOM_UX_SEL_L | 0x0058 | W    | 0x00000000  | GPIO3D iomux configuration                        |
| GPIO3_IOC_GPIO3A_DS0          | 0x0100 | W    | 0x00000F00  | VCCIO4_GPIO3A drive strength                      |
| GPIO3_IOC_GPIO3A_DS1          | 0x0104 | W    | 0x00000F0F  | VCCIO4_GPIO3A drive strength                      |
| GPIO3_IOC_GPIO3A_DS2          | 0x0108 | W    | 0x00000F1F  | VCCIO4_GPIO3A drive strength                      |
| GPIO3_IOC_GPIO3A_DS3          | 0x010C | W    | 0x00000F0F  | VCCIO4_GPIO3A drive strength                      |
| GPIO3_IOC_GPIO3C_DS2          | 0x0128 | W    | 0x00000303  | VCCIO7_GPIO3C drive strength                      |
| GPIO3_IOC_GPIO3C_DS3          | 0x012C | W    | 0x00000303  | VCCIO7_GPIO3C drive strength                      |
| GPIO3_IOC_GPIO3D_DS0          | 0x0130 | W    | 0x00000303  | VCCIO7_GPIO3D drive strength                      |
| GPIO3_IOC_GPIO3D_DS1          | 0x0134 | W    | 0x00000303  | VCCIO7_GPIO3D drive strength                      |
| GPIO3_IOC_GPIO3A_IE           | 0x01A0 | W    | 0x000000FE  | VCCIO4_GPIO3A input enable                        |
| GPIO3_IOC_GPIO3C_IE           | 0x01A8 | W    | 0x000000F0  | VCCIO7_GPIO3C input enable                        |
| GPIO3_IOC_GPIO3D_IE           | 0x01AC | W    | 0x0000000F  | VCCIO7_GPIO3D input enable                        |
| GPIO3_IOC_GPIO3A_P            | 0x01E0 | W    | 0x00005654  | VCCIO4_GPIO3A pull up and pull down configuration |
| GPIO3_IOC_GPIO3C_P            | 0x01E8 | W    | 0x0000AA00  | VCCIO7_GPIO3C pull up and pull down configuration |
| GPIO3_IOC_GPIO3D_P            | 0x01EC | W    | 0x000000AA  | VCCIO7_GPIO3D pull up and pull down configuration |
| GPIO3_IOC_GPIO3A_SUS          | 0x0220 | W    | 0x00000000  | VCCIO4_GPIO3A keeper configuration                |
| GPIO3_IOC_GPIO3C_SUS          | 0x0228 | W    | 0x00000000  | VCCIO7_GPIO3C keeper configuration                |
| GPIO3_IOC_GPIO3D_SUS          | 0x022C | W    | 0x00000000  | VCCIO7_GPIO3D keeper configuration                |
| GPIO3_IOC_GPIO3A_SL           | 0x0260 | W    | 0x0000FFFC  | VCCIO4_GPIO3A skew rate                           |
| GPIO3_IOC_GPIO3C_SL           | 0x0268 | W    | 0x0000FF00  | VCCIO7_GPIO3C skew rate                           |
| GPIO3_IOC_GPIO3D_SL           | 0x026C | W    | 0x000000FF  | VCCIO7_GPIO3D skew rate                           |
| GPIO3_IOC_GPIO3A_IE_SMT       | 0x02A0 | W    | 0x000000FE  | VCCIO4_GPIO3A Schmitt trigger                     |
| GPIO3_IOC_GPIO3C_IE_SMT       | 0x02A8 | W    | 0x000000F0  | VCCIO7_GPIO3C Schmitt trigger                     |
| GPIO3_IOC_GPIO3D_IE_SMT       | 0x02AC | W    | 0x0000000F  | VCCIO7_GPIO3D Schmitt trigger                     |
| GPIO3_IOC_GPIO3A_OD           | 0x02E0 | W    | 0x00000000  | VCCIO4_GPIO3A open drain                          |
| GPIO3_IOC_GPIO3C_OD           | 0x02E8 | W    | 0x00000000  | VCCIO7_GPIO3C open drain                          |
| GPIO3_IOC_GPIO3D_OD           | 0x02EC | W    | 0x00000000  | VCCIO7_GPIO3D open drain                          |

| Name                       | Offset | Size | Reset Value | Description                          |
|----------------------------|--------|------|-------------|--------------------------------------|
| GPIO3_IOC_FORCE_JTAG_SDMMC | 0x02F4 | W    | 0x00000001  | sdmmc and a7 jtag auto-switch enable |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

#### 4.14.2 Detail Registers Description

##### GPIO3\_IOC\_GPIO3A\_IOMUX\_SEL\_L

Address: Operational Base + offset (0x0040)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15    | RO   | 0x0         | reserved                                                                                                                          |
| 14:12 | RW   | 0x0         | gpio3a3_sel<br>3'h0: GPIO<br>3'h1: SDMMC0_D0<br>3'h2: UART2_RX_M0<br>3'h3: TEST_CLK1_OUT<br>3'h4: PWM8_M0                         |
| 11    | RO   | 0x0         | reserved                                                                                                                          |
| 10:8  | RW   | 0x0         | gpio3a2_sel<br>3'h0: GPIO<br>3'h1: SDMMC0_D1<br>3'h2: UART2_TX_M0<br>3'h3: TEST_CLK0_OUT<br>3'h4: PWM9_M0                         |
| 7     | RO   | 0x0         | reserved                                                                                                                          |
| 6:4   | RW   | 0x0         | gpio3a1_sel<br>3'h0: GPIO<br>3'h1: SDMMC0_DET                                                                                     |
| 3:0   | RO   | 0x0         | reserved                                                                                                                          |

##### GPIO3\_IOC\_GPIO3A\_IOMUX\_SEL\_H

Address: Operational Base + offset (0x0044)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14 | RO   | 0x0         | reserved                                                                                                                          |
| 14:12 | RW   | 0x3         | gpio3a7_sel<br>3'h0: GPIO<br>3'h1: SDMMC0_D2<br>3'h2: UART5_RX_M0<br>3'h3: A7_JTAG_TCK_M0<br>3'h4: HPMCU_JTAG_TCK_M1              |
| 11    | RO   | 0x0         | reserved                                                                                                                          |
| 10:8  | RW   | 0x3         | gpio3a6_sel<br>3'h0: GPIO<br>3'h1: SDMMC0_D3<br>3'h2: UART5_TX_M0<br>3'h3: A7_JTAG_TMS_M0<br>3'h4: HPMCU_JTAG_TMS_M1              |
| 7     | RO   | 0x0         | reserved                                                                                                                          |

| Bit | Attr | Reset Value | Description                                                                                                                               |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | RW   | 0x0         | gpio3a5_sel<br>3'h0: GPIO<br>3'h1: SDMMC0_CMD<br>3'h2: UART5_CTSN_M0<br>3'h3: I2C0_SDA_M2<br>3'h4: LPMCU_JTAG_TMS_M1<br>3'h5: PWM11_IR_M0 |
| 3   | RO   | 0x0         | reserved                                                                                                                                  |
| 2:0 | RW   | 0x0         | gpio3a4_sel<br>3'h0: GPIO<br>3'h1: SDMMC0_CLK<br>3'h2: UART5_RTSN_M0<br>3'h3: I2C0_SCL_M2<br>3'h4: LPMCU_JTAG_TCK_M1<br>3'h5: PWM10_M0    |

**GPIO3 IOC GPIO3B IOMUX SEL\_L**

Address: Operational Base + offset (0x0048)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15    | RO   | 0x0         | reserved                                                                                                                          |
| 14:12 | RW   | 0x0         | gpio3b3_sel<br>3'h0: GPIO<br>3'h1: VICAP_D3_M0<br>3'h2: MIPICSI_LVDSRX_CK1P                                                       |
| 11    | RO   | 0x0         | reserved                                                                                                                          |
| 10:8  | RW   | 0x0         | gpio3b2_sel<br>3'h0: GPIO<br>3'h1: VICAP_D2_M0<br>3'h2: MIPICSI_LVDSRX_CK1N                                                       |
| 7     | RO   | 0x0         | reserved                                                                                                                          |
| 6:4   | RW   | 0x0         | gpio3b1_sel<br>3'h0: GPIO<br>3'h1: VICAP_D1_M0<br>3'h2: MIPICSI_LVDSRX_D3P                                                        |
| 3     | RO   | 0x0         | reserved                                                                                                                          |
| 2:0   | RW   | 0x0         | gpio3b0_sel<br>3'h0: GPIO<br>3'h1: VICAP_D0_M0<br>3'h2: MIPICSI_LVDSRX_D3N                                                        |

**GPIO3 IOC GPIO3B IOMUX SEL\_H**

Address: Operational Base + offset (0x004C)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15    | RO   | 0x0         | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 14:12      | RW          | 0x0                | gpio3b7_sel<br>3'h0: GPIO<br>3'h1: VICAP_D7_M0<br>3'h2: MIPICSI_LVDSRX_D1P |
| 11         | RO          | 0x0                | reserved                                                                   |
| 10:8       | RW          | 0x0                | gpio3b6_sel<br>3'h0: GPIO<br>3'h1: VICAP_D6_M0<br>3'h2: MIPICSI_LVDSRX_D1N |
| 7          | RO          | 0x0                | reserved                                                                   |
| 6:4        | RW          | 0x0                | gpio3b5_sel<br>3'h0: GPIO<br>3'h1: VICAP_D5_M0<br>3'h2: MIPICSI_LVDSRX_D2P |
| 3          | RO          | 0x0                | reserved                                                                   |
| 2:0        | RW          | 0x0                | gpio3b4_sel<br>3'h0: GPIO<br>3'h1: VICAP_D4_M0<br>3'h2: MIPICSI_LVDSRX_D2N |

**GPIO3 IOC GPIO3C IOMUX SEL\_L**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RO          | 0x0                | reserved                                                                                                                          |
| 14:12      | RW          | 0x0                | gpio3c3_sel<br>3'h0: GPIO<br>3'h1: VICAP_HSYNC_M0<br>3'h2: MIPICSI_LVDSRX_D0P                                                     |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio3c2_sel<br>3'h0: GPIO<br>3'h1: VICAP_CLKIN_M0<br>3'h2: MIPICSI_LVDSRX_D0N                                                     |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio3c1_sel<br>3'h0: GPIO<br>3'h1: VICAP_D9_M0<br>3'h2: MIPICSI_LVDSRX_CK0P                                                       |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio3c0_sel<br>3'h0: GPIO<br>3'h1: VICAP_D8_M0<br>3'h2: MIPICSI_LVDSRX_CK0N                                                       |

**GPIO3 IOC GPIO3C IOMUX SEL\_H**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 15         | RO          | 0x0                | reserved                                                                                      |
| 14:12      | RW          | 0x0                | gpio3c7_sel<br>3'h0: GPIO<br>3'h1: VICAP_D11<br>3'h2: UART5_TX_M2<br>3'h3: I2C4_SCL_M2        |
| 11         | RO          | 0x0                | reserved                                                                                      |
| 10:8       | RW          | 0x0                | gpio3c6_sel<br>3'h0: GPIO<br>3'h1: VICAP_D10<br>3'h2: PWM7_IR_M2<br>3'h3: MIPICSI_REFCLK_OUT1 |
| 7          | RO          | 0x0                | reserved                                                                                      |
| 6:4        | RW          | 0x0                | gpio3c5_sel<br>3'h0: GPIO<br>3'h1: VICAP_VSYNC_M0                                             |
| 3          | RO          | 0x0                | reserved                                                                                      |
| 2:0        | RW          | 0x0                | gpio3c4_sel<br>3'h0: GPIO<br>3'h1: VICAP_CLKOUT_M0<br>3'h2: MIPICSI_REFCLK_OUT0               |

**GPIO3\_IOC\_GPIO3D\_IOMUX\_SEL\_L**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RO          | 0x0                | reserved                                                                                                                          |
| 14:12      | RW          | 0x0                | gpio3d3_sel<br>3'h0: GPIO<br>3'h1: VICAP_D15<br>3'h2: PWM1_M2                                                                     |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio3d2_sel<br>3'h0: GPIO<br>3'h1: VICAP_D14<br>3'h2: UART5_CTSN_M2<br>3'h3: I2C3_SDA_M2                                          |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio3d1_sel<br>3'h0: GPIO<br>3'h1: VICAP_D13<br>3'h2: UART5_RTSN_M2<br>3'h3: I2C3_SCL_M2                                          |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio3d0_sel<br>3'h0: GPIO<br>3'h1: VICAP_D12<br>3'h2: UART5_RX_M2<br>3'h3: I2C4_SDA_M2                                            |

**GPIO3\_IOC\_GPIO3A\_DSO**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x0f               | gpio3a1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:0        | RO          | 0x00               | reserved                                                                                                                                                                                            |

**GPIO3 IOC GPIO3A DS1**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x0f               | gpio3a3_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x0f               | gpio3a2_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO3 IOC GPIO3A DS2**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x0f               | gpio3a5_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x1f               | gpio3a4_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO3 IOC GPIO3A DS3**

Address: Operational Base + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x0f               | gpio3a7_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x0f               | gpio3a6_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO3 IOC GPIO3C DS2**

Address: Operational Base + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x03               | gpio3c5_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x03               | gpio3c4_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO3 IOC GPIO3C DS3**

Address: Operational Base + offset (0x012C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x03               | gpio3c7_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x03               | gpio3c6_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO3 IOC GPIO3D DS0**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x03               | gpio3d1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x03               | gpio3d0_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO3 IOC GPIO3D DS1**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x03               | gpio3d3_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x03               | gpio3d2_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO3 IOC GPIO3A IE**

Address: Operational Base + offset (0x01A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio3a7_ie<br>Active High input buffer enable                                                                                     |
| 6          | RW          | 0x1                | gpio3a6_ie<br>Active High input buffer enable                                                                                     |
| 5          | RW          | 0x1                | gpio3a5_ie<br>Active High input buffer enable                                                                                     |
| 4          | RW          | 0x1                | gpio3a4_ie<br>Active High input buffer enable                                                                                     |
| 3          | RW          | 0x1                | gpio3a3_ie<br>Active High input buffer enable                                                                                     |
| 2          | RW          | 0x1                | gpio3a2_ie<br>Active High input buffer enable                                                                                     |
| 1          | RW          | 0x1                | gpio3a1_ie<br>Active High input buffer enable                                                                                     |
| 0          | RO          | 0x0                | reserved                                                                                                                          |

**GPIO3 IOC GPIO3C IE**

Address: Operational Base + offset (0x01A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio3c7_ie<br>Active High input buffer enable                                                                                     |
| 6          | RW          | 0x1                | gpio3c6_ie<br>Active High input buffer enable                                                                                     |
| 5          | RW          | 0x1                | gpio3c5_ie<br>Active High input buffer enable                                                                                     |
| 4          | RW          | 0x1                | gpio3c4_ie<br>Active High input buffer enable                                                                                     |
| 3:0        | RO          | 0x0                | reserved                                                                                                                          |

**GPIO3 IOC GPIO3D IE**

Address: Operational Base + offset (0x01AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x1                | gpio3d3_ie<br>Active High input buffer enable                                                                                     |
| 2          | RW          | 0x1                | gpio3d2_ie<br>Active High input buffer enable                                                                                     |
| 1          | RW          | 0x1                | gpio3d1_ie<br>Active High input buffer enable                                                                                     |
| 0          | RW          | 0x1                | gpio3d0_ie<br>Active High input buffer enable                                                                                     |

**GPIO3 IOC GPIO3A P**

Address: Operational Base + offset (0x01E0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | gpio3a7_pd<br>Active High. Weak pull down for pad.                                                                                |
| 14         | RW          | 0x1                | gpio3a7_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 13         | RW          | 0x0                | gpio3a6_pd<br>Active High. Weak pull down for pad.                                                                                |
| 12         | RW          | 0x1                | gpio3a6_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 11         | RW          | 0x0                | gpio3a5_pd<br>Active High. Weak pull down for pad.                                                                                |
| 10         | RW          | 0x1                | gpio3a5_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 9          | RW          | 0x1                | gpio3a4_pd<br>Active High. Weak pull down for pad.                                                                                |
| 8          | RW          | 0x0                | gpio3a4_pu<br>Active High. Weak pull up for pad.                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 7          | RW          | 0x0                | gpio3a3_pd<br>Active High. Weak pull down for pad. |
| 6          | RW          | 0x1                | gpio3a3_pu<br>Active High. Weak pull up for pad.   |
| 5          | RW          | 0x0                | gpio3a2_pd<br>Active High. Weak pull down for pad. |
| 4          | RW          | 0x1                | gpio3a2_pu<br>Active High. Weak pull up for pad.   |
| 3          | RW          | 0x0                | gpio3a1_pd<br>Active High. Weak pull down for pad. |
| 2          | RW          | 0x1                | gpio3a1_pu<br>Active High. Weak pull up for pad.   |
| 1:0        | RO          | 0x0                | reserved                                           |

**GPIO3 IOC GPIO3C P**

Address: Operational Base + offset (0x01E8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x1                | gpio3c7_pd<br>Active High. Weak pull down for pad.                                                                                |
| 14         | RW          | 0x0                | gpio3c7_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 13         | RW          | 0x1                | gpio3c6_pd<br>Active High. Weak pull down for pad.                                                                                |
| 12         | RW          | 0x0                | gpio3c6_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 11         | RW          | 0x1                | gpio3c5_pd<br>Active High. Weak pull down for pad.                                                                                |
| 10         | RW          | 0x0                | gpio3c5_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 9          | RW          | 0x1                | gpio3c4_pd<br>Active High. Weak pull down for pad.                                                                                |
| 8          | RW          | 0x0                | gpio3c4_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 7:0        | RO          | 0x00               | reserved                                                                                                                          |

**GPIO3 IOC GPIO3D P**

Address: Operational Base + offset (0x01EC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio3d3_pd<br>Active High. Weak pull down for pad.                                                                                |
| 6          | RW          | 0x0                | gpio3d3_pu<br>Active High. Weak pull up for pad.                                                                                  |
| 5          | RW          | 0x1                | gpio3d2_pd<br>Active High. Weak pull down for pad.                                                                                |
| 4          | RW          | 0x0                | gpio3d2_pu<br>Active High. Weak pull up for pad.                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 3          | RW          | 0x1                | gpio3d1_pd<br>Active High. Weak pull down for pad. |
| 2          | RW          | 0x0                | gpio3d1_pu<br>Active High. Weak pull up for pad.   |
| 1          | RW          | 0x1                | gpio3d0_pd<br>Active High. Weak pull down for pad. |
| 0          | RW          | 0x0                | gpio3d0_pu<br>Active High. Weak pull up for pad.   |

**GPIO3 IOC GPIO3A SUS**

Address: Operational Base + offset (0x0220)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x0                | gpio3a7_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 6          | RW          | 0x0                | gpio3a6_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 5          | RW          | 0x0                | gpio3a5_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 4          | RW          | 0x0                | gpio3a4_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 3          | RW          | 0x0                | gpio3a3_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 2          | RW          | 0x0                | gpio3a2_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 1          | RW          | 0x0                | gpio3a1_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 0          | RO          | 0x0                | reserved                                                                                                                          |

**GPIO3 IOC GPIO3C SUS**

Address: Operational Base + offset (0x0228)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x0                | gpio3c7_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 2          | RW          | 0x0                | gpio3c6_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 1          | RW          | 0x0                | gpio3c5_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 0          | RW          | 0x0                | gpio3c4_sus<br>Active High. Weak pull keeper for pad.                                                                             |

**GPIO3 IOC GPIO3D SUS**

Address: Operational Base + offset (0x022C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x0                | gpio3d3_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 2          | RW          | 0x0                | gpio3d2_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 1          | RW          | 0x0                | gpio3d1_sus<br>Active High. Weak pull keeper for pad.                                                                             |
| 0          | RW          | 0x0                | gpio3d0_sus<br>Active High. Weak pull keeper for pad.                                                                             |

**GPIO3 IOC GPIO3A SL**

Address: Operational Base + offset (0x0260)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:14      | RW          | 0x3                | gpio3a7_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 13:12      | RW          | 0x3                | gpio3a6_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 11:10      | RW          | 0x3                | gpio3a5_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 9:8        | RW          | 0x3                | gpio3a4_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 7:6        | RW          | 0x3                | gpio3a3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 5:4        | RW          | 0x3                | gpio3a2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 3:2        | RW          | 0x3                | gpio3a1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                      |

**GPIO3 IOC GPIO3C SL**

Address: Operational Base + offset (0x0268)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:14      | RW          | 0x3                | gpio3c7_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 13:12      | RW          | 0x3                | gpio3c6_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 11:10      | RW          | 0x3                | gpio3c5_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 9:8        | RW          | 0x3                | gpio3c4_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 7:0        | RO          | 0x00               | reserved                                                                                                                                                      |

**GPIO3 IOC GPIO3D SL**

Address: Operational Base + offset (0x026C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                      |
| 7:6        | RW          | 0x3                | gpio3d3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 5:4        | RW          | 0x3                | gpio3d2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 3:2        | RW          | 0x3                | gpio3d1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 1:0        | RW          | 0x3                | gpio3d0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

**GPIO3 IOC GPIO3A IE SMT**

Address: Operational Base + offset (0x02A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 7          | RW          | 0x1                | gpio3a7_smt<br>Active High. Receiver enable for Schmitt trigger. |
| 6          | RW          | 0x1                | gpio3a6_smt<br>Active High. Receiver enable for Schmitt trigger. |
| 5          | RW          | 0x1                | gpio3a5_smt<br>Active High. Receiver enable for Schmitt trigger. |
| 4          | RW          | 0x1                | gpio3a4_smt<br>Active High. Receiver enable for Schmitt trigger. |
| 3          | RW          | 0x1                | gpio3a3_smt<br>Active High. Receiver enable for Schmitt trigger. |
| 2          | RW          | 0x1                | gpio3a2_smt<br>Active High. Receiver enable for Schmitt trigger. |
| 1          | RW          | 0x1                | gpio3a1_smt<br>Active High. Receiver enable for Schmitt trigger. |
| 0          | RO          | 0x0                | reserved                                                         |

**GPIO3 IOC GPIO3C IE SMT**

Address: Operational Base + offset (0x02A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio3c7_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 6          | RW          | 0x1                | gpio3c6_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 5          | RW          | 0x1                | gpio3c5_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 4          | RW          | 0x1                | gpio3c4_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 3:0        | RO          | 0x0                | reserved                                                                                                                          |

**GPIO3 IOC GPIO3D IE SMT**

Address: Operational Base + offset (0x02AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x1                | gpio3d3_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 2          | RW          | 0x1                | gpio3d2_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 1          | RW          | 0x1                | gpio3d1_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |
| 0          | RW          | 0x1                | gpio3d0_smt<br>Active High. Receiver enable for Schmitt trigger.                                                                  |

**GPIO3 IOC GPIO3A OD**

Address: Operational Base + offset (0x02E0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x0                | gpio3a7_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 6          | RW          | 0x0                | gpio3a6_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 5          | RW          | 0x0                | gpio3a5_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 4          | RW          | 0x0                | gpio3a4_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 3          | RW          | 0x0                | gpio3a3_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 2          | RW          | 0x0                | gpio3a2_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 1          | RW          | 0x0                | gpio3a1_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 0          | RO          | 0x0                | reserved                                                                                                                          |

**GPIO3 IOC GPIO3C OD**

Address: Operational Base + offset (0x02E8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x0                | gpio3c7_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 6          | RW          | 0x0                | gpio3c6_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 5          | RW          | 0x0                | gpio3c5_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 4          | RW          | 0x0                | gpio3c4_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 3:0        | RO          | 0x0                | reserved                                                                                                                          |

**GPIO3 IOC GPIO3D OD**

Address: Operational Base + offset (0x02EC)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4  | RO   | 0x000       | reserved                                                                                                                          |
| 3     | RW   | 0x0         | gpio2d3_od<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 2     | RW   | 0x0         | gpio3d2_0d<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 1     | RW   | 0x0         | gpio3d1_0d<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |
| 0     | RW   | 0x0         | gpio3d0_0d<br>1'b1: For open drain functionality<br>1'b0: Default for regular IO                                                  |

**GPIO3 IOC FORCE JTAG SDMMC**

Address: Operational Base + offset (0x02F4)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:1  | RO   | 0x0000      | reserved                                                                                                                          |
| 0     | RW   | 0x1         | jtag_sdmmc_auto_switch_en<br>This bit is used to enable sdmmc auto-switch to<br>a7_jtag_m0,active high.                           |

**4.15 GPIO4\_IOC Register Description****4.15.1 Registers Summary**

| Name                                 | Offset | Size | Reset Value | Description                                         |
|--------------------------------------|--------|------|-------------|-----------------------------------------------------|
| <u>GPIO4_IOC_GPIO4A_IOM_UX_SEL_L</u> | 0x0000 | W    | 0x00000000  | GPIO4A iomux configuration register 0               |
| <u>GPIO4_IOC_GPIO4A_IOM_UX_SEL_H</u> | 0x0004 | W    | 0x00000000  | GPIO4A iomux configuration register 1               |
| <u>GPIO4_IOC_GPIO4B_IOM_UX_SEL_L</u> | 0x0008 | W    | 0x00000000  | GPIO4B iomux configuration register 0               |
| <u>GPIO4_IOC_GPIO4C_IOM_UX_SEL_L</u> | 0x0010 | W    | 0x00000000  | GPIO4B iomux configuration register 0               |
| <u>GPIO4_IOC_GPIO4A_DS0</u>          | 0x0020 | W    | 0x00000F0F  | GPIO4A drive strength register 0                    |
| <u>GPIO4_IOC_GPIO4A_DS1</u>          | 0x0024 | W    | 0x00000F0F  | GPIO4A drive strength register 1                    |
| <u>GPIO4_IOC_GPIO4A_DS2</u>          | 0x0028 | W    | 0x00000F0F  | GPIO4A drive strength register 2                    |
| <u>GPIO4_IOC_GPIO4A_DS3</u>          | 0x002C | W    | 0x00000F0F  | GPIO4A drive strength register 3                    |
| <u>GPIO4_IOC_GPIO4B_DS0</u>          | 0x0030 | W    | 0x00000F0F  | GPIO4B drive strength register 0                    |
| <u>GPIO4_IOC_GPIO4A_IE</u>           | 0x0060 | W    | 0x000000FF  | GPIO4A input enable register                        |
| <u>GPIO4_IOC_GPIO4B_IE</u>           | 0x0064 | W    | 0x00000003  | GPIO4B input enable register                        |
| <u>GPIO4_IOC_GPIO4A_P</u>            | 0x0070 | W    | 0x00005555  | GPIO4A pull up and pull down configuration register |
| <u>GPIO4_IOC_GPIO4B_P</u>            | 0x0074 | W    | 0x00000009  | GPIO4B pull up and pull down configuration register |

| Name                           | Offset | Size | Reset Value | Description                          |
|--------------------------------|--------|------|-------------|--------------------------------------|
| <u>GPIO4_IOC_GPIO4A_SUS</u>    | 0x0080 | W    | 0x00000000  | GPIO4A keeper configuration register |
| <u>GPIO4_IOC_GPIO4B_SUS</u>    | 0x0084 | W    | 0x00000000  | GPIO4A keeper configuration register |
| <u>GPIO4_IOC_GPIO4A_SL</u>     | 0x0090 | W    | 0x0000FFFF  | GPIO4A skew rate register            |
| <u>GPIO4_IOC_GPIO4B_SL</u>     | 0x0094 | W    | 0x0000000F  | GPIO4B skew rate register            |
| <u>GPIO4_IOC_GPIO4A_IE_SMT</u> | 0x00A0 | W    | 0x000000FF  | GPIO4A Schmitt trigger register      |
| <u>GPIO4_IOC_GPIO4B_IE_SMT</u> | 0x00A4 | W    | 0x00000003  | GPIO4B Schmitt trigger register      |
| <u>GPIO4_IOC_GPIO4A_OD</u>     | 0x00B0 | W    | 0x00000000  | GPIO4A open drain register           |
| <u>GPIO4_IOC_GPIO4B_OD</u>     | 0x00B4 | W    | 0x00000000  | GPIO4B open drain register           |
| <u>GPIO4_IOC_SARADC_IOCON</u>  | 0x00C0 | W    | 0x00001300  | GPIO4C0/GPIO4C1 control              |
| <u>GPIO4_IOC_VCCIO3_VOLCON</u> | 0x0200 | W    | 0x00000004  | VCCIO3 voltage control register      |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

#### 4.15.2 Detail Registers Description

##### GPIO4\_IOC\_GPIO4A\_IOMUX\_SEL\_L

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                        |
| 15    | RO   | 0x0         | reserved                                                                                                                                                 |
| 14:12 | RW   | 0x0         | gpio4a3_sel<br>3'h0: GPIO4A3<br>3'h1: EMMC_D1<br>3'h2: FSPI_D1<br>Others: Reserved                                                                       |
| 11    | RO   | 0x0         | reserved                                                                                                                                                 |
| 10:8  | RW   | 0x0         | gpio4a2_sel<br>3'h0: GPIO4A2<br>3'h1: EMMC_D2<br>3'h2: FSPI_D2<br>Others: Reserved                                                                       |
| 7     | RO   | 0x0         | reserved                                                                                                                                                 |
| 6:4   | RW   | 0x0         | gpio4a1_sel<br>3'h0: GPIO4A1<br>3'h1: EMMC_D6<br>3'h2: SPI1_MOSI_M0<br>3'h3: UART0_TX_M2<br>3'h4: I2C0_SCL_M1<br>3'h5: TEST_CLK3_OUT<br>Others: Reserved |
| 3     | RO   | 0x0         | reserved                                                                                                                                                 |

| Bit | Attr | Reset Value | Description                                                                                                                                              |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | RW   | 0x0         | gpio4a0_sel<br>3'h0: GPIO4A0<br>3'h1: EMMC_D7<br>3'h2: SPI1_MISO_M0<br>3'h3: UART0_RX_M2<br>3'h4: I2C0_SDA_M1<br>3'h5: TEST_CLK2_OUT<br>Others: Reserved |

**GPIO4 IOC GPIO4A IOMUX SEL H**

Address: Operational Base + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual<br>1'b0: Write access disable<br>1'b1: Write access enable  |
| 15    | RO   | 0x0         | reserved                                                                                                                          |
| 14:12 | RW   | 0x0         | gpio4a7_sel<br>3'h0: GPIO4A7<br>3'h1: EMMC_D5<br>3'h2: SPI1_CLK_M0<br>3'h3: UART1_RX_M2<br>3'h4: I2C2_SCL_M1<br>Others: Reserved  |
| 11    | RO   | 0x0         | reserved                                                                                                                          |
| 10:8  | RW   | 0x0         | gpio4a6_sel<br>3'h0: GPIO4A6<br>3'h1: EMMC_D3<br>3'h2: FSPI_D3<br>Others: Reserved                                                |
| 7     | RO   | 0x0         | reserved                                                                                                                          |
| 6:4   | RW   | 0x0         | gpio4a5_sel<br>3'h0: GPIO4A5<br>3'h1: EMMC_D4<br>3'h2: SPI1_CS0n_M0<br>3'h3: UART1_TX_M2<br>3'h4: I2C2_SDA_M1<br>Others: Reserved |
| 3     | RO   | 0x0         | reserved                                                                                                                          |
| 2:0   | RW   | 0x0         | gpio4a4_sel<br>3'h0: GPIO4A4<br>3'h1: EMMC_D0<br>3'h2: FSPI_D0<br>Others: Reserved                                                |

**GPIO4 IOC GPIO4B IOMUX SEL L**

Address: Operational Base + offset (0x0008)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7  | RO   | 0x000       | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 6:4        | RW          | 0x0                | gpio4b1_sel<br>3'h0: GPIO4B1<br>3'h1: EMMC_CLK<br>3'h2: FSPI_CLK<br>Others: Reserved  |
| 3          | RO          | 0x0                | reserved                                                                              |
| 2:0        | RW          | 0x0                | gpio4b0_sel<br>3'h0: GPIO4B0<br>3'h1: EMMC_CMD<br>3'h2: FSPI_CS0n<br>Others: Reserved |

**GPIO4 IOC GPIO4C IOMUX SEL\_L**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio4c1_sel<br>3'h0: GPIO4C1<br>3'h1: ADC_IN1<br>3'h2: PWM1_M1<br>Others: Reserved                                                |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio4c0_sel<br>3'h0: GPIO4C0<br>3'h1: ADC_IN0<br>Others: Reserved                                                                 |

**GPIO4 IOC GPIO4A DS0**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x0f               | gpio4a1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x0f               | gpio4a0_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO4 IOC GPIO4A DS1**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x0f               | gpio4a3_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x0f               | gpio4a2_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO4 IOC GPIO4A DS2**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x0f               | gpio4a5_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x0f               | gpio4a4_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO4 IOC GPIO4A DS3**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x0f               | gpio4a7_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x0f               | gpio4a6_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO4 IOC GPIO4B DS0**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 13:8       | RW          | 0x0f               | gpio4b1_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                            |
| 5:0        | RW          | 0x0f               | gpio4b0_ds<br>The drive strength of IO which can be programmed from 2mA to 12mA, each bit controls 2mA of driving ability. The weakest setting is 6'b000001 and the strongest setting is 6'b111111. |

**GPIO4 IOC GPIO4A IE**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio4a7_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 6          | RW          | 0x1                | gpio4a6_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 5          | RW          | 0x1                | gpio4a5_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 4          | RW          | 0x1                | gpio4a4_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 3          | RW          | 0x1                | gpio4a3_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 2          | RW          | 0x1                | gpio4a2_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 1          | RW          | 0x1                | gpio4a1_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 0          | RW          | 0x1                | gpio4a0_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |

**GPIO4 IOC GPIO4B IE**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                          |
| 1          | RW          | 0x1                | gpio4b1_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 0          | RW          | 0x1                | gpio4b0_ie<br>Receiver enable.<br>1'b0: Disable<br>1'b1: Enable                                                                   |

**GPIO4 IOC GPIO4A P**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | gpio4a7_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 14         | RW          | 0x1                | gpio4a7_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable                                                              |
| 13         | RW          | 0x0                | gpio4a6_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 12         | RW          | 0x1                | gpio4a6_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable                                                              |
| 11         | RW          | 0x0                | gpio4a5_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 10         | RW          | 0x1                | gpio4a5_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable                                                              |
| 9          | RW          | 0x0                | gpio4a4_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 8          | RW          | 0x1                | gpio4a4_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |
| 7          | RW          | 0x0                | gpio4a3_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 6          | RW          | 0x1                | gpio4a3_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |
| 5          | RW          | 0x0                | gpio4a2_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 4          | RW          | 0x1                | gpio4a2_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |
| 3          | RW          | 0x0                | gpio4a1_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x1                | gpio4a1_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |
| 1          | RW          | 0x0                | gpio4a0_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x1                | gpio4a0_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |

**GPIO4 IOC GPIO4B P**

Address: Operational Base + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                          |
| 3          | RW          | 0x1                | gpio4b1_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 2          | RW          | 0x0                | gpio4b1_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 1          | RW          | 0x0                | gpio4b0_pd<br>Weak pull down for pad.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x1                | gpio4b0_pu<br>Weak pull up for pad.<br>1'b0: Disable<br>1'b1: Enable   |

**GPIO4 IOC GPIO4A SUS**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x0                | gpio4a7_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 6          | RW          | 0x0                | gpio4a6_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 5          | RW          | 0x0                | gpio4a5_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 4          | RW          | 0x0                | gpio4a4_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 3          | RW          | 0x0                | gpio4a3_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 2          | RW          | 0x0                | gpio4a2_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 1          | RW          | 0x0                | gpio4a1_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 0          | RW          | 0x0                | gpio4a0_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |

**GPIO4 IOC GPIO4B SUS**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                          |
| 1          | RW          | 0x0                | gpio4a1_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 0          | RW          | 0x0                | gpio4a0_sus<br>Weak pull keeper for pad.<br>1'b0: Disable<br>1'b1: Enable                                                         |

**GPIO4 IOC GPIO4A SL**

Address: Operational Base + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:14      | RW          | 0x3                | gpio4a7_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 13:12      | RW          | 0x3                | gpio4a6_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 11:10      | RW          | 0x3                | gpio4a5_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 9:8        | RW          | 0x3                | gpio4a4_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 7:6        | RW          | 0x3                | gpio4a3_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 5:4        | RW          | 0x3                | gpio4a2_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 3:2        | RW          | 0x3                | gpio4a1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 1:0        | RW          | 0x3                | gpio4a0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

**GPIO4 IOC GPIO4B SL**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:4       | RO          | 0x000              | reserved                                                                                                                                                      |
| 3:2        | RW          | 0x3                | gpio4b1_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |
| 1:0        | RW          | 0x3                | gpio4b0_sl<br>Slew rate control for the driver section, while driving pad, 2'b11 is fastest and 2'b00 is slowest.<br>Always set to 2'b11 in normal operation. |

**GPIO4 IOC GPIO4A IE SMT**

Address: Operational Base + offset (0x00A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio4a7_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 6          | RW          | 0x1                | gpio4a6_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 5          | RW          | 0x1                | gpio4a5_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 4          | RW          | 0x1                | gpio4a4_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 3          | RW          | 0x1                | gpio4a3_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 2          | RW          | 0x1                | gpio4a2_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 1          | RW          | 0x1                | gpio4a1_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 0          | RW          | 0x1                | gpio4a0_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |

**GPIO4 IOC GPIO4B IE SMT**

Address: Operational Base + offset (0x00A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                          |
| 1          | RW          | 0x1                | gpio4b1_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 0          | RW          | 0x1                | gpio4b0_smt<br>Receiver enable for schmitt trigger.<br>1'b0: Disable<br>1'b1: Enable                                              |

**GPIO4 IOC GPIO4A OD**

Address: Operational Base + offset (0x00B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x0                | gpio4a7_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 6          | RW          | 0x0                | gpio4a6_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 5          | RW          | 0x0                | gpio4a5_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 4          | RW          | 0x0                | gpio4a4_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 3          | RW          | 0x0                | gpio4a3_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 2          | RW          | 0x0                | gpio4a2_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 1          | RW          | 0x0                | gpio4a1_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 0          | RW          | 0x0                | gpio4a0_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |

**GPIO4 IOC GPIO4B OD**

Address: Operational Base + offset (0x00B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                          |
| 1          | RW          | 0x0                | gpio4b1_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |
| 0          | RW          | 0x0                | gpio4b0_od<br>1'b0: Default for regular IO<br>1'b1: For open drain functionality                                                  |

**GPIO4 IOC SARADC IO CON**

Address: Operational Base + offset (0x00C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                        |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                 |
| 14         | RW          | 0x0                | saradc_io_ps<br>SARADC IO Pull selector signal, high active.<br>PE=1'b0: High Z<br>PE=1'b1: PS=1'b1, pull up<br>PE=1'b1: PS=1'b0, pull down<br>Shared by two SARADC IO.                                  |
| 13         | RW          | 0x0                | saradc_io_pe<br>SARADC IO Pull selector signal, high active.<br>PE=1'b0: High Z<br>PE=1'b1: PS=1'b1, pull up<br>PE=1'b1: PS=1'b0, pull down<br>Shared by two SARADC IO.                                  |
| 12         | RW          | 0x1                | saradc_io_sl<br>SARADC IO Slew rate signal, high active.<br>Shared by two SARADC IO.                                                                                                                     |
| 11         | RW          | 0x0                | saradc_io_ds1<br>SARADC IO DS1 signal, driving selector.<br>(DS1,DS0) = 2'b00: 10.8mA<br>(DS1,DS0) = 2'b01: 21.5mA<br>(DS1,DS0) = 2'b10: 32.1mA<br>(DS1,DS0) = 2'b11: 42.4mA<br>Shared by two SARADC IO. |
| 10         | RW          | 0x0                | saradc_io_ds0<br>SARADC IO DS1 signal, driving selector.<br>(DS1,DS0) = 2'b00: 10.8mA<br>(DS1,DS0) = 2'b01: 21.5mA<br>(DS1,DS0) = 2'b10: 32.1mA<br>(DS1,DS0) = 2'b11: 42.4mA<br>Shared by two SARADC IO. |
| 9          | RW          | 0x1                | saradc_io_st1<br>SARADC IO Schmitt trigger enable signal, high active.<br>Shared by two SARADC IO.                                                                                                       |
| 8          | RW          | 0x1                | saradc_io_st0<br>SARADC IO Schmitt trigger enable signal, high active.<br>Shared by two SARADC IO.                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 7:4        | RO          | 0x0                | reserved                                                      |
| 3          | RW          | 0x0                | saradc_io_ie1<br>SARADC IO1 input enable signal, high active. |
| 2          | RW          | 0x0                | saradc_io_ie0<br>SARADC IO0 input enable signal, high active. |
| 1          | RW          | 0x0                | saradc_io_he1<br>SARADC IO1 Hold enable signal, high active.  |
| 0          | RW          | 0x0                | saradc_io_he0<br>SARADC IO0 Hold enable signal, high active.  |

**GPIO4 IOC VCCIO3 VOL CON**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                             |
| 15:5       | RO          | 0x000              | reserved                                                                                                                                                      |
| 4          | RO          | 0x0                | vccio3_vd<br>VCCIO3 voltage detection.<br>1'b0: VDDO is 1.8v<br>1'b1: VDDO is 3.3v                                                                            |
| 3          | RW          | 0x0                | vccio3_iddq_sw<br>Software configuration for VCCIO3 IDDQ pin.<br>Set 1 for IDDQ testing.                                                                      |
| 2          | RW          | 0x1                | vccio3_cle_sw<br>Software configuration for VCCIO3 CLE pin.<br>Set to 1 for VDDO=3.3v operation.                                                              |
| 1          | RW          | 0x0                | vccio3_v18_sw<br>Software configuration for VCCIO3 V18 pin.<br>Set to 1 for VDDO=1.8v operation.                                                              |
| 0          | RW          | 0x0                | vccio3_vsel<br>VCCIO3 voltage pin(V18/CLE/IDDQ) controller selection.<br>1'b0: Voltage pin controlled by hardware<br>1'b1: Voltage pin controlled by software |

## Chapter 5 Cortex-A7

### 5.1 Overview

The Cortex-A7 subsystem of the device is based on the ARMv7-A architecture. The Cortex-A7 has one Cortex-A7 central processing unit (CPU). Each processor has 32KB of Level 1 (L1) instruction cache, 32KB of L1 data cache, NEON and FPU. The Cortex-A7 also includes 128KB of Level 2 (L2) cache, Snoop Control Unit(SCU), Generic Interrupt Controller (GIC), and standard CoreSight components to support SMP debug and emulation.

The key features of the Cortex-A7 include:

- ARM Cortex-A7
  - Full implements the ARMv7-A architecture profile that includes the Advanced SIMD and VFP Extensions
  - 1 Cortex-A7 processor cores
  - 32KB L1 I-Cache and 32KB L1 D-Cache per CPU
  - In-order pipeline with direct and indirect branch prediction
  - Harvard L1 memory system with a Memory Management Unit (MMU)
  - SCU ensures memory coherency
  - Interrupt controller with 128 hardware interrupt inputs
- 128KB L2 cache
  - Fixed line length of 64 bytes
  - Physically indexed and tagged cache
  - 8-way set-associative cache structure
  - Pseudo-random cache replacement policy

### 5.2 Block Diagram



Fig. 5-1 Core Subsystem Architecture

### 5.3 Function Description

Please refer to the document [Cortex-A7 MPCore Technical Reference Manual](#) for the CPU detail description.

### 5.4 Register Description

Please refer to the document [Cortex-A7 MPCore Technical Reference Manual](#) for the CPU detail description.

## Chapter 6 Embedded SRAM

### 6.1 Overview

There are two embedded SRAMs, SYSTEM\_SRAM and PMU\_SRAM.

- SYSTEM\_SRAM
  - Provide 256KB access space
  - Support security and non-security access
  - Secure or non-secure space is software programmable
- PMU\_SRAM
  - Provide 8KB access space
  - Support secure access only

### 6.2 Block Diagram

The following figure shows the block diagram of Share Memory.



Fig. 6-1 Block Diagram of SRAM

### 6.3 Function Description

#### 6.3.1 PMU SRAM Access

PMU SRAM is secure only and base address is 0xFF670000. Only CPU, MCU and CRYPTO can access PMU SRAM

#### 6.3.2 SYSTEM SRAM Access

All the masters that can access SYSTEM SRAM is shown in the above figure. The security is decided by the firewall and can be set by SRAM firewall. There are 8 regions can configured to secure or non-secure and each master can be disabled.

## Chapter 7 PMU

### 7.1 Overview

In order to meet low power requirements, a power management unit (PMU) is designed for controlling power resources in RV1106. The RV1106 PMU is dedicated for managing the power of the whole chip.

PMU supports the following features:

- Support multi voltage domains: VD\_CORE, VD\_LOGIC, VD\_PMU
- Support BIU idle operations: BIU\_MSCH, BIU\_DDR, BIU\_NPU, BIU\_NPU\_ACLK, BIU\_VI, BIU\_VO, BIU\_PERI, BIU\_CRU, BIU\_CPU, BIU\_VENC\_COM, BIU\_VENC
- Support to send idle request to BIU
- Support global interrupt disable in low power mode
- Support low frequency clock source from PMU PVTM or RTC
- Support PMU clock switch to low frequency clock in low power mode
- Support PLLs power down/up by hardware in low power mode
- Support OSC enable/disable request in low power mode
- Support to clamp all VD\_PMU input before power off VD\_LOGIC in low power mode
- Support wakeup reset control in power off mode
- Support DDR self-refresh in low power mode
- Support block clock auto gating in low power mode
- Support varies configurable wakeup source for low power mode

### 7.2 Block Diagram

The following figure is the PMU block diagram. The PMU includes 3 following sections:

- APB Interface and Register: Provide AMBA APB interface for register read and write
- System Power State Control: Provide power management for various low power modes
- Power Gating Control: Provide power gating control for power domains



Fig. 7-1 PMU Bock Diagram

### 7.3 Function Description

#### 7.3.1 Block Description

The following table lists IPs in every block or voltage domain.

Table 7-1 Block Description Summary

| <b>Voltage Domain</b> | <b>Block Partition</b> | <b>Description</b>                                                                                                                                                                                                            |
|-----------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VD_CORE               | CORE_WRAPPER           | CORE_BIU<br>CRU_CORE<br>CORE_GRF<br>CORE_SGRF<br>CORTEXA7<br>DAP_LITE<br>HPMCU<br>CORE_MAILBOX<br>CORE_PVTM<br>CORE_PVTPLL                                                                                                    |
| VDD_PMU               | PMU_WRAPPER            | PMU_BIU<br>CRU_PMU<br>PMU_GRF<br>PMU_SGRF<br>PMU_SRAM<br>PMU_PVTM<br>PMU_WDT<br>PMU_MAILBOX<br>PMU<br>LPMCU<br>I2C1<br>HPTIMER<br>DDR_FAIL_SAFE<br>GPIO0<br>PMUIO_IOC<br>NPOR<br>PAD_RING_PMU<br>APLL<br>CPLL<br>DPLL<br>GPLL |
| VDD_LOGIC             | CRU_WRAPPER            | CRU_NIU<br>CRU<br>PVTPLL0/1<br>PVTPLL_GRF<br>APLL_WRAPPER<br>CPLL_WRAPPER<br>DPLL_WRAPPER<br>GPLL_WRAPPER                                                                                                                     |
|                       | DDR_WRAPPER            | MSCH<br>CRU_DDR<br>CRU_SUBDDR<br>DDR_GRF<br>DDR_CTL<br>DFI_CTL<br>DFI_RS<br>HW_LP_CTRL<br>DDR_MONITOR<br>SYSTEM_MEMORY<br>DDRPHY_WRAPPER<br>DDRPHY                                                                            |
|                       | PERI_WRAPPER           | PERI_BIU<br>CRU_PERI<br>PERI_GRF<br>PERI_SGRF                                                                                                                                                                                 |

| Voltage Domain | Block Partition | Description                                                                                                                                                                                                                                                                                                                                        |
|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |                 | DMAC<br>SCRYPTO<br>DECOM<br>IVE<br>BOOTROM<br>SEC_TRNG_S<br>SEC_TRNG_NS<br>I2S<br>SAI<br>DSM<br>ACODEC_WRAPPER<br>SFC<br>EMMC<br>USBOTG<br>USBPHY_WRAPPER<br>WDT_S<br>WDT_NS<br>TIMER_S(TIMER_2CH)<br>TIMER_NS(TIMER_6CH)<br>UART0/1/2/3/4/5<br>I2C0/2/3/4<br>SPI1<br>SARADC_CON<br>SARADC_WRAPPER<br>GPIO4<br>VCCIO3_IOC<br>DFT2APB<br>TM_DECODER |
|                | NPU_WRAPPER     | NPU_BIU<br>CRU_NPU<br>NPU_GRF<br>NPU_SGRF<br>RKNN                                                                                                                                                                                                                                                                                                  |
|                | VENC_WRAPPER    | VENC_BIU<br>CRU_VENC<br>VENC_GRF<br>VENC_SGRF<br>VENC<br>VEPU_PP<br>VEPU_DVBM<br>SPI0<br>GPIO1<br>VENCIO_IOC                                                                                                                                                                                                                                       |
|                | VI_WRAPPER      | VI_BIU<br>CRU_VI<br>VI_GRF<br>VI_SGRF<br>VICAP<br>CSIHOST0/1<br>CSIPHY_WRAPPER<br>ISP<br>SDMMC<br>RTC_TEST<br>GPIO3<br>VIIO_IOC                                                                                                                                                                                                                    |

| Voltage Domain | Block Partition | Description                                                                                                                                                                |
|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | VO_WRAPPER      | VO_BIU<br>CRU_VO<br>VO_GRF<br>VO_SGRF<br>VOP<br>RGA<br>SDIO<br>GMAC<br>MACPHY_WRAPPER<br>OTPC_S<br>OTPC_NS<br>OTP_WRAPPER<br>TSADC<br>TSADC_WRAPPER<br>GPIO2<br>VCCIO5_IOC |
|                | TOP             | CSIPHY<br>USBPHY<br>SARADC<br>TSADC<br>OTP<br>MACPHY<br>ACODEC<br>PAD_RING_TOP                                                                                             |
| VDD_RTC        | RTC_WRAPPER     | RTC                                                                                                                                                                        |

### 7.3.2 Operation Mode

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 registers. For example, LPMCU can write PMU\_BIU\_IDLE\_SFTCON register to determine BIU idle 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 be delayed to execute after FSM running in particular phase.

To enter low power mode, after setting some power configurations, the PMU\_PWR\_CON[0] bit must be set 1 to enable PMU FSM. Then CPU needs to execute a WFI command to perform ready signal if PMU\_SCU\_PWR\_CON[2] is 0. After PMU detects CPU in WFI status, 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 RV1106 chip.

## 7.4 Register Description

### 7.4.1 Registers Summary

| Name                | Offset | Size | Reset Value | Description                       |
|---------------------|--------|------|-------------|-----------------------------------|
| PMU_VERSION         | 0x0000 | W    | 0x030A0000  | PMU version register              |
| PMU_PWR_CON         | 0x0004 | W    | 0x00000000  | PMU power control register        |
| PMU_GLB_POWER_STS   | 0x0008 | W    | 0x00000000  | PMU power status register         |
| PMU_INT_MASK_CON    | 0x000C | W    | 0x00000000  | Interrupt mask control register   |
| PMU_WAKEUP_INT_CON  | 0x0010 | W    | 0x00000000  | Wakeup interrupt control register |
| PMU_WAKEUP_INT_ST   | 0x0014 | W    | 0x00000000  | Wakeup interrupt status register  |
| PMU_PMIC_STABLE_CNT | 0x0024 | W    | 0x000FFFFF  | PMIC stable counter register      |

| Name                   | Offset | Size | Reset Value | Description                                       |
|------------------------|--------|------|-------------|---------------------------------------------------|
| PMU OSC STABLE_CNT     | 0x0028 | W    | 0x000FFFFF  | OSC stable counter register                       |
| PMU WAKEUP_RSTCLR_CNT  | 0x002C | W    | 0x000FFFFF  | Wakeup reset clear counter register               |
| PMU PLL_LOCK_CNT       | 0x0030 | W    | 0x000FFFFF  | PLL lock counter register                         |
| PMU WAKEUP_TIMEOUT_CNT | 0x0048 | W    | 0x00005DC0  | WAKEUP timeout counter register                   |
| PMU PWM_SWITCH_CNT     | 0x004C | W    | 0x000FFFFF  | PWM switch stable counter register                |
| PMU SCU_PWR_CON        | 0x0080 | W    | 0x00000000  | Wakeup interrupt control register                 |
| PMU SCU_STS            | 0x0080 | W    | 0x00000000  | SCU status register                               |
| PMU BIU_IDLE_CON       | 0x00B0 | W    | 0x00000000  | BIU idle request hardware control register        |
| PMU BIU_IDLE_SFTCON    | 0x00C0 | W    | 0x00000000  | BIU idle request software control register        |
| PMU BIU_IDLE_ACK       | 0x00D0 | W    | 0x00000000  | BIU idle acknowledge status register              |
| PMU BIU_IDLE_ST        | 0x00D8 | W    | 0x00000000  | BIU idle status register                          |
| PMU BIU_AUTO_CON       | 0x00E0 | W    | 0x00000000  | BIU automatic power control register              |
| PMU DDR_PWR_CON        | 0x00F0 | W    | 0x00000000  | DDR power hardware control register               |
| PMU DDR_PWR_SFTCON     | 0x00F4 | W    | 0x00000000  | DDR power software control register               |
| PMU DDR_POWER_STS      | 0x00F8 | W    | 0x00000000  | DDR power state register                          |
| PMU DDR_STS            | 0x00FC | W    | 0x00000000  | DDR status register                               |
| PMU CRU_PWR_CON0       | 0x0120 | W    | 0x00000000  | Clock and reset hardware power control register 0 |
| PMU CRU_PWR_CON1       | 0x0140 | W    | 0x00000000  | Clock and reset hardware power control register 1 |
| PMU CRU_PWR_SFTCON     | 0x0124 | W    | 0x00000000  | Clock and reset software power control register   |
| PMU CRU_POWER_STS      | 0x0128 | W    | 0x00000000  | Clock and reset power state register              |
| PMU_PLLPD_CON          | 0x0130 | W    | 0x00000000  | PLL power hardware control register               |
| PMU_PLLPD_SFTCON       | 0x0134 | W    | 0x00000000  | PLL power software control register               |
| PMU_INFO_TX_CON        | 0x0150 | W    | 0x00000000  | PMU information transmit control register         |
| PMU_SYS_REG0           | 0x01C0 | W    | 0x00000000  | PMU system register 0                             |
| PMU_SYS_REG1           | 0x01C4 | W    | 0x00000000  | PMU system register 1                             |
| PMU_SYS_REG2           | 0x01C8 | W    | 0x00000000  | PMU system register 2                             |
| PMU_SYS_REG3           | 0x01CC | W    | 0x00000000  | PMU system register 3                             |
| PMU_SYS_REG4           | 0x01D0 | W    | 0x00000000  | PMU system register 4                             |
| PMU_SYS_REG5           | 0x01D4 | W    | 0x00000000  | PMU system register 5                             |
| PMU_SYS_REG6           | 0x01D8 | W    | 0x00000000  | PMU system register 6                             |
| PMU_SYS_REG7           | 0x01DC | W    | 0x00000000  | PMU system register 7                             |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

#### 7.4.2 Detail Register Description

##### PMU VERSION

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:0       | RO          | 0x030a0000         | version<br>PMU version number |

**PMU\_PWR\_CON**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                   |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                             |
| 7          | RW          | 0x0                | cru_bypass<br>Bypass clock and reset low power flow in low power procedure.<br>If asserted, PMU_CRU_PWR_CON cannot take effect for clock and reset low power flow. If you want to execute clock and reset low power flow, you can program PMU_CRU_PWR_SFTCON through software flow.<br>1'b0: Disable<br>1'b1: Enable |
| 6          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                             |
| 5          | RW          | 0x0                | ddr_bypass<br>Bypass DDR low power flow in low power procedure.<br>If asserted, PMU_DDR_PWR_CON cannot take effect for DDR low power flow. If you want to execute DDR low power flow, you can program PMU_DDR_SFTCON through software flow.<br>1'b0: Disable<br>1'b1: Enable                                         |
| 4          | RW          | 0x0                | bus_bypass<br>Bypass BIU idle request in low power procedure.<br>If asserted, PMU_BIU_IDLE_CON cannot take effect for BIU idle request. If you want to execute BIU idle request, you can program PMU_BIU_IDLE_SFTCON through software flow.<br>1'b0: Disable<br>1'b1: Enable                                         |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                             |
| 0          | R/W SC      | 0x0                | powermode_en<br>Low power mode enable. When controller enters low power flow, this bit is automatically cleared.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                    |

**PMU\_GLB\_POWER\_STS**

Address: Operational Base + offset (0x0008)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RO          | 0x0                | <p>power_state<br/>PMU global power state.</p> <p>4'h0: Normal state<br/>4'h1: SCU low power state<br/>4'h3: Bus low power state<br/>4'h4: DDR low power state<br/>4'h5: Power gating low power state<br/>4'h6: Clock and reset low power state<br/>4'h7: Sleep state<br/>4'h8: Clock and reset active state<br/>4'h9: Power gating active state<br/>4'ha: DDR active state<br/>4'hb: Bus active state<br/>4'hd: SCU active state<br/>Others: Reserved</p> |

**PMU INT MASK CON**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_enable<br/>Write enable for lower 16 bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p> |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                                        |
| 0          | RW          | 0x0                | <p>glb_int_mask<br/>Global interrupt mask during low power procedure.</p> <p>1'b0: Disable<br/>1'b1: Enable</p>                                 |

**PMU WAKEUP INT CON**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                               |
| 7          | RW          | 0x0                | <p>pmu_sft_wakeup_cfg<br/>Software wakeup enable.</p> <p>1'b0: Disable<br/>1'b1: Enable</p>                            |
| 6          | RW          | 0x0                | <p>wakeup_timerout_en<br/>Enable PMU timeout interrupt as wakeup source.</p> <p>1'b0: Disable<br/>1'b1: Enable</p>     |
| 5          | RW          | 0x0                | <p>wakeup_timer_en<br/>Enable HPTIMER interrupt as wakeup source.</p> <p>1'b0: Disable<br/>1'b1: Enable</p>            |
| 4          | RW          | 0x0                | <p>wakeup_usbdev_en<br/>Enable USB device detect interrupt as wakeup source.</p> <p>1'b0: Disable<br/>1'b1: Enable</p> |
| 3          | RW          | 0x0                | <p>wakeup_sdio_en<br/>Enable SDIO interrupt as wakeup source.</p> <p>1'b0: Disable<br/>1'b1: Enable</p>                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | wakeup_sdmmc_en<br>Enable SDMMC detect interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | wakeup_gpio_int_en<br>Enable GPIO0 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable     |
| 0          | RW          | 0x0                | wakeup_cpu_int_en<br>Enable CPU interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable        |

**PMU\_WAKEUP\_INT\_ST**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                       |
| 6          | RO          | 0x0                | wakeup_timerout_int_st<br>PMU timeout interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active     |
| 5          | RO          | 0x0                | wakeup_timer_int_st<br>HPTIMER interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active            |
| 4          | RO          | 0x0                | wakeup_usbdev_int_st<br>USB device detect interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active |
| 3          | RO          | 0x0                | wakeup_sdio_int_st<br>SDIO interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                |
| 2          | RO          | 0x0                | wakeup_sdmmc_int_st<br>SDMMC detect interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active       |
| 1          | RO          | 0x0                | wakeup_gpio_int_st<br>GPIO0 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active               |
| 0          | RO          | 0x0                | wakeup_cpu_int_st<br>CPU interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active                  |

**PMU\_PMIC\_STABLE\_CNT**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                 |
| 19:0       | RW          | 0xfffff            | stable_cnt<br>PMIC power stable counter for CRU from power off to wakeup |

**PMU\_OSC\_STABLE\_CNT**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                          |
| 19:0       | RW          | 0xfffff            | stable_cnt<br>OSC stable counter for OSC from power off to wakeup |

**PMU WAKEUP\_RSTCLR\_CNT**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                       |
| 19:0       | RW          | 0xfffff            | wakeup_RSTCLR_CNT<br>Stable counter for CRU wakeup reset clear |

**PMU PLL\_LOCK\_CNT**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                  |
| 19:0       | RW          | 0xfffff            | pll_lock_cnt<br>Lock counter for PLL from powerup to lock |

**PMU WAKEUP\_TIMEOUT\_CNT**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:0       | RW          | 0x000005dc0        | wakeup_timeout_cnt<br>WAKEUP timeout counter |

**PMU PWM\_SWITCH\_CNT**

Address: Operational Base + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                |
| 19:0       | RW          | 0xfffff            | stable_cnt<br>PWM switch stable counter |

**PMU SCU\_PWR\_CON**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                                                                                                               |
| 2          | RW          | 0x0                | standbywfi_byass<br>Bypass core standbywfi.<br>1'b0: Disable. PMU should not execute low power procedure until core enters wfi state.<br>1'b1: Enable, PMU will execute low power procedure not caring core wfi state. |
| 1          | RW          | 0x0                | cpu_int_mask_ena<br>Interrupt mask for CPU during low power procedure.<br>1'b0: Disable<br>1'b0: Enable                                                                                                                |
| 0          | RW          | 0x0                | scu_int_mask_ena<br>Interrupt mask for SCU during low power procedure.<br>1'b0: Disable<br>1'b0: Enable                                                                                                                |

**PMU SCU\_STS**

Address: Operational Base + offset (0x0080)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 1          | RO          | 0x0                | standbywfil2<br>L2 standbywifi state.<br>1'b0: Inactive<br>1'b1: Active |
| 0          | RO          | 0x0                | standbywfi<br>CPU standbywfi state.<br>1'b0: Inactive<br>1'b1: Active   |

**PMU BIU IDLE CON**

Address: Operational Base + offset (0x00B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:11      | RO          | 0x00               | reserved                                                                                                                           |
| 10         | RW          | 0x0                | idle_req_vepu<br>Enable sending bus idle request to BIU_VEPU by hardware.<br>1'b0: Disable<br>1'b1: Enable                         |
| 9          | RW          | 0x0                | idle_req_venc_com<br>Enable sending bus idle request to BIU_VENC_COM by hardware.<br>1'b0: Disable<br>1'b1: Enable                 |
| 8          | RW          | 0x0                | idle_req_cpu<br>Enable sending bus idle request to BIU_CPU by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |
| 7          | RW          | 0x0                | idle_req_cru<br>Enable sending bus idle request to BIU_CRU by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |
| 6          | RW          | 0x0                | idle_req_peri<br>Enable sending bus idle request to BIU_PERI by hardware.<br>1'b0: Disable<br>1'b1: Enable                         |
| 5          | RW          | 0x0                | idle_req_vo<br>Enable sending bus idle request to BIU_VO by hardware.<br>1'b0: Disable<br>1'b1: Enable                             |
| 4          | RW          | 0x0                | idle_req_vi<br>Enable sending bus idle request to BIU_VI by hardware.<br>1'b0: Disable<br>1'b1: Enable                             |
| 3          | RW          | 0x0                | idle_req_npu_aclk<br>Enable sending bus idle request to BIU_NPU_ACLK by hardware.<br>1'b0: Disable<br>1'b1: Enable                 |
| 2          | RW          | 0x0                | idle_req_npu<br>Enable sending idle request to BIU_NPU by hardware.<br>1'b0: Disable<br>1'b1: Enable                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | idle_req_ddr<br>Enable sending bus idle request to BIU_DDR by hardware.<br>1'b0: Disable<br>1'b1: Enable   |
| 0          | RW          | 0x0                | idle_req_msch<br>Enable sending bus idle request to BIU_MSCH by hardware.<br>1'b0: Disable<br>1'b1: Enable |

**PMU BIU IDLE SFTCON**

Address: Operational Base + offset (0x00C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:11      | RO          | 0x00               | reserved                                                                                                                           |
| 10         | RW          | 0x0                | idle_req_vepu<br>Enable sending bus idle request to BIU_VEPU by software.<br>1'b0: Disable<br>1'b1: Enable                         |
| 9          | RW          | 0x0                | idle_req_venc_com<br>Enable sending bus idle request to BIU_VENC_COM by software.<br>1'b0: Disable<br>1'b1: Enable                 |
| 8          | RW          | 0x0                | idle_req_cpu<br>Enable sending bus idle request to BIU_CPU by software.<br>1'b0: Disable<br>1'b1: Enable                           |
| 7          | RW          | 0x0                | idle_req_cru<br>Enable sending bus idle request to BIU_CRU by software.<br>1'b0: Disable<br>1'b1: Enable                           |
| 6          | RW          | 0x0                | idle_req_peri<br>Enable sending bus idle request to BIU_PERI by software.<br>1'b0: Disable<br>1'b1: Enable                         |
| 5          | RW          | 0x0                | idle_req_vo<br>Enable sending bus idle request to BIU_VO by software.<br>1'b0: Disable<br>1'b1: Enable                             |
| 4          | RW          | 0x0                | idle_req_vi<br>Enable sending bus idle request to BIU_VI by software.<br>1'b0: Disable<br>1'b1: Enable                             |
| 3          | RW          | 0x0                | idle_req_npu_aclk<br>Enable sending bus idle request to BIU_NPU_ACLK by software.<br>1'b0: Disable<br>1'b1: Enable                 |
| 2          | RW          | 0x0                | idle_req_npu<br>Enable sending idle request to BIU_NPU by software.<br>1'b0: Disable<br>1'b1: Enable                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | idle_req_ddr<br>Enable sending bus idle request to BIU_DDR by software.<br>1'b0: Disable<br>1'b1: Enable   |
| 0          | RW          | 0x0                | idle_req_msch<br>Enable sending bus idle request to BIU_MSCH by software.<br>1'b0: Disable<br>1'b1: Enable |

**PMU BIU IDLE ACK**

Address: Operational Base + offset (0x00D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:11      | RO          | 0x000000           | reserved                                                                                                    |
| 10         | RO          | 0x0                | idle_ack_vepu<br>BIU_VEPU bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge         |
| 9          | RO          | 0x0                | idle_ack_venc_com<br>BIU_VENC_COM bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |
| 8          | RO          | 0x0                | idle_ack_cpu<br>BIU_CPU bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge           |
| 7          | RO          | 0x0                | idle_ack_cru<br>BIU_CRU bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge           |
| 6          | RO          | 0x0                | idle_ack_peri<br>BIU_PERI bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge         |
| 5          | RO          | 0x0                | idle_ack_vo<br>BIU_VO bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge             |
| 4          | RO          | 0x0                | idle_ack_vi<br>BIU_VI bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge             |
| 3          | RO          | 0x0                | idle_ack_npu_aclk<br>BIU_NPU_ACLK bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |
| 2          | RO          | 0x0                | idle_ack_npu<br>BIU_NPU bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge           |
| 1          | RO          | 0x0                | idle_ack_ddr<br>BIU_DDR bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | idle_ack_msch<br>BIU_MSCH bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |

**PMU BIU IDLE ST**

Address: Operational Base + offset (0x00D8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:11      | RO          | 0x000000           | reserved                                                                  |
| 10         | RO          | 0x0                | idle_vepu<br>BIU_VEPU idle state.<br>1'b0: Not idle<br>1'b1: Idle         |
| 9          | RO          | 0x0                | idle_venc_com<br>BIU_VENC_COM idle state.<br>1'b0: Not idle<br>1'b1: Idle |
| 8          | RO          | 0x0                | idle_cpu<br>BIU_CPU idle state.<br>1'b0: Not idle<br>1'b1: Idle           |
| 7          | RO          | 0x0                | idle_cru<br>BIU_CRU idle state.<br>1'b0: Not idle<br>1'b1: Idle           |
| 6          | RO          | 0x0                | idle_peri<br>BIU_PERI idle state.<br>1'b0: Not idle<br>1'b1: Idle         |
| 5          | RO          | 0x0                | idle_vo<br>BIU_VO idle state.<br>1'b0: Not idle<br>1'b1: Idle             |
| 4          | RO          | 0x0                | idle_vi<br>BIU_VI idle state.<br>1'b0: Not idle<br>1'b1: Idle             |
| 3          | RO          | 0x0                | idle_npu_aclk<br>BIU_NPU_ACLK idle state.<br>1'b0: Not idle<br>1'b1: Idle |
| 2          | RO          | 0x0                | idle_npu<br>BIU_NPU idle state.<br>1'b0: Not idle<br>1'b1: Idle           |
| 1          | RO          | 0x0                | idle_ddr<br>NIU_DDR idle state.<br>1'b0: Not idle<br>1'b1: Idle           |
| 0          | RO          | 0x0                | idle_msch<br>BIU_MSCH idle state.<br>1'b0: Not idle<br>1'b1: Idle         |

**PMU BIU AUTO CON**

Address: Operational Base + offset (0x00E0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                           |
| 15:11      | RO          | 0x00               | reserved                                                                                                                                                     |
| 10         | RW          | 0x0                | auto_idle_vepu<br>If enable, BIU_VEPU corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable         |
| 9          | RW          | 0x0                | auto_idle_venc_com<br>If enable, BIU_VENC_COM corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable |
| 8          | RW          | 0x0                | auto_idle_cpu<br>If enable, BIU_CPU corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable           |
| 7          | RW          | 0x0                | auto_idle_cru<br>If enable, BIU_CRU corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable           |
| 6          | RW          | 0x0                | auto_idle_peri<br>If enable, BIU_PERI corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable         |
| 5          | RW          | 0x0                | auto_idle_vo<br>If enable, BIU_VO corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable             |
| 4          | RW          | 0x0                | auto_idle_vi<br>If enable, BIU_VI corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable             |
| 3          | RW          | 0x0                | auto_idle_npu_aclk<br>If enable, BIU_NPU_ACLK corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x0                | auto_idle_npu<br>If enable, BIU_NPU corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable           |
| 1          | RW          | 0x0                | auto_idle_ddr<br>If enable, BIU_DDR corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | auto_idle_msch<br>If enable, BIU_MSCH corresponding clock can be opened or gated automatically when idle operation.<br>1'b0: Disable<br>1'b1: Enable |

**PMU DDR PWR CON**

Address: Operational Base + offset (0x00F0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                            |
| 15:8       | RO          | 0x00               | reserved                                                                                                                                                      |
| 7          | RW          | 0x0                | ddrctl_a_auto_gating_ena<br>Enable DDRCTL's AXI-clock auto clock gating. AXI-clock can be gated when in self-refresh mode.<br>1'b0: Disable<br>1'b1: Enable   |
| 6          | RW          | 0x0                | ddr_sref_a_ena<br>Enable DDR self-refresh mode for AXI-clock domain by hardware.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 5          | RW          | 0x0                | msch_auto_gating_ena<br>Enable MSCH auto clock gating function performed by PMU, when DDR enter self-refresh state.<br>1'b0: Disable<br>1'b1: Enable          |
| 4          | RO          | 0x0                | reserved                                                                                                                                                      |
| 3          | RW          | 0x0                | ddrctl_c_auto_gating_ena<br>Enable DDRCTL's core-clock auto clock gating. Core-clock can be gated when in self-refresh mode.<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x0                | ddrio_ret_exit_ena<br>Enable DDR IO retention de-asserted performed by hardware.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 1          | RW          | 0x0                | ddrio_ret_ena<br>Enable DDR IO retention function performed by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                     |
| 0          | RW          | 0x0                | ddr_sref_c_ena<br>Enable DDR self-refresh mode for core-clock domain by hardware.<br>1'b0: Disable<br>1'b1: Enable                                            |

**PMU DDR PWR SFTCON**

Address: Operational Base + offset (0x00F4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 15:5       | RO          | 0x000              | reserved                                                                                                              |
| 4          | RW          | 0x0                | sw_ddr_sref_a_req<br>Enable DDR self-refresh mode for AXI-clock domain by software.<br>1'b0: Disable<br>1'b1: Enable  |
| 3          | RW          | 0x0                | ddrctl_active_wait<br>DDR controller waits for c_active high after c_sysack high.<br>1'b0: Disable<br>1'b1: Enable    |
| 2          | RW          | 0x0                | sw_ddrio_ret_exit<br>DDR IO retention exit request by software.<br>1'b0: Disable<br>1'b1: Enable                      |
| 1          | RW          | 0x0                | sw_ddrio_ret_req<br>DDR IO retention enter request by software.<br>1'b0: Disable<br>1'b1: Enable                      |
| 0          | RW          | 0x0                | sw_ddr_sref_c_req<br>Enable DDR self-refresh mode for core-clock domain by software.<br>1'b0: Disable<br>1'b1: Enable |

**PMU DDR POWER STS**

Address: Operational Base + offset (0x00F8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                        |
| 2:0        | RO          | 0x0                | ddr_power_state<br>DDR power state.<br>4'h0: Normal state<br>4'h1: Enter self-refresh mode for AXI-clock state<br>4'h2: Enter self-refresh mode core-clock state<br>4'h3: Enter retention mode state<br>4'h4: Sleep state<br>4'h5: Exit retention mode<br>4'h6: Exit self-refresh mode for core-clock state<br>4'h7: Exit self-refresh mode for AXI-clock state |

**PMU DDR STS**

Address: Operational Base + offset (0x00FC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                 |
| 4          | RO          | 0x0                | ddrctl_a_active<br>DDRCCTL AXI clock active.<br>1'b0: Inactive<br>1'b1: Active                           |
| 3          | RO          | 0x0                | ddrctl_a_sysack<br>DDRCCTL AXI hardware low-power request acknowledge.<br>1'b0: Inactive<br>1'b1: Active |
| 2          | RO          | 0x0                | ddrio_ret<br>DDR IO retention state.<br>1'b0: Inactive<br>1'b1: Active                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | ddrctl_c_active<br>DDRCTL hardware low-power clock active.<br>1'b0: Inactive<br>1'b1: Active        |
| 0          | RO          | 0x0                | ddrctl_c_sysack<br>DDRCTL hardware low-power request acknowledge.<br>1'b0: Inactive<br>1'b1: Active |

**PMU CRU PWR CON0**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                           |
| 15:9       | RO          | 0x00               | reserved                                                                                                                                                     |
| 8          | RW          | 0x0                | pwm_switch_iout<br>PWM output.<br>1'b0: Disable<br>1'b1: Enable                                                                                              |
| 7          | RW          | 0x0                | pwm_gpio_ioe_ena<br>PWM output enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                      |
| 6          | RW          | 0x0                | pwm_switch_ena<br>PWM switch.<br>1'b0: Disable<br>1'b1: Enable                                                                                               |
| 5          | RW          | 0x0                | power_off_ena<br>Chip power off enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                                         |
| 4          | RW          | 0x0                | alive_osc_ena<br>pclk_pmu switch oscillator enable. When alive_32k_ena is asserted, this bit is ignored.<br>1'b0: Disable<br>1'b1: Enable                    |
| 3          | RW          | 0x0                | input_clamp_ena<br>VD_PMU input clamp enable by hardware.<br>1'b0: Disable<br>1'b1: Enable                                                                   |
| 2          | RW          | 0x0                | wakeup_RST_ena<br>Wakeup reset enable. If asserted, the whole chip except IPs supporting reset hold function will be reset.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | osc_dis_ena<br>Disable oscillator by hardware.<br>1'b0: Enable<br>1'b1: Disable                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | alive_32k_ena<br>Enable pclk_pmu and clk_pmu switch to 32KHz clock by hardware.<br>1'b0: Disable<br>1'b1: Enable |

**PMU CRU PWR CON1**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7          | RW          | 0x0                | cru_clk_src_gate_ena<br>Auto gating CRU_WRAPPER clock when CRU_POWER_STS is in sleep state.<br>1'b0: Disable<br>1'b1: Enable       |
| 6          | RW          | 0x0                | core_clk_src_gate_ena<br>Auto gating CORE_WRAPPER clock when CRU_POWER_STS is in sleep state.<br>1'b0: Disable<br>1'b1: Enable     |
| 5          | RW          | 0x0                | peri_clk_src_gate_ena<br>Auto gating PERI_WRAPPER clock when CRU_POWER_STS is in sleep state.<br>1'b0: Disable<br>1'b1: Enable     |
| 4          | RW          | 0x0                | ddr_clk_src_gate_ena<br>Auto gating DDR_WRAPPER clock when CRU_POWER_STS is in sleep state.<br>1'b0: Disable<br>1'b1: Enable       |
| 3          | RW          | 0x0                | npu_clk_src_gate_ena<br>Auto gating NPU_WRAPPER clock when CRU_POWER_STS is in sleep state.<br>1'b0: Disable<br>1'b1: Enable       |
| 2          | RW          | 0x0                | venc_clk_src_gate_ena<br>Auto gating VENC_WRAPPER clock when CRU_POWER_STS is in sleep state.<br>1'b0: Disable<br>1'b1: Enable     |
| 1          | RW          | 0x0                | vo_clk_src_gate_ena<br>Auto gating VO_WRAPPER clock when CRU_POWER_STS is in sleep state.<br>1'b0: Disable<br>1'b1: Enable         |
| 0          | RW          | 0x0                | vi_clk_src_gate_ena<br>Auto gating VI_WRAPPER clock when CRU_POWER_STS is in sleep state.<br>1'b0: Disable<br>1'b1: Enable         |

**PMU CRU PWR SFTCON**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                    |
| 15:6       | RO          | 0x000              | reserved                                                                                                                                              |
| 5          | RW          | 0x0                | power_off_ena<br>Power off chip by software.<br>1'b0: Disable<br>1'b1: Enable                                                                         |
| 4          | RW          | 0x0                | alive_osc_ena<br>pclk_pmu switch oscillator enable by software. When alive_32k_ena is asserted, this bit is ignored.<br>1'b0: Disable<br>1'b1: Enable |
| 3          | RW          | 0x0                | input_clamp_ena<br>VD_PMU input clamp enable by software.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 2          | RW          | 0x0                | wakeup_RST_ena<br>Wakeup reset enable by software. Reset the whole chip, except IPs supporting reset hold function.<br>1'b0: Disable<br>1'b1: Enable  |
| 1          | RW          | 0x0                | osc_dis_ena<br>Disable oscillator by software.<br>1'b0: Enable<br>1'b1: Disable                                                                       |
| 0          | RW          | 0x0                | alive_32k_ena<br>Enable pclk_pmu and clk_pmu switch to 32KHz clock by software.<br>1'b0: Disable<br>1'b1: Enable                                      |

**PMU CRU POWER STS**

Address: Operational Base + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3:0        | RO          | 0x0                | cru_power_state<br>Clock and reset power state.<br>4'h0: Normal state<br>4'h1: Clock low frequency state<br>4'h2: PLL power down state<br>4'h3: Input clamp state<br>4'h4: Oscillator disable state<br>4'h5: Sleep state<br>4'h6: Wakeup state<br>4'h7: Oscillator enable state<br>4'h8: Input clamp release state<br>4'h9: Clock high frequency state<br>4'ha: Wakeup reset clear state<br>4'hb: GPIO switch state<br>4'hc: PLL power up state<br>4'hd: PWM switch state<br>Others: Reserved |

**PMU PLLPD CON**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                           |
| 3          | RW          | 0x0                | gpll_pd_ena<br>GPLL power down by PMU.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 2          | RW          | 0x0                | cpll_pd_ena<br>CPLL power down by PMU.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 1          | RW          | 0x0                | dpll_pd_ena<br>DPLL power down by PMU.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 0          | RW          | 0x0                | apll_pd_ena<br>APLL power down by PMU.<br>1'b0: Disable<br>1'b1: Enable                                                            |

**PMU PLLPD\_SFTCON**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:4       | RO          | 0x000              | reserved                                                                                                                           |
| 3          | RW          | 0x0                | gpll_pd_ena<br>GPLL power down by software.<br>1'b0: Disable<br>1'b1: Enable                                                       |
| 2          | RW          | 0x0                | cpll_pd_ena<br>CPLL power down by software.<br>1'b0: Disable<br>1'b1: Enable                                                       |
| 1          | RW          | 0x0                | dpll_pd_ena<br>DPLL power down by software.<br>1'b0: Disable<br>1'b1: Enable                                                       |
| 0          | RW          | 0x0                | apll_pd_ena<br>APLL power down by software.<br>1'b0: Disable<br>1'b1: Enable                                                       |

**PMU INFO TX CON**

Address: Operational Base + offset (0x0150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8       | RW          | 0x00               | info_tx_intv_time<br>The interval time from 1 byte sends over to a new byte sends start. The value is the cycle number counted in clk_pmu. |
| 7:1        | RO          | 0x00               | reserved                                                                                                                                   |
| 0          | RW          | 0x0                | info_tx_en<br>PMU debug information transmit enable.<br>1'b0: Disable<br>1'b1: Enable                                                      |

**PMU SYS REG0**

Address: Operational Base + offset (0x01C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RW          | 0x00000000         | pmu_sys_reg<br>PMU system register |

**PMU SYS REG1**

Address: Operational Base + offset (0x01C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RW          | 0x00000000         | pmu_sys_reg<br>PMU system register |

**PMU SYS REG2**

Address: Operational Base + offset (0x01C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RW          | 0x00000000         | pmu_sys_reg<br>PMU system register |

**PMU SYS REG3**

Address: Operational Base + offset (0x01CC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RW          | 0x00000000         | pmu_sys_reg<br>PMU system register |

**PMU SYS REG4**

Address: Operational Base + offset (0x01D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RW          | 0x00000000         | pmu_sys_reg<br>PMU system register |

**PMU SYS REG5**

Address: Operational Base + offset (0x01D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RW          | 0x00000000         | pmu_sys_reg<br>PMU system register |

**PMU SYS REG6**

Address: Operational Base + offset (0x01D8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RW          | 0x00000000         | pmu_sys_reg<br>PMU system register |

**PMU SYS REG7**

Address: Operational Base + offset (0x01DC)

| Bit  | Attr | Reset Value | Description                        |
|------|------|-------------|------------------------------------|
| 31:0 | RW   | 0x00000000  | pmu_sys_reg<br>PMU system register |

## 7.5 Interface Description

Table 7-2 Interface Description

| Module Pin    | Direction | Pad Name                                             | IOMUX Setting                     |
|---------------|-----------|------------------------------------------------------|-----------------------------------|
| pmu_debug     | O         | PWM4_M0/PMU_DEBUG/I2C2_SDA_M0/UART3_RX_M0/GPIO1_A1_d | VENCIOC_GPIO1A_IOMUX_SEL_L[7:4]=3 |
| pmic_sleep_m0 | O         | PWM1_M0/PMIC_SLEEP_M0/GPIO0_A4_d                     | PMUIOC_GPIO0A_IOMUX_SEL_H[3:0]=1  |
| pmic_sleep_m1 | O         | PMIC_SLEEP_M1/GPIO0_A3_u                             | PMUIOC_GPIO0A_IOMUX_SEL_L15:12]=1 |

Notes: I=input, O=output, I/O=input/output, bidirectional

## 7.6 Application Notes

### 7.6.1 Hardware Low Power Mode

PMU can work in low power mode by hardware. After setting bit[0] of PMU\_PWR\_CON and CPU enter standbywf state, PMU low power FSM will start to run. In the low power mode, PMU will manage power resources by hardware or software, such as send idle request to specified power domain, auto clock switch and clock gating, shut down PLLs, and so on. All of above are configurable by setting corresponding registers.

Also, the standbywf state can be bypass if PMU\_SCU\_PWR\_CON[2] is set to 1.

### 7.6.2 Software Low Power Mode

PMU can work in the low power mode by software. In this application, you can use LPMCU to set PMU software power control registers to execute low power procedure.

### 7.6.3 PMU Debug Information

The PMU internal states could be monitored through pmu\_debug IO in 8-bit UART interface mode. The transmission can be enabled by setting PMU\_INFO\_TX\_CON[0], and the transmission interval time can be set in PMU\_INFO\_TX\_CON[15:8].

Table 7-3 PMU Debug Information Decode

| Decode Value | PMU State                                         | Description            |
|--------------|---------------------------------------------------|------------------------|
| 1            | Not care                                          | -                      |
| 2            | Not care                                          | -                      |
| 3            | Bus low power state                               | PMU_GLB_POWER_STS=4'h3 |
| 4            | DDR enters self-refresh mode for AXI-clock state  | PMU_DDR_POWER_STS=4'h1 |
| 5            | DDR enters self-refresh mode for core-clock state | PMU_DDR_POWER_STS=4'h2 |
| 6            | DDR enters retention mode state                   | PMU_DDR_POWER_STS=4'h3 |
| 7            | Not care                                          | -                      |
| 8            | Clock low frequency state                         | PMU_CRU_POWER_STS=4'h1 |
| 9            | PLL power down state                              | PMU_CRU_POWER_STS=4'h2 |
| 10           | Input clamp state                                 | PMU_CRU_POWER_STS=4'h3 |
| 11           | Oscillator disable state                          | PMU_CRU_POWER_STS=4'h4 |
| 12           | Sleep state                                       | PMU_GLB_POWER_STS=4'h7 |
| 13           | Wake up state                                     | PMU_CRU_POWER_STS=4'h6 |
| 14           | Oscillator enable state                           | PMU_CRU_POWER_STS=4'h7 |
| 15           | Input clamp release state                         | PMU_CRU_POWER_STS=4'h8 |
| 16           | Clock high frequency state                        | PMU_CRU_POWER_STS=4'h9 |
| 17           | Wake up reset clear state                         | PMU_CRU_POWER_STS=4'ha |

| Decode Value | PMU State                                           | Description            |
|--------------|-----------------------------------------------------|------------------------|
| 18           | GPIO switch state                                   | PMU_CRU_POWER_STS=4'hb |
| 19           | PLL power up state                                  | PMU_CRU_POWER_STS=4'hc |
| 20           | PWM switch state                                    | PMU_CRU_POWER_STS=4'hd |
| 21           | Not care                                            | -                      |
| 22           | DDR exits retention mode through RETON/RETOFF state | PMU_DDR_POWER_STS=4'h5 |
| 23           | DDR exits self-refresh mode for core-clock state    | PMU_DDR_POWER_STS=4'h6 |
| 24           | DDR exits self-refresh mode for AXI-clock state     | PMU_DDR_POWER_STS=4'h7 |
| 25           | Bus active state                                    | PMU_GLB_POWER_STS=4'hb |
| 26           | Not care                                            | -                      |
| 27           | Not care                                            | -                      |

#### 7.6.4 System Register

PMU support 8 system registers: PMU\_SYS\_REG0~ PMU\_SYS\_REG7. These registers are always on no matter what low power mode. Therefore, software can use these registers to retain some information which is useful after wakeup from any mode.

## Chapter 8 MCU Subsystem

### 8.1 Overview

The MCU Subsystem embedded one MCU processor(RISCV Architecture), a 16KB unified I/D cache and interrupt multiplexer(INTMUX). It allowed fast & efficient data exchange. And the Level 1 Instruction/Data Cache designed for MCU can improve the memory access performance significantly.

The following features may or may not be present in the actual product. Please contact Rockchip for the actual feature configurations and the third-party licensing requirements.

The MCU features and benefits are:

- One MCU processor
- Machine privilege level
- 32 32-bit general purpose integer registers
- Instruction set is RV32I with M and C extensions
- 3 stage pipeline implementation
- 3 embedded 64bit performance counters
- Real time clock
- Cycle counter
- Instructions-retired counter
- Optional debug support
- Two hardware breakpoints
- Support Serial Wire debug connection
- Interrupt multiplexer(INTMUX)
  - Multiplexer 16 interrupts from 128 interrupt sources using round-robin algorithm
  - Each 32 adjacent interrupts are seen as a group which share same INTMUX\_INT\_ENABLE\_GROUPx and INTMUX\_INT\_FLAG\_GROUPx register
- 16KB unified I/D Cache
  - Support 2-way set-associative with 32Byte cache line size
  - Support one 128bit AHB-Lite bus master interface to SoC interconnect
  - Support memory cacheable access and peripheral bypass access
  - Support Write-Through with No-Write-Allocate and Read-Allocate
  - Support Write-Back with Write-Allocate and Read-Allocate
  - Support cache maintenance operations (clean/invalidate/clean & invalidate) by address
  - Support cache invalidate/clean & invalidate operations for all cache lines
  - Support cache initialization by software configuration
  - Support RAM debug mode for tag RAM and data RAM
  - Support one interrupt source

There is a MCU subsystems in RV1106, High performance(HP) subsystems. Its main configurations are as shown below.

Table 8-1 MCU Subsystem Configurations

|         | HP_MCU |
|---------|--------|
| CACHE   | 16KB   |
| IRQ_NUM | 16     |
| INTMUX  | YES    |

### 8.2 Block Diagram

The Int\_in[127:0] will connect with all interrupt source of RV1106, and please refer to "Chapter System Overview" for the detail interrupt number. The Int\_in[15:0] will be specified in section 1.5.2. MCU Subsystem are shown below.



Fig. 8-1 Block Diagram of HP MCU Subsystem

## 8.3 Register Description

Software should read and write these registers using 32-bits accesses.

### 8.3.1 Registers Summary(MCU)

The first six registers are timer related which are outside of MCU core, the base address is 0xFF1E0000, they should be accessed by load/store instructions. The rest registers are control status registers(CSR) which are in MCU core, they should be accessed by system instructions.

| Name              | Offset | Size | Reset Value | Description                               |
|-------------------|--------|------|-------------|-------------------------------------------|
| MCU_TIMER_CTRL    | 0x0000 | W    | 0x00000001  | Timer Control Register                    |
| MCU_TIMER_DIV     | 0x0004 | W    | 0x00000000  | Timer Divider Register                    |
| MCU_MTIME         | 0x0008 | W    | 0x00000000  | Machine Timer Register Low 32bit          |
| MCU_MTIMEH        | 0x000C | W    | 0x00000000  | Machine Timer Register High 32bit         |
| MCU_MTIMECMP      | 0x0010 | W    | 0x00000000  | Machine Timer Compare Register Low 32bit  |
| MCU_MTIMECMRH     | 0x0014 | W    | 0x00000000  | Machine Timer Compare Register High 32bit |
| MCU_CSR_MVENDORID | 0x0F11 | W    | 0x00000000  | Machine Vendor ID Register                |
| MCU_CSR_MARCHID   | 0x0F12 | W    | 0x00000008  | Machine Architecture ID Register          |
| MCU_CSR_MIMPID    | 0x0F13 | W    | 0x19083000  | Machine Implementation ID Register        |
| MCU_CSR_MHARTID   | 0x0F14 | W    | 0x00000000  | Machine Hart ID Register                  |
| MCU_CSR_MSTATUS   | 0x0300 | W    | 0x00001880  | Machine Status Register                   |
| MCU_CSR_MISA      | 0x0301 | W    | 0x40001104  | Machine Base ISA Control Register         |

| Name                | Offset | Size | Reset Value | Description                                |
|---------------------|--------|------|-------------|--------------------------------------------|
| MCU_CSR_MIE         | 0x0304 | W    | 0x00000000  | Machine Interrupt Enable Register          |
| MCU_CSR_MTVEC       | 0x0305 | W    | 0x002001C0  | Machine Trap-Vector Base-Address Register  |
| MCU_CSR_MSCRATCH    | 0x0340 | W    | 0x00000000  | Machine Scratch Register                   |
| MCU_CSR_MEPC        | 0x0341 | W    | 0x00000000  | Machine Exception Program Counter Register |
| MCU_CSR_MCAUSE      | 0x0342 | W    | 0x00000000  | Machine Cause Register                     |
| MCU_CSR_MTVAL       | 0x0343 | W    | 0x00000000  | Machine Trap Value Register                |
| MCU_CSR_MIP         | 0x0344 | W    | 0x00000000  | Machine Interrupt Pending Register         |
| MCU_CSR_MCYCLEL     | 0x0B00 | W    | 0x00000000  | Machine Cycle Counter Low Register         |
| MCU_CSR_MCYCLEH     | 0x0B80 | W    | 0x00000000  | Machine Cycle Counter High Register        |
| MCU_CSR_MINSTRETL   | 0x0B02 | W    | 0x00000000  | Machine Instructions Retired Low Register  |
| MCU_CSR_MINSTRETH   | 0x0B82 | W    | 0x00000000  | Machine Instructions Retired High Register |
| MCU_CSR_MCOUNTEN    | 0x07E0 | W    | 0x00000005  | Machine Counter Enable Register            |
| MCU_CSR_DBG_SCRATCH | 0x07C8 | W    | 0x00000000  | Debug Scratch Register                     |
| MCU_CSR_IPIC_CISV   | 0x0BF0 | W    | 0x00000000  | Current Interrupt Vector in Service        |
| MCU_CSR_IPIC_CCSR   | 0x0BF1 | W    | 0x00000000  | Current Interrupt Control Status Register  |
| MCU_CSR_IPIC_IPR    | 0x0BF2 | W    | 0x00000000  | Interrupt Pending Register                 |
| MCU_CSR_IPIC_ISVR   | 0x0BF3 | W    | 0x00000000  | Interrupt Serviced Register                |
| MCU_CSR_IPIC_EOI    | 0x0BF4 | W    | 0x00000000  | End Of Interrupt                           |
| MCU_CSR_IPIC_SOI    | 0x0BF5 | W    | 0x00000000  | Start Of Interrupt                         |
| MCU_CSR_IPIC_IDX    | 0x0BF6 | W    | 0x00000000  | Index Register                             |
| MCU_CSR_IPIC_ICSR   | 0x0BF7 | W    | 0x00000000  | Interrupt Control Status register          |

Notes: **S**-ize: **B**- Byte (8 bits) access, **H****W**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **D****W**-Double WORD (64 bits) access

### 8.3.2 Detail Registers Description

#### MCU\_TIMER\_CTRL

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                          |
|------|------|-------------|------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                                             |
| 1    | RW   | 0x0         | CLKSRC<br>timer clock source<br>1'b0: internal core clock(default)<br>1'b1: external real-time clock |
| 0    | RW   | 0x1         | ENABLE<br>timer enable bit<br>1'b0: timer disable<br>1'b1: timer enable                              |

#### MCU\_TIMER\_DIV

Address: Operational Base + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                       |
|-------|------|-------------|-------------------------------------------------------------------|
| 31:10 | RO   | 0x000000    | reserved                                                          |
| 9:0   | RW   | 0x000       | DIV<br>Timer divider<br>Timer tick occurs every DIV+1 clock ticks |

**MCU\_MTIME**

Address: Operational Base + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                        |
|------|------|-------------|--------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | MTIMEL<br>Low 32bit of wall-clock real time(number of timer ticks) |

**MCU\_MTIMEH**

Address: Operational Base + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                                         |
|------|------|-------------|---------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | MTIMEH<br>High 32bit of wall-clock real time(number of timer ticks) |

**MCU\_MTIMECMP**

Address: Operational Base + offset (0x0010)

| Bit  | Attr | Reset Value | Description                                                |
|------|------|-------------|------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | MTIMECMPL<br>Machine-mode timer compare register low 32bit |

**MCU\_MTIMECMPH**

Address: Operational Base + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                                 |
|------|------|-------------|-------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | MTIMECMPH<br>Machine-mode timer compare register high 32bit |

**MCU\_CSR\_MVENDORID**

Address: Operational Base + offset (0x0F11)

| Bit  | Attr | Reset Value | Description                                                        |
|------|------|-------------|--------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | VENDOR ID<br>The JEDEC manufacturer ID of the provider of the core |

**MCU\_CSR\_MARCHID**

Address: Operational Base + offset (0x0F12)

| Bit  | Attr | Reset Value | Description                                                 |
|------|------|-------------|-------------------------------------------------------------|
| 31:0 | RO   | 0x00000008  | ARCH ID<br>Encoding the base micro-architecture of the hart |

**MCU\_CSR\_MIMPID**

Address: Operational Base + offset (0x0F13)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x19083000  | YEAR-MONTH-DAY-RELEASE<br>Bit[31]-bit[24]: BCD-coded value of the year<br>Bit[23]-bit[16]: BCD-coded value of the month<br>Bit[16]-bit[8]: BCD-coded value of the day<br>Bit[7]-bit[0]: 8-bit value of intraday release number |

**MCU\_CSR\_MHARTID**

Address: Operational Base + offset (0x0F14)

| Bit  | Attr | Reset Value | Description                                                                   |
|------|------|-------------|-------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | HART ID<br>Containing the integer ID of the hardware thread running the code. |

**MCU\_CSR\_MSTATUS**

Address: Operational Base + offset (0x0300)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:13 | RO   | 0x00000     | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 12:11      | RO          | 0x3                | MPP<br>Previous privilege mode (hardwired to 11) |
| 10:8       | RO          | 0x0                | reserved                                         |
| 7          | RW          | 0x1                | MPIE<br>Previous global interrupt enable         |
| 6:4        | RO          | 0x0                | reserved                                         |
| 3          | RW          | 0x0                | MIE<br>Global interrupt enable                   |
| 2:0        | RO          | 0x0                | reserved                                         |

**MCU CSR MISA**

Address: Operational Base + offset (0x0301)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x1                | MXL<br>Machine XLEN (hardwired to 01)                |
| 29:24      | RO          | 0x00               | reserved                                             |
| 23         | RO          | 0x0                | RVX<br>Non-standard extensions                       |
| 22:13      | RO          | 0x000              | reserved                                             |
| 12         | RO          | 0x1                | RVM<br>Integer Multiply/Divide extension implemented |
| 11:9       | RO          | 0x0                | reserved                                             |
| 8          | RO          | 0x1                | RVI<br>RV32I base integer instruction set            |
| 7:5        | RO          | 0x0                | reserved                                             |
| 4          | RO          | 0x0                | RVE<br>RV32E base integer instruction set            |
| 3          | RO          | 0x0                | reserved                                             |
| 2          | RO          | 0x1                | RVC<br>Compressed instruction extension implemented  |
| 1:0        | RO          | 0x0                | reserved                                             |

**MCU CSR MIE**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                  |
| 11         | RW          | 0x0                | MEIE<br>Machine External Interrupt Enable |
| 10:8       | RO          | 0x0                | reserved                                  |
| 7          | RW          | 0x0                | MTIE<br>Machine Timer Interrupt Enable    |
| 6:4        | RO          | 0x0                | reserved                                  |
| 3          | RW          | 0x0                | MSIE<br>Machine Software Interrupt Enable |
| 2:0        | RO          | 0x0                | reserved                                  |

**MCU CSR MTVEC**

Address: Operational Base + offset (0x0305)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:6       | RW          | 0x0008007          | BASE<br>Vector base address (upper 26 bits)          |
| 5:2        | RO          | 0x0                | reserved                                             |
| 1:0        | RW          | 0x0                | MODE<br>Vector mode (0-direct mode, 1-vectored mode) |

**MCU CSR MSCRATCH**

Address: Operational Base + offset (0x0340)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | MSCRATCH<br>Hold a pointer to a machine-mode hart-local context space and swapped with a user register upon entry to an M-mode trap handler. |

**MCU CSR MEPC**

Address: Operational Base + offset (0x0341)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:1       | RW          | 0x00000000         | MEPC<br>Hold the virtual address of the instruction that encountered the exception. |
| 0          | RO          | 0x0                | reserved                                                                            |

**MCU CSR MCAUSE**

Address: Operational Base + offset (0x0342)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31         | RW          | 0x0                | INT<br>Interrupt     |
| 30:4       | RO          | 0x00000000         | reserved             |
| 3:0        | RW          | 0x0                | EC<br>Exception Code |

**MCU CSR MTVAL**

Address: Operational Base + offset (0x0343)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                 |
| 30:0       | RW          | 0x00000000         | MTVAL<br>When a trap is taken into M-mode, mtval is written with exception-specific information to assist software in handling the trap. |

**MCU CSR MIP**

Address: Operational Base + offset (0x0344)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                   |
| 11         | RO          | 0x0                | MEIP<br>Machine External Interrupt Pending |
| 10:8       | RO          | 0x0                | reserved                                   |
| 7          | RO          | 0x0                | MTIP<br>Machine Timer Interrupt Pending    |
| 6:4        | RO          | 0x0                | reserved                                   |
| 3          | RO          | 0x0                | MSIP<br>Machine Software Interrupt Pending |
| 2:0        | RO          | 0x0                | reserved                                   |

**MCU CSR MCYCLEL**

Address: Operational Base + offset (0x0B00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | MCYCLEL<br>Represent the number of clock cycles(low 32bit) since some arbitrary point of time in the past. |

**MCU CSR MCYCLEH**

Address: Operational Base + offset (0x0B80)

| Bit  | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | MCYCLEH<br>Represent the number of clock cycles(high 32bit) since some arbitrary point of time in the past. |

**MCU CSR MINSTRETL**

Address: Operational Base + offset (0x0B02)

| Bit  | Attr | Reset Value | Description                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | MINSTRETL<br>Represent the number of instructions(low 32bit) retired by the core from some arbitrary time in the past. |

**MCU CSR MINSTRETH**

Address: Operational Base + offset (0x0B82)

| Bit  | Attr | Reset Value | Description                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | MINSTRETH<br>Represent the number of instructions(low 32bit) retired by the core from some arbitrary time in the past. |

**MCU CSR MCOUNTEN**

Address: Operational Base + offset (0x07E0)

| Bit  | Attr | Reset Value | Description                               |
|------|------|-------------|-------------------------------------------|
| 31:3 | RO   | 0x00000000  | reserved                                  |
| 2    | RW   | 0x1         | IR<br>Enable retired instructions counter |
| 1    | RO   | 0x0         | reserved                                  |
| 0    | RW   | 0x1         | CY<br>Enable cycle counter                |

**MCU CSR DBG SCRATCH**

Address: Operational Base + offset (0x07C8)

| Bit  | Attr | Reset Value | Description                                                                  |
|------|------|-------------|------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | DSCRATCH<br>Used to exchange data between the core and the debug controller. |

**MCU CSR IPIC CISV**

Address: Operational Base + offset (0x0BF0)

| Bit  | Attr | Reset Value | Description                                                 |
|------|------|-------------|-------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                    |
| 4:0  | RO   | 0x00        | CISV<br>Number of the interrupt vector currently in service |

**MCU CSR IPIC CICSR**

Address: Operational Base + offset (0x0BF1)

| Bit  | Attr | Reset Value | Description                                                                       |
|------|------|-------------|-----------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                          |
| 1    | RW   | 0x0         | IE<br>Interrupt Enable Bit<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 0          | W1<br>C     | 0x0                | IP<br>Interrupt pending<br>1'b0: no interrupt<br>1'b1: Interrupt pending |

**MCU CSR IPIC IPR**

Address: Operational Base + offset (0x0BF2)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                |
| 15:0       | W1<br>C     | 0x0000             | PENDING<br>Interrupt vector0 ~ vector15 pending status, each bit represents one vector. |

**MCU CSR IPIC ISVR**

Address: Operational Base + offset (0x0BF3)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                            |
| 15:0       | RO          | 0x0000             | SERVICE<br>When corresponding bit is set (1) - this interrupt vector is in service. |

**MCU CSR IPIC EOI**

Address: Operational Base + offset (0x0BF4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | WS          | 0x00000000         | END OF INTERRUPT<br>Writing any value to EOI register ends the interrupt which is currently in service, read will return zero. |

**MCU CSR IPIC SOI**

Address: Operational Base + offset (0x0BF5)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | WS          | 0x00000000         | START OF INTERRUPT<br>Writing any value to SOI activates start of interrupt if one of the following conditions is true:<br>1. There is at least one pending interrupt with IE and ISR is zero (no interrupts in service)<br>2. There is at least one pending interrupt with IE and this interrupt has higher priority than the interrupts currently in service. |

**MCU CSR IPIC IDX**

Address: Operational Base + offset (0x0BF6)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                    |
| 3:0        | RW          | 0x0                | INDEX<br>Interrupt vector index to access through IPIC_ICSR |

**MCU CSR IPIC ICSR**

Address: Operational Base + offset (0x0BF7)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x000000           | reserved                                                                                                                                                |
| 12         | RO          | 0x0                | LN<br>External IRQ Line Number assigned to this interrupt vector. This value is always equal to IPIC_IDX, because of the static line to vector mapping. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 11:9       | RO          | 0x0                | reserved                                                                          |
| 8          | RO          | 0x0                | PRV<br>Privilege mode: hardwired to 11 (machine mode)                             |
| 7:5        | RO          | 0x0                | reserved                                                                          |
| 4          | RW          | 0x0                | IS<br>In Service                                                                  |
| 3          | RW          | 0x0                | INV<br>Line Inversion<br>1'b0: no inversion<br>1'b1: line inversion               |
| 2          | RW          | 0x0                | IM<br>Interrupt Mode<br>1'b0: Level interrupt<br>1'b1: Edge interrupt             |
| 1          | RW          | 0x0                | IE<br>Interrupt Enable Bit<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |
| 0          | W1<br>C     | 0x0                | IP<br>Interrupt pending<br>1'b0: no interrupt<br>1'b1: Interrupt pending          |

### 8.3.3 Registers Summary (CACHE)

| Name                          | Offset | Size | Reset Value | Description                              |
|-------------------------------|--------|------|-------------|------------------------------------------|
| CACHE_CTRL                    | 0x0000 | W    | 0x0000006cc | Cache Control Register                   |
| CACHE_MAINTAIN0               | 0x0004 | W    | 0x000000000 | Cache Maintain 0 Register                |
| CACHE_MAINTAIN1               | 0x0008 | W    | 0x000000000 | Cache Maintain 1 Register                |
| CACHE_STB_TIMEOUT_CTRL        | 0x000c | W    | 0x4000000c  | Store Buffer Timeout Control Register    |
| CACHE_RAM_DEBUG               | 0x0010 | W    | 0x000000000 | Cache RAM Debug Register                 |
| CACHE_INT_EN                  | 0x0020 | W    | 0x000000000 | Cache Interrupt Enable Register          |
| CACHE_INT_ST                  | 0x0024 | W    | 0x000000000 | Cache Interrupt Status Register          |
| CACHE_ERR_HADDR               | 0x0028 | W    | 0x000000000 | Cache Error Address Register             |
| CACHE_STATUS                  | 0x0030 | W    | 0x000000000 | Cache Status Register                    |
| CACHE_PMU_RD_NUM_CNT          | 0x0040 | W    | 0x000000000 | PMU Read Number Count Register           |
| CACHE_PMU_WR_NUM_CNT          | 0x0044 | W    | 0x000000000 | PMU Write Number Count Register          |
| CACHE_PMU_RAM_RD_HIT_CNT      | 0x0048 | W    | 0x000000000 | PMU RAM Read Hit Count Register          |
| CACHE_PMU_HB_RD_HIT_CNT       | 0x004c | W    | 0x000000000 | PMU Hot Buffer Read Hit Count Register   |
| CACHE_PMU_STB_RD_HIT_CNT      | 0x0050 | W    | 0x000000000 | PMU Store Buffer Read Hit Count Register |
| CACHE_PMU_RD_HIT_CNT          | 0x0054 | W    | 0x000000000 | PMU Read Hit Count Register              |
| CACHE_PMU_WR_HIT_CNT          | 0x0058 | W    | 0x000000000 | PMU Write Hit Count Register             |
| CACHE_PMU_RD_MISS_PENALTY_CNT | 0x005c | W    | 0x000000000 | PMU Read Miss Penalty Count Register     |
| CACHE_PMU_WR_MISS_PENALTY_CNT | 0x0060 | W    | 0x000000000 | PMU Write Miss Penalty Count Register    |
| CACHE_PMU_RD_LAT_CNT          | 0x0064 | W    | 0x000000000 | PMU Read Latency Count Register          |
| CACHE_PMU_WR_LAT_CNT          | 0x0068 | W    | 0x000000000 | PMU Write Latency Count Register         |
| CACHE_REVISION                | 0x00f0 | W    | 0x00000100  | Cache Design Revision Register           |

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

### 8.3.4 Detail Registers Description

#### CACHE\_CTRL

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:14 | RO   | 0x00000     | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | cache_pf_en<br>Cache prefetch enable register.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                 |
| 12         | RW          | 0x0                | cache_mpu_mode<br>Cache MPU mode enable register. When this bit is set to 1, the cacheability policy is determined by MPU of Cortex-M4.<br>1'b0: Disable<br>1'b1: Enable                                                                        |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                                                        |
| 10:8       | RW          | 0x6                | stb_entry_thresh<br>Store buffer entry threshold control register. The depth of the store buffer entry is 8. When the number of the used data entries is greater than or equal to threshold value, the write data will be written to Cache RAM. |
| 7          | RW          | 0x1                | stb_timeout_en<br>Store buffer timeout enable register. When this bit is set to 1, the data in the store buffer must be flushed to Cache RAM if the counter value is equal to the timeout value.<br>1'b0: Disable<br>1'b1: Enable               |
| 6          | RW          | 0x1                | cache_bypass<br>Cache bypass mode enable register. When this bit is set to 1, data will bypass the Cache.<br>1'b0: Disable<br>1'b1: Enable                                                                                                      |
| 5          | RW          | 0x0                | cache_pmu_en<br>Cache Performance Monitor Unit enable register.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                |
| 4          | RW          | 0x0                | cache_flush<br>Cache flush enable register. When this bit is set to 1, the dirty data is flushed to external memory and the cache line are invalidated.<br>1'b0: Disable<br>1'b1: Enable                                                        |
| 3          | RW          | 0x1                | cache_stb_en<br>Cache store buffer enable register. This bit must be set to 0 when Write-Through mode is selected and must be set to 1 when Write-Back mode is selected.<br>1'b0: Disable<br>1'b1: Enable                                       |
| 2          | RW          | 0x1                | cache_hb_en<br>Cache hot buffer enable register.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                               |
| 1          | RW          | 0x0                | cache_wt_en<br>Cache mode control register.<br>1'b0: Write-Back<br>1'b1: Write-Through                                                                                                                                                          |
| 0          | RW          | 0x0                | cache_en<br>Cache initialization enable register.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                              |

**CACHE MAINTAINO**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RW          | 0x00000000         | cache_m_addr<br>Cache maintain start address. This address is 32Byte cache line aligned, that is, the bits[4:0] are always 0.                                                 |
| 4:3        | RO          | 0x0                | reserved                                                                                                                                                                      |
| 2:1        | RW          | 0x0                | cache_m_cmd<br>Cache maintain command register.<br>2'b00: Clean by address<br>2'b01: Invalidate by address<br>2'b10: Clean and Invalidate by address<br>2'b11: Invalidate all |
| 0          | WO          | 0x0                | cache_m_valid<br>Cache maintain valid register. The maintenance operation is valid only when this bit is set to 1.                                                            |

**CACHE MAINTAIN1**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 26:0       | RW          | 0x00000000         | cache_m_offset<br>Cache maintain offset. This bit field indicates the end offset of cache line, that is, the value plus 1 determines the number of cache line to be maintained. The bit field of cache_m_addr is treated as the start offset of cache line, so the maintain address range is from (cache_m_addr * 32) to (cache_m_addr * 32 + 31 + cache_m_offset * 32). |

**CACHE STB TIMEOUT CTRL**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RW          | 0x4000000c         | stb_timeout_value<br>Store buffer timeout value. |

**CACHE RAM DEBUG**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                               |
| 0          | RW          | 0x0                | ram_debug_en<br>Cache RAM debug mode enable register.<br>1'b0: Disable<br>1'b1: Enable |

**CACHE INT EN**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                              |
| 0          | RW          | 0x0                | err_record_en<br>AHB master bus error record enable.<br>1'b0: Disable<br>1'b1: Enable |

**CACHE INT ST**

Address: Operational Base + offset (0x0024)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | ahb_error_status<br>Error status bit for AHB master bus.<br>1'b0: Nothing<br>1'b1: Bus error |

**CACHE\_ERR\_HADDR**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                |
| 0          | RO          | 0x0                | status_haddr<br>Recent record of AHB bus error address. |

**CACHE\_STATUS**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                        |
| 2          | RO          | 0x0                | cache_flush_done<br>Cache flush done status register.<br>1'b0: Nothing<br>1'b1: Flush done                                      |
| 1          | RO          | 0x0                | cache_m_busy<br>Cache maintain busy status register.<br>1'b0: Idle<br>1'b1: Busy                                                |
| 0          | RO          | 0x0                | cache_init_finish<br>Cache initialization finish status register.<br>1'b0: Cache is uninitialized<br>1'b1: Cache is initialized |

**CACHE\_PMU\_RD\_NUM\_CNT**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_rd_num_cnt<br>Total count of read transfers. |

**CACHE\_PMU\_WR\_NUM\_CNT**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_wr_num_cnt<br>Total count of write transfers. |

**CACHE\_PMU\_RAM\_RD\_HIT\_CNT**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_ram_rd_hit_cnt<br>Count of read hits on Cache RAM. |

**CACHE\_PMU\_HB\_RD\_HIT\_CNT**

Address: Operational Base + offset (0x004c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_hb_rd_hit_cnt<br>Count of read hits on hot buffer. |

**CACHE\_PMU\_STB\_RD\_HIT\_CNT**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_stb_rd_hit_cnt<br>Count of read hits on store buffer. |

**CACHE PMU RD HIT CNT**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                          |
|------------|-------------|--------------------|---------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_rd_hit_cnt<br>Total count of read hits. |

**CACHE PMU WR HIT CNT**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_wr_hit_cnt<br>Total count of write hits. |

**CACHE PMU RD MISS PENALTY CNT**

Address: Operational Base + offset (0x005c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_rd_miss_penalty_cnt<br>Total count of read miss penalty (in clock cycles). |

**CACHE PMU WR MISS PENALTY CNT**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_wr_miss_penalty_cnt<br>Total count of write miss penalty (in clock cycles). |

**CACHE PMU RD LAT CNT**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_rd_lat_cnt<br>Total count of read latency (in clock cycles). |

**CACHE PMU WR LAT CNT**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pmu_wr_lat_cnt<br>Total count of write latency (in clock cycles). |

**CACHE REVISION**

Address: Operational Base + offset (0x00f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RO          | 0x00000100         | revision<br>Cache revision number. |

**8.3.5 Registers Summary(INTMUX)**

| <b>Name</b>                                | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>               |
|--------------------------------------------|---------------|-------------|--------------------|----------------------------------|
| <u>INTMUX INT ENABLE GR</u><br><u>OUP0</u> | 0x0000        | W           | 0x00000000         | Interrupt Group0 Enable Register |
| <u>INTMUX INT ENABLE GR</u><br><u>oup1</u> | 0x0004        | W           | 0x00000000         | Interrupt Group1 Enable Register |
| <u>INTMUX INT ENABLE GR</u><br><u>oup2</u> | 0x0008        | W           | 0x00000000         | Interrupt Group2 Enable Register |

| Name                                 | Offset | Size | Reset Value | Description                      |
|--------------------------------------|--------|------|-------------|----------------------------------|
| <u>INTMUX INT ENABLE GR<br/>OUP3</u> | 0x000C | W    | 0x00000000  | Interrupt Group3 Enable Register |
| <u>INTMUX INT FLAG GROU<br/>P0</u>   | 0x0080 | W    | 0x00000000  | Interrupt Group0 Flag Register   |
| <u>INTMUX INT FLAG GROU<br/>P1</u>   | 0x0084 | W    | 0x00000000  | Interrupt Group1 Flag Register   |
| <u>INTMUX INT FLAG GROU<br/>P2</u>   | 0x0088 | W    | 0x00000000  | Interrupt Group2 Flag Register   |
| <u>INTMUX INT FLAG GROU<br/>P3</u>   | 0x008C | W    | 0x00000000  | Interrupt Group3 Flag Register   |

Notes: **S**ize: **B**- Byte (8 bits) access, **H**W- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 8.3.6 Detail Registers Description

#### INTMUX INT ENABLE GROUP0

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | enable<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

#### INTMUX INT ENABLE GROUP1

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | enable<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

#### INTMUX INT ENABLE GROUP2

Address: Operational Base + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | enable<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

#### INTMUX INT ENABLE GROUP3

Address: Operational Base + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | enable<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

#### INTMUX INT FLAG GROUP0

Address: Operational Base + offset (0x0080)

| Bit  | Attr | Reset Value | Description                                                                                                              |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | flag<br>Each bit represents one interrupt is in service.<br>1'b0: Interrupt in service<br>1'b1: Interrupt out of service |

#### INTMUX INT FLAG GROUP1

Address: Operational Base + offset (0x0084)

| Bit  | Attr | Reset Value | Description                                                                                                              |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | flag<br>Each bit represents one interrupt is in service.<br>1'b0: Interrupt in service<br>1'b1: Interrupt out of service |

**INTMUX INT FLAG GROUP2**

Address: Operational Base + offset (0x0088)

| Bit  | Attr | Reset Value | Description                                                                                                              |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | flag<br>Each bit represents one interrupt is in service.<br>1'b0: Interrupt in service<br>1'b1: Interrupt out of service |

**INTMUX INT FLAG GROUP3**

Address: Operational Base + offset (0x008C)

| Bit  | Attr | Reset Value | Description                                                                                                              |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | flag<br>Each bit represents one interrupt is in service.<br>1'b0: Interrupt in service<br>1'b1: Interrupt out of service |

## 8.4 Interface Description

HP\_MCU has two sets of serial debug interface. When we debug using serial wire, not only set IOMUX, but also configure the bit[1] of CPU\_CTRL\_CON in CORE\_SGRF to enable debug for HP\_MCU.

Table 8-2 MCU Serial Wire Debug Interface Description

| Module Pin       | Direction | Pad Name                                                                   | IOMUX Setting                               |
|------------------|-----------|----------------------------------------------------------------------------|---------------------------------------------|
| hpmcu_jtag_tckm0 | I         | LPMCU_JTAG_TCK_M0/HPMCU_JTAG_TCK_M0/UART2_TX_M1/A7_JTAG_TCK_M1(GPIO1_B2_d) | VCCIO1_IOC_GPIO1B_IOMUX_SEL_L[11:8] = 3'h3  |
| hpmcu_jtag_tmsm0 | I/O       | LPMCU_JTAG_TMS_M0/HPMCU_JTAG_TMS_M0/UART2_RX_M1/A7_JTAG_TMS_M1(GPIO1_B3_u) | VCCIO1_IOC_GPIO1B_IOMUX_SEL_L[14:12] = 3'h3 |
| hpmcu_jtag_tckm1 | I         | HPMCU_JTAG_TCK_M1/A7_JTAG_TCK_M0/UART5_RX_M0/SDMM_C0_D2(GPIO3_A7_u)        | VCCIO4_IOC_GPIO3A_IOMUX_SEL_H[14:12] = 3'h4 |
| hpmcu_jtag_tmsm1 | I/O       | HPMCU_JTAG_TMS_M1/A7_JTAG_TMS_M0/UART5_TX_M0/SDMM_C0_D3(GPIO3_A6_u)        | VCCIO4_IOC_GPIO3A_IOMUX_SEL_H[11:8] = 3'h4  |

Notes: I=input, O=output, I/O=input/output, bidirectional

## 8.5 Application Notes

### 8.5.1 Clock and Reset Generation

Please refer to "Chapter CRU" for more detailed information.

### 8.5.2 Cache Initialization

The Cache is bypassed after reset and need to be initialized by the MCU. The basic initialization flow is:

- Configure to Write-Back or Write-Through mode by setting CACHE\_CTRL.cache\_wt\_en and start initialization by configuring CACHE\_CTRL.cache\_en to high while keeping the Cache in bypass mode (CACHE\_CTRL.cache\_bypass is high). The store buffer must and only can be enabled for Write-Back mode, so you must disable the store buffer when Write-Through mode is selected. You can also enable the hot buffer for better performance. It is recommended that configure the I-Cache to Write-Through mode and configure the D-Cache to Write-

Back mode.

2. Wait for cache initialization to be finished by polling CACHE\_STATUS.cache\_init\_finish.
3. Disable cache bypass mode by configuring CACHE\_CTRL.cache\_bypass to low. Now that the Cache is enabled.
4. Simply configure CACHE\_CTRL.cache\_bypass to bypass or enable the Cache again after the initialization flow.

### 8.5.3 Cache Maintenance

The Cache Controller support the following cache maintenance operations:

- Clean by address: push the specified cache line data to external memory if it is valid and dirty.
- Invalidate by address: unconditionally clear the valid and dirty data of the specified cache lines.
- Clean and invalidate by address: clean and then invalidate the specified cache lines.
- Invalidate all: unconditionally clear the valid and dirty data for all the cache lines.
- Clean and invalidate all (Flush): clean and then invalidate all the cache lines.

For the operation of cache clean and invalidate all, configure CACHE\_CTRL.cache\_flush to high first, and then wait for flush to be done by polling

CACHE\_STATUS.cache\_flush\_done. Finally, if the flush is done, you should configure CACHE\_CTRL.cache\_flush to low.

For the other four maintenance operations, you should set the maintenance command and the address range of the cache lines by configuring CACHE\_MAINTAIN0 and CACHE\_MAINTAIN1, then start by configuring CACHE\_MAINTAIN0.cache\_m\_valid to high. When the operation is finished, CACHE\_MAINTAIN0.cache\_m\_valid will be automatically cleared to low. You can also poll CACHE\_STATUS.cache\_m\_busy to judge whether the operation is done.

### 8.5.4 Cache RAM Debug Mode

When the Cache is enabled and not in the bypass mode, you can enter the cache RAM debug mode by configuring CACHE\_RAM\_DEBUG.ram\_debug\_en to high. In the RAM debug mode, the cache RAM can be accessed directly by the specific address, and all the other cacheable memory accesses are bypassed because the cache core is disabled. The following table shows the address map for the cache RAM debug.

Table 8-3 Address Map for the Cache RAM Debug

| <b>RAM Access Type</b> | <b>RAM Access Size</b> | <b>Address Range for Cache RAM Debug</b> |
|------------------------|------------------------|------------------------------------------|
| Reserved               | 7KB                    | 0xF6F26400 ~ 0xF6F27FFF                  |
| TAG RAM1               | 1KB                    | 0xF6F26000 ~ 0xF6F263FF                  |
| Reserved               | 7KB                    | 0xF6F24400 ~ 0xF6F25FFF                  |
| TAG RAMCU              | 1KB                    | 0xF6F24000 ~ 0xF6F243FF                  |
| DATA RAM1              | 8KB                    | 0xF6F22000 ~ 0xF6F23FFF                  |
| DATA RAMCU             | 8KB                    | 0xF6F20000 ~ 0xF6F21FFF                  |

As shown in the above table, there are 2 ways for each cache, and the size of one DATA RAM is 8KB. The following explanation may help you use the RAM debug method:

- Using the word-aligned address to access the TAG RAM.
- The bits[9:2] of the TAG RAM address are acted as the bits[12:5] of the corresponding memory address.
- Only the bits[20:0] of the TAG RAM data are available, and the bits[31:21] are always zero.
  - The bit[20] is the valid flag bit.
  - The bit[19] is the dirty flag bit.
  - The bits[18:0] are acted as the bits[31:13] of the corresponding memory address.
- The bits[12:0] of the DATA RAM address are acted as the bits[12:0] of the corresponding memory address.
- In order to get the cache line data at the wanted address, you should read the both of the TAG RAMs to find the matched address, and then read data from the corresponding

DATA RAM.

- If write data to the DATA RAM, 8 copies of the 32bit data on the AHB bus will be written to the 32Byte cache line.

### **8.5.5 Other Hints**

One interrupt request source is supported for the I/D-Cache, so you can query the interrupt register in the ISR if it is enabled. When CACHE\_INT\_EN.err\_record\_en is high, the Cache will generate a bus error interrupt if access to a wrong address. You can read CACHE\_INT\_ST.ahb\_error\_status for the cache interrupt status and get the recent error address information from CACHE\_ERR\_HADDR.status\_haddr.

## **8.6 Application Notes**

- How to boot?

Currently, the MCU core boot address is configurable, its default value is 32'h0000\_0000, and the default value of trap vector base address is 32'h0010\_01c0, you can configure SCR1\_BOOT\_ADDR of SGRF before de-assert its reset. if you change the boot address, don't forget to configure the MCU\_CSR\_MTVEC register by system instructions.

## Chapter 9 Timer

### 9.1 Overview

TIMER is a programmable timer peripheral. This component is an APB slave device. In RV1106, there are three types of TIMER according to the count type, which are normal decrement count TIMER, normal increment count TIMER and special function increment count TIMER. The normal decrement count TIMER is called NDCTIMER. The normal increment count TIMER is called NICTIMER. The special function increment count TIMER is called HPTIMER(High Precision TIMER).

5 normal decrement count TIMERS and 1 normal increment count TIMER constitute a 6-channel TIMER. In 6-channel TIMER, TIMER5 is the normal increment count TIMER, and the other channel TIMER is the normal decrement count TIMER.

2 normal increment count TIMERS form a 2-channel TIMER.

HPTIMER has calibration function and provides count value for CPU.

Timer supports the following features:

- All three kinds of counter support 32 bits APB slave
- All three kinds of counter loading count value support configurable
- All three kinds of counter support two counting modes: free-running and user-defined count
- All three kinds of counters support maskable interrupts
- HPTIMER with three timer mode: Normal, Hardware adjust, Software adjust
- Hardware adjust mode HPTIMER can be calibrated back to the exact count value without software calculation
- Software adjust mode HPTIMER can be calibrated back to the exact count value with software-aided calculation
- Common multiples of slow and fast clock cycles are configurable

## 9.2 Block Diagram

### 9.2.1 Normal count TIMER block diagram



Fig. 9-1 Normal Timer Block Diagram

Fig. 9-1 show 6-channel TIMER and 2-channel TIMER. At 6CH\_TIMER, the TIMER ch0~ch4 are the normal decrement count TIMER and ch5 is the normal increment count TIMER. At 2CH\_TIMER, ch0 and ch1 are common normal increment count TIMER. APB is the read and write interface of timer register. resetn\_timern and clk\_timern are reset and count clock for each channel timer. Timern\_int and timern\_en are interrupt and clock enable for each channel timer respectively. (timern is the signal corresponding to TIMER CHn)

## 9.2.2 HPTIMER block diagram



Fig. 9-2 HPTIMER Block Diagram

Fig. 9-2 shows the block diagram of HPTIMER.

HPTIMER has a set of APB interfaces for reading and writing registers.

lp\_ena is the low power enable signal sent by PMU to HPTIMER, and it is also the indication signal of clk\_timer frequency switching.

timer\_core\_value[63:0], timer\_core\_upd\_req, timer\_core\_upd\_ack is the interaction signal with core. timer\_core\_value[63:0] is the count update value, timer\_core\_upd\_req is the update count request signal, timer\_core\_upd\_ack is the update count response signal.

timer\_hp\_en is the enabling signal of clk\_32k and clk\_timer clocks. timer\_hp\_int is the interrupt output of HPTIMER.

## 9.3 Function Description

### 9.3.1 TIMER clock

The clock frequency of the counting clock source of NICTIMER and NDCTIMER is 24MHz. The clock source clock of clk\_32k of HPTIMER is 32KHz, and the clock frequency of clk\_timer clock source is switched between 24MHz and 32Khz.

### 9.3.2 Programming sequence

#### 9.3.2.1 NDCTIMER and NICTIMER programming sequence

1. Initialize the TIMER by the TIMER\_TIMERn\_CONTROLREG ( $0 \leq n \leq 5$ ) register:
  - (1) Disable the timer by writing a "0" to the timer enable bit (bit 0). Accordingly, the timer\_en output signal is de-asserted.
  - (2) Program the timer mode—free-running or user-defined—by writing a "0" or "1" respectively, to the timer mode bit (bit 1).
  - (3) 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 TIMER\_TIMERn\_LOAD\_COUNT1 ( $0 \leq n \leq 5$ ) and TIMER\_TIMERn\_LOAD\_COUNT0 ( $0 \leq n \leq 5$ ) register.
3. Enable the TIMER by writing a "1" to bit 0 of TIMER\_TIMERn\_CONTROLREG ( $0 \leq n \leq 5$ ).



Fig. 9-3 Timer Usage Flow

### 9.3.2.2 HPTIMER programming sequence

#### 9.3.2.2.1 Normal mode

1. Initialize the HPTIMER by the TIMER\_HP\_CTRL register:
  - (1) Disable the HPTIMER by writing a '0' to the timer enable bit (bit 0). Accordingly, the timer\_hp\_en output signal is de-asserted.
  - (2) Program the timer mode, normal mode by writing a 0x0 to the timer mode bits (bit 1 to bit 2).
  - (3) Program the count mode, free-running or user-defined by writing a '0' or '1' to the count mode bit (bit 3).
2. Load the HPTIMER count value into the TIMER\_HP\_LOAD\_COUNT1 and TIMER\_HP\_LOAD\_COUNT0 register.
3. Enable the HPTIMER by writing a '1' to bit 0 of TIMER\_HP\_CTRL.

If you want to do another count, repeat steps 1 to 3.

#### 9.3.2.2.2 Hardware adjust mode

1. Initialize the HPTIMER by the TIMER\_HP\_CTRL register:
  - (1) Disable the HPTIMER by writing a '0' to the timer enable bit (bit 0). Accordingly, the timer\_hp\_en output signal is de-asserted.
  - (2) Program the timer mode, normal mode by writing a 0x1 to the timer mode bits (bit 1 to bit 2).
  - (3) Program the count mode, free-running or user-defined by writing a '0' or '1' to the count mode bit (bit 3).
2. Initialize the HPTIMER by the TIMER\_HP\_INTR\_STATUS register. Write 0x7 to TIMER\_HP\_INTR\_STATUS register to clear TIMER\_HP\_INTR\_STATUS register.
3. Load the HPTIMER count value into the TIMER\_HP\_LOAD\_COUNT1 and TIMER\_HP\_LOAD\_COUNT0 register.
4. Configure the HPTIMER GCD register.
  - (1) Divide the least common multiple of clk\_timer and clk\_32k clock cycle by clk\_timer clock cycle and configure it in TIMER\_HP\_T24\_GCD register.
  - (2) Divide the least common multiple of clk\_timer and clk\_32k clock cycle by clk\_32k clock cycle and configure it in TIMER\_HP\_T32\_GCD register.
5. Enable the HPTIMER by writing a '1' to bit 0 of TIMER\_HP\_CTRL.
6. Read out the INTR\_STATUS register until the ini\_adj\_done bit segment (bit 1) is '1', which means that the HPTIMER 32K count is initially adjusted. The low power mode can only be entered after the initial adjustment is completed.
7. The chip enters and exits the low power consumption mode at any time in between.
8. Read out the INTR\_STATUS register until the sync\_done bit segment (bit 2) is '1', indicating that the HPTIMER count is adjusted.
9. Write 0x7 to TIMER\_HP\_INTR\_STATUS register to clear TIMER\_HP\_INTR\_STATUS register.

If the chip enters and exits the low power consumption mode again, repeat steps 7 to 9.

#### 9.3.2.2.3 Software adjust mode

1. Initialize the HPTIMER by the TIMER\_HP\_CTRL register:
  - (1) Disable the HPTIMER by writing a '0' to the timer enable bit (bit 0). Accordingly, the timer\_hp\_en output signal is de-asserted.

- (2) Program the timer mode, normal mode by writing a 0x2 to the timer mode bits (bit 1 to bit 2).
- (3) Program the count mode, free-running or user-defined by writing a '0' or '1' to the count mode bit (bit 3).
2. Initialize the HPTIMER by the TIMER\_HP\_INTR\_STATUS and BEGIN\_END\_VALID register. Write 0x7 to TIMER\_HP\_INTR\_STATUS register to clear TIMER\_HP\_INTR\_STATUS register. write 0x3 to BEGIN\_END\_VALID register to clear BEGIN\_END\_VALID register.
3. Load the HPTIMER count value into the TIMER\_HP\_LOAD\_COUNT1 and TIMER\_HP\_LOAD\_COUNT0 register.
4. Enable the HPTIMER by writing a '1' to bit 0 of TIMER\_HP\_CTRL.
5. The chip enters and exits the low power consumption mode at any time in between.
6. Read out BEGIN\_END\_VALID register until the value of it is 0x3, which indicates that the chip has entered and exited the low power consumption mode, then you can adjust the timer count value. Then write 0x3 to BEGIN\_END\_VALID register to clear the register.
7. The count value of HPTIMER compensation.
  - (1) Read out TIMER\_HP\_T24\_32BEGIN1, TIMER\_HP\_T24\_32BEGIN0, TIMER\_HP\_T32\_24END1 and TIMER\_HP\_T32\_24END0 register.
  - (2) configure TIMER\_HP\_T24\_DELAT\_COUNT1 and TIMER\_HP\_T24\_DELAT\_COUNT0 registers to compensate for the count values according to the values of these registers read out above.
  - (3) Write 0x1 to TIMER\_HP\_SYNC\_REQ register to start compensation counting.
  - (4) Read out the INTR\_STATUS register until the sync\_done bit segment (bit 2) is '1', indicating that the compensation count is completed.
8. Write 0x7 to TIMER\_HP\_INTR\_STATUS register to clear TIMER\_HP\_INTR\_STATUS register.

If the chip enters and exits the low power consumption mode again, repeat steps 5 to 8.

### **9.3.3 Loading a timer count value**

For the descending TIMER(that is, the value from which it counts down). The initial value for each TIMER is loaded into the TIMER using the load count register (TIMER\_TIMERn\_LOAD\_COUNT1 and TIMER\_TIMERn\_LOAD\_COUNT0). Two events can cause a TIMER to load the initial value from its load count register:

- TIMER is enabled after reset or disabled.
- TIMER counts down to 0, when TIMER is configured into free-running mode.
- For the incremental TIMER(that is, the value from which it counts up). The initial value for each timer is zero. The count register will count up to the value loaded in the register TIMER\_TIMERn\_LOAD\_COUNT1 and TIMER\_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 TIMER\_TIMERn\_LOAD\_COUNT1 and TIMER\_TIMERn\_LOAD\_COUNT0, when timer is configured into free-running mode.

### **9.3.4 Timer mode selection**

- User-defined count mode – TIMER loads TIMER\_TIMERn\_LOAD\_COUNT1 and TIMER\_TIMERn\_LOAD\_COUNT0 registers (for descending TIMER) or zero (for incremental TIMER) as initial value. When the TIMER counts down to 0 (for descending TIMER) or counts up to the value in TIMER\_TIMERn\_LOAD\_COUNT1 and TIMER\_TIMERn\_LOAD\_COUNT0 (for incremental TIMER), it will not automatically reload the count register. User need to disable timer firstly and follow the programming sequence to make timer work again.
- Free-running mode – TIMER loads the TIMER\_TIMERn\_LOAD\_COUNT1 and TIMER\_TIMERn\_LOAD\_COUNT0(for descending TIMER) or zero(for incremental TIMER) register as initial value. TIMER will automatically reload the count register, when timer counts down to 0(for descending TIMER) or counts up to the value in TIMER\_TIMERn\_LOAD\_COUNT1 and TIMER\_TIMERn\_LOAD\_COUNT0 (for incremental TIMER).

## 9.4 Register Description

### 9.4.1 Registers Summary

#### 9.4.1.1 Normal Count TIMER Register Summary

For 2-channel normal count TIMER, the base address of channel 1 is greater than that of channel 0 by 0x20. For 6-channel normal count TIMER, the base address of channel 1 is greater than that of channel 0 by 0x20, the base address of channel 2 is greater than that of channel 1 by 0x20, and so on. The revision register offset of 2-channel / 6-channel normal count TIMER is 0xf0.

If you want to know that each TIMER is 2-channel or 6-channel, please refer to the "TIMER attributes" section at the end of "Chapter TIMER".

| Name                           | Offset            | Size | Reset Value | Description                                                                                                                      |
|--------------------------------|-------------------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| TIMER TIMERN LOAD CO<br>UNTO   | 0x0000<br>+n*0x20 | W    | 0x00000000  | Timern Load Count Register 0                                                                                                     |
| TIMER TIMERN LOAD CO<br>UNT1   | 0x0004<br>+n*0x20 | W    | 0x00000000  | Timern Load Count Register 1.<br>Higher 32 bits Value to be loaded into Timer n. This is the value from which counting commences |
| TIMER TIMERN CURRENT<br>VALUE0 | 0x0008<br>+n*0x20 | W    | 0x00000000  | Timern Current Value Register 0                                                                                                  |
| TIMER TIMERN CURRENT<br>VALUE1 | 0x000c<br>+n*0x20 | W    | 0x00000000  | Timern Current Value Register 1.<br>High 32 bits of Current Value of Timer n                                                     |
| TIMER TIMERN CONTROL<br>REG    | 0x0010<br>+n*0x20 | W    | 0x00000000  | Timern Control Register                                                                                                          |
| TIMER TIMERN INTSTAT<br>US     | 0x0018<br>+n*0x20 | W    | 0x00000000  | Timern Interrupt Status Register                                                                                                 |
| TIMER 2CH REVISION             | 0x00F0            | W    | 0x15650302  | 2-channel TIMER version                                                                                                          |
| TIMER 6CH REVISION             | 0x00F0            | W    | 0x11972006  | 6-channel TIMER version                                                                                                          |

Notes: **S**-Size:**B**- Byte (8 bits) access, **H****W**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

#### 9.4.1.2 HPTIMER Register Summary

| Name                          | Offset | Size | Reset Value | Description                                     |
|-------------------------------|--------|------|-------------|-------------------------------------------------|
| TIMER HP REVISION             | 0x0000 | W    | 0x13D10201  | HPTIMER version                                 |
| TIMER HP CTRL                 | 0x0004 | W    | 0x00000000  | HPTIMER control                                 |
| TIMER HP INTR EN              | 0x0008 | W    | 0x00000000  | Interrupt mask                                  |
| TIMER HP T24 GCD              | 0x000C | W    | 0x00000000  | Common multiple div 24M                         |
| TIMER HP T32 GCD              | 0x0010 | W    | 0x00000000  | Common multiple div 32K                         |
| TIMER HP LOAD COUNT<br>0      | 0x0014 | W    | 0x00000000  | Low 32bits of load count value                  |
| TIMER HP LOAD COUNT<br>1      | 0x0018 | W    | 0x00000000  | High 32bits of load count value                 |
| TIMER HP T24 DELAT C<br>OUNT0 | 0x001C | W    | 0x00000000  | Low 32bits of 24M clock delay time count value  |
| TIMER HP T24 DELAT C<br>OUNT1 | 0x0020 | W    | 0x00000000  | High 32bits of 24M clock delay time count value |

| Name                                | Offset | Size | Reset Value | Description                            |
|-------------------------------------|--------|------|-------------|----------------------------------------|
| TIMER HP CURR 32K VA<br><u>LUE0</u> | 0x0024 | W    | 0x00000000  | Low 32bits of current cnt_32k value    |
| TIMER HP CURR 32K VA<br><u>LUE1</u> | 0x0028 | W    | 0x00000000  | High 32bits of current cnt_32k value   |
| TIMER HP CURR TIMER<br>VALUE0       | 0x002C | W    | 0x00000000  | Low 32bits of current timer_cnt value  |
| TIMER HP CURR TIMER<br>VALUE1       | 0x0030 | W    | 0x00000000  | High 32bits of current timer_cnt value |
| TIMER HP T24 32BEGIN<br><u>0</u>    | 0x0034 | W    | 0x00000000  | Low 32 bits of low power begin         |
| TIMER HP T24 32BEGIN<br><u>1</u>    | 0x0038 | W    | 0x00000000  | High 32 bits of low power begin        |
| TIMER HP T32 24END0                 | 0x003C | W    | 0x00000000  | Low 32 bits of low power end           |
| TIMER HP T32 24END1                 | 0x0040 | W    | 0x00000000  | High 32 bits of low power end          |
| TIMER HP BEGIN END V<br><u>ALID</u> | 0x0044 | W    | 0x00000000  | Low power count value valid            |
| TIMER HP SYNC REQ                   | 0x0048 | W    | 0x00000000  | Synchronize request                    |
| TIMER HP INTR STATUS                | 0x004C | W    | 0x00000000  | Interrupt status                       |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 9.4.2 Detail Register Description

### 9.4.2.1 Normal Count TIMER Detail Register Description

#### **TIMERn TIMERn LOAD COUNT0**

Address: Operational Base + offset (0x0000+n\*0x20)

| Bit  | Attr | Reset Value | Description                                                                                                     |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | load_count_0<br>Lower 32 bits Value to be loaded into Timer n. This is the value from which counting commences. |

#### **TIMERn TIMERn LOAD COUNT1**

Address: Operational Base + offset (0x0004+n\*0x20)

| Bit  | Attr | Reset Value | Description                                                                                                      |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | load_count_1<br>Higher 32 bits Value to be loaded into Timer n. This is the value from which counting commences. |

#### **TIMERn TIMERn CURRENT VALUE0**

Address: Operational Base + offset (0x0008+n\*0x20)

| Bit  | Attr | Reset Value | Description                                                         |
|------|------|-------------|---------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | timern_current_value0<br>Lower 32 bits of Current Value of Timer n. |

#### **TIMERn TIMERn CURRENT VALUE1**

Address: Operational Base + offset (0x000c+n\*0x20)

| Bit  | Attr | Reset Value | Description                                                          |
|------|------|-------------|----------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | timern_current_value1<br>Higher 32 bits of Current Value of Timer n. |

#### **TIMERn TIMERn CONTROLREG**

Address: Operational Base + offset (0x0010+n\*0x20)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x0                | Reserved                                                                             |
| 2          | RW          | 0x0                | timer_int_en<br>Timer interrupt enable<br>1'b0: Disable<br>1'b1: Enable              |
| 1          | RW          | 0x0                | timer_mode<br>Timer mode<br>1'b0: Free-running mode<br>1'b1: User-defined count mode |
| 0          | RW          | 0x0                | timer_en<br>Timer enable<br>1'b0: Disable<br>1'b1: Enable                            |

**TIMER TIMERn INTSTATUS**

Address: Operational Base + offset (0x0018+n\*0x20)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:1       | RO          | 0x0                | Reserved                                                              |
| 0          | RO          | 0x0                | timern_int<br>This register contains the interrupt status for timern. |

**TIMER 2CH REVISION**

Address: Operational Base + offset (0x00F0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:16      | RO          | 0x1565             | svn_revision<br>SVN revision: 16'h1565       |
| 15:10      | RO          | 0x00               | reserved                                     |
| 9          | RW          | 0x1                | ch1_type<br>Channel 1 is a count up counter. |
| 8          | RW          | 0x1                | ch0_type<br>Channel 0 is a count up counter. |
| 7:0        | RO          | 0x02               | ip_function<br>IP function: 8'h2             |

**TIMER 6CH REVISION**

Address: Operational Base + offset (0x00F0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:16      | RW          | 0x1197             | svn_revision<br>SVN revision: 16'h1197         |
| 15:14      | RO          | 0x0                | reserved                                       |
| 13         | RW          | 0x1                | ch5_type<br>Channel 5 is a count up counter.   |
| 12         | RW          | 0x0                | ch4_type<br>Channel 4 is a count down counter. |
| 11         | RW          | 0x0                | ch3_type<br>Channel 3 is a count down counter. |
| 10         | RW          | 0x0                | ch2_type<br>Channel 2 is a count down counter. |
| 9          | RW          | 0x0                | ch1_type<br>Channel 1 is a count down counter. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 8          | RW          | 0x0                | ch0_type<br>Channel 0 is a count down counter. |
| 7:0        | RW          | 0x06               | ip_function<br>IP function: 8'h6               |

### 9.4.2.2 HPTIMER Detail Register Description

#### **TIMER HP REVISION**

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 31:16      | RO          | 0x19e1             | svn_revision<br>SVN revision: 16'h19e1                                         |
| 15:10      | RO          | 0x00               | reserved                                                                       |
| 9:8        | RW          | 0x2                | ch_type<br>Channel 0 is a low power recovery self-correction count up counter. |
| 7:0        | RO          | 0x01               | ip_function<br>IP function: 8'h1.                                              |

#### **TIMER HP CTRL**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                 |
| 3          | RW          | 0x0                | count_mode<br>Timer count mode<br>1'b0: Free-running mode<br>1'b1: User-defined count mode                                                               |
| 2:1        | RW          | 0x0                | timer_mode<br>Select timer as which timer<br>2'b00: Normal timer<br>2'b01: Adjust timer with hardware adjust<br>2'b10: Adjust timer with software adjust |
| 0          | RW          | 0x0                | timer_en<br>Timer enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                |

#### **TIMER HP INTR EN**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                              |
| 2          | RW          | 0x0                | sync_done_intr_en<br>Synchronization done interrupt enable<br>1'b0: Disable<br>1'b1: Enable           |
| 1          | RW          | 0x0                | ini_adj_done_intr_en<br>Initial adjust done interrupt enable<br>1'b0: Disable<br>1'b1: Enable         |
| 0          | RW          | 0x0                | count_reach_intr_en<br>Timer count reach load_count interrupt enable<br>1'b0: Disable<br>1'b1: Enable |

#### **TIMER HP T24 GCD**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | t24_gcd<br>The least common multiple of 24M and 32K clock cycles divided by 24M clock cycles. |

**TIMER HP T32 GCD**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | t32_gcd<br>The least common multiple of 24M and 32K clock cycles divided by 32K clock cycles. |

**TIMER HP LOAD COUNT0**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | load_count0<br>Low 32bits of load count value. |

**TIMER HP LOAD COUNT1**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:0       | RW          | 0x00000000         | load_count1<br>High 32bits of load count value. |

**TIMER HP T24 DELAT COUNT0**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | t24_delay_time_count0<br>Low 32bits of 24M clock delay time count value. |

**TIMER HP T24 DELAT COUNT1**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | t24_delay_time_count1<br>High 32bits of 24M clock delay time count value. |

**TIMER HP CURR 32K VALUE0**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | current_32k_value0<br>Low 32bits of current cnt_32k value. |

**TIMER HP CURR 32K VALUE1**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | current_32k_value1<br>High 32bits of current cnt_32k value. |

**TIMER HP CURR TIMER VALUE0**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | current_value0<br>Low 32bits of current timer_cnt value. |

**TIMER HP CURR TIMER VALUE1**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | current_value1<br>High 32bits of current timer_cnt value. |

**TIMER HP T24\_32BEGIN0**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | t24_32begin0<br>24M switches to 32K clock, with a low 32 bits of timer_cnt value. |

**TIMER HP T24\_32BEGIN1**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | t24_32begin1<br>24M switches to 32K clock, with a high 32 bits of timer_cnt value. |

**TIMER HP T32\_24END0**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | t32_24end0<br>32K switches to 24M clock, with a low 32 bits of timer_cnt value. |

**TIMER HP T32\_24END1**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | t32_24end1<br>32K switches to 24M clock, with a high 32 bits of timer_cnt value. |

**TIMER HP BEGIN END VALID**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                     |
| 1          | W1 C        | 0x0                | t32_24end_valid<br>T32_24END value valid<br>1'b0: Invalid<br>1'b1: Valid     |
| 0          | W1 C        | 0x0                | t24_32begin_valid<br>T24_32BEGIN value valid<br>1'b0: Invalid<br>1'b1: Valid |

**TIMER HP SYNC REQ**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                       |
| 0          | R/W SC      | 0x0                | sync_request<br>Timer_cnt synchronize request. |

**TIMER HP INTR STATUS**

Address: Operational Base + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                     |
| 2          | W1 C        | 0x0                | sync_done<br>Timer_cnt synchronization done. |

| Bit | Attr    | Reset Value | Description                                                      |
|-----|---------|-------------|------------------------------------------------------------------|
| 1   | W1<br>C | 0x0         | ini_adj_done<br>Cnt_32k initial adjust done.                     |
| 0   | W1<br>C | 0x0         | count_reach<br>Normal counter: timer_cnt reach load_count value. |

## 9.5 Application Notes

### 9.5.1 Clock and Enable

In the chip, the timer\_clk is from 24MHz XIN\_OSC, asynchronous to the pclk. When user disables the timer enables bit (bit 0 of TIMERn\_CONTROLREG ( $0 \leq n \leq 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. 9-4 Timing between timer\_en and timer\_clk

Please refer to function description section for the timer usage flow.

### 9.5.2 HPTIMER application notes

- Initial adjustment, synchronous counting adjustment time is about 2ms.
- When HPTIMER is used as software / hardware adjustment count, the count reaches the TIMER\_HP\_LOAD\_COUNT value, the interrupt status bit will be set, but the count will not stop and continue to count.
- The timer\_en of the CTRL register will output as a reference signal for timer clock gating. When timer\_en is '0', it will gate the 24M and 32K clocks of the input timer. The application is only allowed to re-config registers when timer\_en is low.

### 9.5.3 TIMER attributes

Table 9-1 shows the TIMER name corresponding to each TIMER, the total number of channels and their PD. It also shows the base address of each TIMER, in which the difference of TIMER address offset between adjacent channels in each TIMER is 0x20.

Table 9-1 TIMER attribute

| TIMER Name   | CH NUM | PD      | Base Address |
|--------------|--------|---------|--------------|
| TIMER_2CH_S  | 2      | pd_peri | 0xff590000   |
| TIMER_6CH_NS | 6      | pd_peri | 0xff580000   |
| HP_TIMER     | 1      | pd_pmu  | 0xff2f0000   |

## Chapter 10 DMA Controller (DMAC)

### 10.1 Overview

RV1106 supports a Direct Memory Access (DMA) Controller. 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 configurable SGRF module.

DMAC supports the following features:

- Supports 21 peripheral requests
- Up to 64 bits 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 DMAC request mapping scheme.

Table 10-1 DMAC Request Mapping Table

| DMAC0      |             |            |
|------------|-------------|------------|
| Req number | Source      | Polarity   |
| 0          | SPI0_RX     | High level |
| 1          | SPI0_TX     | High level |
| 2          | SPI1_RX     | High level |
| 3          | SPI1_TX     | High level |
| 6          | UART0_RX    | High level |
| 7          | UART0_TX    | High level |
| 8          | UART1_RX    | High level |
| 9          | UART1_TX    | High level |
| 10         | UART2_RX    | High level |
| 11         | UART2_TX    | High level |
| 12         | UART3_RX    | High level |
| 13         | UART3_TX    | High level |
| 14         | UART4_RX    | High level |
| 15         | UART4_TX    | High level |
| 16         | UART5_RX    | High level |
| 17         | UART5_TX    | High level |
| 18         | PWM0        | High level |
| 19         | PWM1        | High level |
| 20         | PWM2        | High level |
| 21         | I2S0_8CH_RX | High level |
| 22         | I2S0_8CH_TX | High level |

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

### 10.2 Block Diagram

Following figure shows the block diagram of DMAC.



Fig. 10-1 DMAC Block Diagram

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.

## 10.3 Function Description

### 10.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. It 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.

### 10.3.2 Operation states

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



Fig. 10-2 DMAC Operation State

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 DMA manager thread moves to the Stopped state.

## 10.4 Register Description

### 10.4.1 Registers Summary

| Name           | Offset | Size | Reset Value | Description                         |
|----------------|--------|------|-------------|-------------------------------------|
| DMAC_DSR       | 0x0000 | W    | 0x00000000  | DMA Manager Status Register         |
| DMAC_DPC       | 0x0004 | W    | 0x00000000  | DMA Program Counter Register        |
| DMAC_INTEN     | 0x0020 | W    | 0x00000000  | Interrupt Enable Register           |
| DMAC_EVENT_RIS | 0x0024 | W    | 0x00000000  | Event-Interrupt Raw Status Register |
| DMAC_INTMIS    | 0x0028 | W    | 0x00000000  | Interrupt Status Register           |
| DMAC_INTCLR    | 0x002c | W    | 0x00000000  | Interrupt Clear Register            |
| DMAC_FSRD      | 0x0030 | W    | 0x00000000  | Fault Status DMA Manager Register   |
| DMAC_FSRC      | 0x0034 | W    | 0x00000000  | Fault Status DMA Channel Register   |
| DMAC_FTRD      | 0x0038 | W    | 0x00000000  | Fault Type DMA Manager Register     |
| DMAC_FTR0      | 0x0040 | W    | 0x00000000  | Fault Type DMA Channel 0 Register   |
| DMAC_FTR1      | 0x0044 | W    | 0x00000000  | Fault Type DMA Channel 1 Register   |
| DMAC_FTR2      | 0x0048 | W    | 0x00000000  | Fault Type DMA Channel 2 Register   |
| DMAC_FTR3      | 0x004c | W    | 0x00000000  | Fault Type DMA Channel 3 Register   |
| DMAC_FTR4      | 0x0050 | W    | 0x00000000  | Fault Type DMA Channel 4 Register   |
| DMAC_FTR5      | 0x0054 | W    | 0x00000000  | Fault Type DMA Channel 5 Register   |

| Name       | Offset | Size | Reset Value | Description                            |
|------------|--------|------|-------------|----------------------------------------|
| DMAC_FTR6  | 0x0058 | W    | 0x00000000  | Fault Type DMA Channel 6 Register      |
| DMAC_FTR7  | 0x005c | W    | 0x00000000  | Fault Type DMA Channel 7 Register      |
| DMAC_CSR0  | 0x0100 | W    | 0x00000000  | Channel 0 Status Register              |
| DMAC_CPC0  | 0x0104 | W    | 0x00000000  | Channel 0 Program Counter Register     |
| DMAC_CSR1  | 0x0108 | W    | 0x00000000  | Channel 1 Status Register              |
| DMAC_CPC1  | 0x010c | W    | 0x00000000  | Channel 1 Program Counter Register     |
| DMAC_CSR2  | 0x0110 | W    | 0x00000000  | Channel 2 Status Register              |
| DMAC_CPC2  | 0x0114 | W    | 0x00000000  | Channel 2 Program Counter Register     |
| DMAC_CSR3  | 0x0118 | W    | 0x00000000  | Channel 3 Status Register              |
| DMAC_CPC3  | 0x011c | W    | 0x00000000  | Channel 3 Program Counter Register     |
| DMAC_CSR4  | 0x0120 | W    | 0x00000000  | Channel 4 Status Register              |
| DMAC_CPC4  | 0x0124 | W    | 0x00000000  | Channel 4 Program Counter Register     |
| DMAC_CSR5  | 0x0128 | W    | 0x00000000  | Channel 5 Status Register              |
| DMAC_CPC5  | 0x012c | W    | 0x00000000  | Channel 5 Program Counter Register     |
| DMAC_CSR6  | 0x0130 | W    | 0x00000000  | Channel 6 Status Register              |
| DMAC_CPC6  | 0x0134 | W    | 0x00000000  | Channel 6 Program Counter Register     |
| DMAC_CSR7  | 0x0138 | W    | 0x00000000  | Channel 7 Status Register              |
| DMAC_CPC7  | 0x013c | W    | 0x00000000  | Channel 7 Program Counter Register     |
| DMAC_SAR0  | 0x0400 | W    | 0x00000000  | Channel 0 Source Address Register      |
| DMAC_DAR0  | 0x0404 | W    | 0x00000000  | Channel 0 Destination Address Register |
| DMAC_CCR0  | 0x0408 | W    | 0x00000000  | Channel 0 Channel Control Register     |
| DMAC_LC0_0 | 0x040c | W    | 0x00000000  | Channel 0 Loop Counter 0 Register      |
| DMAC_LC1_0 | 0x0410 | W    | 0x00000000  | Channel 0 Loop Counter 1 Register      |
| DMAC_SAR1  | 0x0420 | W    | 0x00000000  | Channel 1 Source Address Register      |
| DMAC_DAR1  | 0x0424 | W    | 0x00000000  | Channel 1 Destination Address Register |
| DMAC_CCR1  | 0x0428 | W    | 0x00000000  | Channel 1 Channel Control Register     |
| DMAC_LC0_1 | 0x042c | W    | 0x00000000  | Channel 1 Loop Counter 0 Register      |
| DMAC_LC1_1 | 0x0430 | W    | 0x00000000  | Channel 1 Loop Counter 1 Register      |
| DMAC_SAR2  | 0x0440 | W    | 0x00000000  | Channel 2 Source Address Register      |
| DMAC_DAR2  | 0x0444 | W    | 0x00000000  | Channel 2 Destination Address Register |
| DMAC_CCR2  | 0x0448 | W    | 0x00000000  | Channel 2 Channel Control Register     |

| Name           | Offset | Size | Reset Value | Description                            |
|----------------|--------|------|-------------|----------------------------------------|
| DMAC_LC0_2     | 0x044c | W    | 0x00000000  | Channel 2 Loop Counter 0 Register      |
| DMAC_LC1_2     | 0x0450 | W    | 0x00000000  | Channel 2 Loop Counter 1 Register      |
| DMAC_SAR3      | 0x0460 | W    | 0x00000000  | Channel 3 Source Address Register      |
| DMAC_DAR3      | 0x0464 | W    | 0x00000000  | Channel 3 Destination Address Register |
| DMAC_CCR3      | 0x0468 | W    | 0x00000000  | Channel 3 Channel Control Register     |
| DMAC_LC0_3     | 0x046c | W    | 0x00000000  | Channel 3 Loop Counter 0 Register      |
| DMAC_LC1_3     | 0x0470 | W    | 0x00000000  | Channel 3 Loop Counter 1 Register      |
| DMAC_SAR4      | 0x0480 | W    | 0x00000000  | Channel 4 Address Register             |
| DMAC_DAR4      | 0x0484 | W    | 0x00000000  | Channel 4 Destination Address Register |
| DMAC_CCR4      | 0x0488 | W    | 0x00000000  | Channel 4 Channel Control Register     |
| DMAC_LC0_4     | 0x048c | W    | 0x00000000  | Channel 4 Loop Counter 0 Register      |
| DMAC_LC1_4     | 0x0490 | W    | 0x00000000  | Channel 4 Loop Counter 1 Register      |
| DMAC_SAR5      | 0x04a0 | W    | 0x00000000  | Channel 5 Address Register             |
| DMAC_DAR5      | 0x04a4 | W    | 0x00000000  | Channel 5 Destination Address Register |
| DMAC_CCR5      | 0x04a8 | W    | 0x00000000  | Channel 5 Channel Control Register     |
| DMAC_LC0_5     | 0x04ac | W    | 0x00000000  | Channel 5 Loop Counter 0 Register      |
| DMAC_LC1_5     | 0x04b0 | W    | 0x00000000  | Channel 5 Loop Counter 1 Register      |
| DMAC_SAR6      | 0x04c0 | W    | 0x00000000  | Channel 6 Source Address Register      |
| DMAC_DAR6      | 0x04c4 | W    | 0x00000000  | Channel 6 Destination Address Register |
| DMAC_CCR6      | 0x04c8 | W    | 0x00000000  | Channel 6 Channel Control Register     |
| DMAC_LC0_6     | 0x04cc | W    | 0x00000000  | Channel 6 Loop Counter 0 Register      |
| DMAC_LC1_6     | 0x04d0 | W    | 0x00000000  | Channel 6 Loop Counter 1 Register      |
| DMAC_SAR7      | 0x04e0 | W    | 0x00000000  | Channel 7 Source Address Register      |
| DMAC_DAR7      | 0x04e4 | W    | 0x00000000  | Channel 7 Destination Address Register |
| DMAC_CCR7      | 0x04e8 | W    | 0x00000000  | Channel 7 Channel Control Register     |
| DMAC_LC0_7     | 0x04ec | W    | 0x00000000  | Channel 7 Loop Counter 0 Register      |
| DMAC_LC1_7     | 0x04f0 | W    | 0x00000000  | Channel 7 Loop Counter 1 Register      |
| DMAC_DBGSTATUS | 0x0d00 | W    | 0x00000000  | Debug Status Register                  |
| DMAC_DBGCMD    | 0x0d04 | W    | 0x00000000  | Debug Command Register                 |

| Name          | Offset | Size | Reset Value | Description                  |
|---------------|--------|------|-------------|------------------------------|
| DMAC_DBGINST0 | 0x0d08 | W    | 0x00000000  | Debug Instruction-0 Register |
| DMAC_DBGINST1 | 0x0d0c | W    | 0x00000000  | Debug Instruction-1 Register |
| DMAC_CR0      | 0x0e00 | W    | 0x001f3075  | Configuration Register 0     |
| DMAC_CR1      | 0x0e04 | W    | 0x000000b5  | Configuration Register 1     |
| DMAC_CR2      | 0x0e08 | W    | 0x00000000  | Configuration Register 2     |
| DMAC_CR3      | 0x0e0c | W    | 0x0000ffff  | Configuration Register 3     |
| DMAC_CR4      | 0x0e10 | W    | 0x000fffff  | Configuration Register 4     |
| DMAC_CRDn     | 0x0e14 | W    | 0x07ff7f73  | Configuration Register       |
| DMAC_WD       | 0x0e80 | W    | 0x00000000  | DMA Watchdog Register        |

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

### 10.4.2 Detail Register Description

#### DMAC\_DSR

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | RO   | 0x0         | reserved                                                                                                                                                 |
| 9     | RO   | 0x0         | dns<br>1'b0: DMA manager operates in the Secure state<br>1'b1: DMA manager operates in the Non-secure state                                              |
| 8:4   | RO   | 0x00        | wakeup_event<br>5'h0: event[0]<br>5'h1: event[1]<br>5'h2: event[2]<br>...<br>5'h1f: event[31]                                                            |
| 3:0   | RO   | 0x0         | dma_status<br>4'h0: Stopped<br>4'h1: Executing<br>4'h2: Cache miss<br>4'h3: Updating PC<br>4'h4: Waiting for event<br>4'hf: Faulting<br>Others: Reserved |

#### DMAC\_DPC

Address: Operational Base + offset (0x0004)

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

#### DMAC\_INTEN

Address: Operational Base + offset (0x0020)

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

**DMAC EVENT RIS**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | 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 |

**DMAC INTMIS**

Address: Operational Base + offset (0x0028)

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

**DMAC INTCLR**

Address: Operational Base + offset (0x002c)

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

**DMAC FSRD**

Address: Operational Base + offset (0x0030)

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

**DMAC FSRC**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                                                     |
| 7:0        | RO          | 0x00               | 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 state |

**DMAC FTRD**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                  |
| 30         | RO          | 0x0                | dbg_instr<br>Memory or from the debug interface.<br>1'b0: Instruction that generated an abort was read from system memory<br>1'b1: Instruction that generated an abort was read from the debug interface                                                                  |
| 29:17      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                  |
| 16         | RO          | 0x0                | 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          | 0x0                | mgr_evnt_err<br>1'b0: DMA manager has appropriate security to execute DMAWFE or DMASEV<br>1'b1: DMA manager thread in the Non-secure state attempted to execute either:<br>a. DMAWFE to wait for a secure event<br>b. DMASEV to create a secure event or secure interrupt |
| 4          | RO          | 0x0                | dmago_err<br>1'b0: DMA manager has appropriate security to execute DMAGO<br>1'b1: DMA manager thread in the Non-secure state attempted to execute DMAGO to create a DMA channel operating in the Secure state                                                             |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                  |
| 1          | RO          | 0x0                | operand_invalid<br>The configuration of the DMAC.<br>1'b0: Valid operand<br>1'b1: Invalid operand                                                                                                                                                                         |
| 0          | RW          | 0x0                | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction                                                                                                                                                                                                   |

**DMAC\_FTR0**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | lockup_err<br>1'b0: DMA channel has adequate resources<br>1'b1: DMA channel has locked-up because of insufficient resources<br>This fault is an imprecise abort.                                                                                                                                    |
| 30         | RO          | 0x0                | dbg_instr<br>Memory or from the debug interface.<br>1'b0: Instruction that generated an abort was read from system memory<br>1'b1: Instruction that generated an abort was read from the debug interface<br>This fault is an imprecise abort but the bit is only valid when a precise abort occurs. |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RO          | 0x0                | 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          | 0x0                | 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          | 0x0                | 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 complete<br>1'b1: Previous DMALDs have not put enough data in the MFIFO to enable the DMAST to complete<br>This fault is a precise abort.                                                                                                                                                                                                                          |
| 12         | RO          | 0x0                | 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 DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7          | RO          | 0x0                | 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 violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6          | RO          | 0x0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security permissions.<br>1'b0: a DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: a DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFP to wait for a secure peripheral<br>b. DMALDP or DMASTP to notify a secure peripheral<br>c. DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RO          | 0x0                | ch_event_err<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFE to wait for a secure event<br>b. DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort. |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                            |
| 1          | RO          | 0x0                | 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.                                                                                                                                                                                       |
| 0          | RO          | 0x0                | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort.                                                                                                                                                                                                                           |

**DMAC FTR1**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | lockup_err<br>1'b0: DMA channel has adequate resources<br>1'b1: DMA channel has locked-up because of insufficient resources<br>This fault is an imprecise abort.                                                                                                                                    |
| 30         | RO          | 0x0                | dbg_instr<br>Memory or from the debug interface.<br>1'b0: Instruction that generated an abort was read from system memory<br>1'b1: Instruction that generated an abort was read from the debug interface<br>This fault is an imprecise abort but the bit is only valid when a precise abort occurs. |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                            |
| 18         | RO          | 0x0                | 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          | 0x0                | 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          | 0x0                | 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                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RO          | 0x0                | st_data_unavailable<br>1'b0: MFIFO contains all the data to enable the DMAST to complete<br>1'b1: Previous DMALDs have not put enough data in the MFIFO to enable the DMAST to complete<br>This fault is a precise abort.                                                                                                                                                                                                                          |
| 12         | RO          | 0x0                | 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 DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7          | RO          | 0x0                | 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 violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6          | RO          | 0x0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security permissions.<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFP to wait for a secure peripheral<br>b. DMALDP or DMASTP to notify a secure peripheral<br>c. DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5          | RO          | 0x0                | ch_event_err<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFE to wait for a secure event<br>b. DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1          | RO          | 0x0                | 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.                                                                                                                                                                                                                                                                                                      |
| 0          | RO          | 0x0                | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                                                          |

**DMAC FTR2**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | lockup_err<br>1'b0: DMA channel has adequate resources<br>1'b1: DMA channel has locked-up because of insufficient resources<br>This fault is an imprecise abort.                                                                                                                                    |
| 30         | RO          | 0x0                | dbg_instr<br>Memory or from the debug interface.<br>1'b0: Instruction that generated an abort was read from system memory<br>1'b1: Instruction that generated an abort was read from the debug interface<br>This fault is an imprecise abort but the bit is only valid when a precise abort occurs. |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                            |
| 18         | RO          | 0x0                | 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          | 0x0                | 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          | 0x0                | 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 complete<br>1'b1: Previous DMALDs have not put enough data in the MFIFO to enable the DMAST to complete<br>This fault is a precise abort.                                                                           |
| 12         | RO          | 0x0                | 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 DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to complete<br>This fault is an imprecise abort.           |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                            |
| 7          | RO          | 0x0                | 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 violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to perform a secure read or secure write<br>This fault is a precise abort. |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | RO   | 0x0         | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security permissions.<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFP to wait for a secure peripheral<br>b. DMALDP or DMASTP to notify a secure peripheral<br>c. DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5   | RO   | 0x0         | ch_event_err<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFE to wait for a secure event<br>b. DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                |
| 4:2 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1   | RO   | 0x0         | 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.                                                                                                                                                                                                                                                                                                      |
| 0   | RO   | 0x0         | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                                                          |

**DMAC FTR3**

Address: Operational Base + offset (0x004c)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RO   | 0x0         | lockup_err<br>1'b0: DMA channel has adequate resources<br>1'b1: DMA channel has locked-up because of insufficient resources<br>This fault is an imprecise abort.                                                                                                                                    |
| 30    | RO   | 0x0         | dbg_instr<br>Memory or from the debug interface.<br>1'b0: Instruction that generated an abort was read from system memory<br>1'b1: Instruction that generated an abort was read from the debug interface<br>This fault is an imprecise abort but the bit is only valid when a precise abort occurs. |
| 29:19 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                            |
| 18    | RO   | 0x0         | 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.                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17         | RO          | 0x0                | 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          | 0x0                | 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 complete<br>1'b1: Previous DMALDs have not put enough data in the MFIFO to enable the DMAST to complete<br>This fault is a precise abort.                                                                                                                                                                                                                          |
| 12         | RO          | 0x0                | 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 DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7          | RO          | 0x0                | 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 violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6          | RO          | 0x0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security permissions.<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFP to wait for a secure peripheral<br>b. DMALDP or DMASTP to notify a secure peripheral<br>c. DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5          | RO          | 0x0                | ch_event_err<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFE to wait for a secure event<br>b. DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | 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. |
| 0          | RO          | 0x0                | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort.                                     |

**DMAC FTR4**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | lockup_err<br>1'b0: DMA channel has adequate resources<br>1'b1: DMA channel has locked-up because of insufficient resources<br>This fault is an imprecise abort.                                                                                                                                    |
| 30         | RO          | 0x0                | dbg_instr<br>Memory or from the debug interface.<br>1'b0: Instruction that generated an abort was read from system memory<br>1'b1: Instruction that generated an abort was read from the debug interface<br>This fault is an imprecise abort but the bit is only valid when a precise abort occurs. |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                            |
| 18         | RO          | 0x0                | 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          | 0x0                | 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          | 0x0                | 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 complete<br>1'b1: Previous DMALDs have not put enough data in the MFIFO to enable the DMAST to complete<br>This fault is a precise abort.                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RO          | 0x0                | 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 complete<br>This fault is an imprecise abort.                                                                                                                                                       |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7          | RO          | 0x0                | 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 violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6          | RO          | 0x0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security permissions.<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFP to wait for a secure peripheral<br>b. DMALDP or DMASTP to notify a secure peripheral<br>c. DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5          | RO          | 0x0                | ch_event_err<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFE to wait for a secure event<br>b. DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1          | RO          | 0x0                | 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.                                                                                                                                                                                                                                                                                                      |
| 0          | RO          | 0x0                | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                                                          |

**DMAC\_FTR5**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | lockup_err<br>1'b0: DMA channel has adequate resources<br>1'b1: DMA channel has locked-up because of insufficient resources<br>This fault is an imprecise abort. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30         | RO          | 0x0                | dbg_instr<br>Memory or from the debug interface.<br>1'b0: Instruction that generated an abort was read from system memory<br>1'b1: Instruction that generated an abort was read from the debug interface<br>This fault is an imprecise abort but the bit is only valid when a precise abort occurs. |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                            |
| 18         | RO          | 0x0                | 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          | 0x0                | 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          | 0x0                | 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 complete<br>1'b1: Previous DMALDs have not put enough data in the MFIFO to enable the DMAST to complete<br>This fault is a precise abort.                                                                           |
| 12         | RO          | 0x0                | 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 DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to complete<br>This fault is an imprecise abort.           |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                            |
| 7          | RO          | 0x0                | 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 violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to perform a secure read or secure write<br>This fault is a precise abort. |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | RO   | 0x0         | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security permissions.<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFP to wait for a secure peripheral<br>b. DMALDP or DMASTP to notify a secure peripheral<br>c. DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5   | RO   | 0x0         | ch_event_err<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFE to wait for a secure event<br>b. DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                |
| 4:2 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1   | RO   | 0x0         | 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.                                                                                                                                                                                                                                                                                                      |
| 0   | RO   | 0x0         | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                                                          |

**DMAC FTR6**

Address: Operational Base + offset (0x0058)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RO   | 0x0         | lockup_err<br>1'b0: DMA channel has adequate resources<br>1'b1: DMA channel has locked-up because of insufficient resources<br>This fault is an imprecise abort.                                                                                                                                    |
| 30    | RO   | 0x0         | dbg_instr<br>Memory or from the debug interface.<br>1'b0: Instruction that generated an abort was read from system memory<br>1'b1: Instruction that generated an abort was read from the debug interface<br>This fault is an imprecise abort but the bit is only valid when a precise abort occurs. |
| 29:19 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                            |
| 18    | RO   | 0x0         | 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   | 0x0         | 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.                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RO          | 0x0                | 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 complete<br>1'b1: Previous DMALDs have not put enough data in the MFIFO to enable the DMAST to complete<br>This fault is a precise abort.                                                                                                                                                                                                                          |
| 12         | RO          | 0x0                | 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 DMAST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMAST to complete<br>This fault is an imprecise abort.                                                                                                                                                          |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7          | RO          | 0x0                | 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 violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6          | RO          | 0x0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security permissions.<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFP to wait for a secure peripheral<br>b. DMALDP or DMASTP to notify a secure peripheral<br>c. DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5          | RO          | 0x0                | ch_event_err<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFE to wait for a secure event<br>b. DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1          | RO          | 0x0                | 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.                                                                                                                                                                                                                                                                                                      |

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

**DMAC\_FTR7**

Address: Operational Base + offset (0x005c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | lockup_err<br>1'b0: DMA channel has adequate resources<br>1'b1: DMA channel has locked-up because of insufficient resources<br>This fault is an imprecise abort.                                                                                                                                    |
| 30         | RO          | 0x0                | dbg_instr<br>Memory or from the debug interface.<br>1'b0: Instruction that generated an abort was read from system memory<br>1'b1: Instruction that generated an abort was read from the debug interface<br>This fault is an imprecise abort but the bit is only valid when a precise abort occurs. |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                            |
| 18         | RO          | 0x0                | 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          | 0x0                | 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          | 0x0                | 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 complete<br>1'b1: Previous DMALDs have not put enough data in the MFIFO to enable the DMAST to complete<br>This fault is a precise abort.                                                                           |
| 12         | RO          | 0x0                | mfifo_err<br>DMA LD<br>1'b0: MFIFO contains sufficient space<br>1'b1: MFIFO is too small to hold the data that DMALD requires DMA ST<br>1'b0: MFIFO contains sufficient data<br>1'b1: MFIFO is too small to store the data to enable DMA ST to complete<br>This fault is an imprecise abort.        |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RO          | 0x0                | 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 violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to perform a secure read or secure write<br>This fault is a precise abort.                                                                                                                                                |
| 6          | RO          | 0x0                | ch_periph_err<br>DMASTP, or DMAFLUSHP with inappropriate security permissions.<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFP to wait for a secure peripheral<br>b. DMALDP or DMASTP to notify a secure peripheral<br>c. DMAFLUSHP to flush a secure peripheral<br>This fault is a precise abort. |
| 5          | RO          | 0x0                | ch_event_err<br>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions<br>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:<br>a. DMAWFE to wait for a secure event<br>b. DMASEV to create a secure event or secure interrupt<br>This fault is a precise abort.                                                                                                                |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1          | RO          | 0x0                | 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.                                                                                                                                                                                                                                                                                                      |
| 0          | RO          | 0x0                | undef_instr<br>1'b0: Defined instruction<br>1'b1: Undefined instruction<br>This fault is a precise abort.                                                                                                                                                                                                                                                                                                                                          |

**DMAC CSR0**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:4        | RO          | 0x00               | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for.<br>5'h0: DMA channel is waiting for event, or peripheral, 0<br>5'h1: DMA channel is waiting for event, or peripheral, 1<br>5'h2: DMA channel is waiting for event, or peripheral, 2<br>...<br>5'h1f: DMA channel is waiting for event, or peripheral, 31 |
| 3:0        | RO          | 0x0                | channel_status<br>Channel 0 status.<br>4'h0: Stopped<br>4'h1: Executing<br>4'h2: Cache miss<br>4'h3: Updating PC<br>4'h4: Waiting for event<br>4'h5: At barrier<br>4'h7: Waiting for peripheral<br>4'h8: Killing<br>4'h9: Completing<br>4'he: Faulting completing<br>4'hf: Faulting<br>Others: Reserved                                            |

**DMAC CPC0**

Address: Operational Base + offset (0x0104)

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

**DMAC CSR1**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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               | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for.<br>5'h0: DMA channel is waiting for event, or peripheral, 0<br>5'h1: DMA channel is waiting for event, or peripheral, 1<br>5'h2: DMA channel is waiting for event, or peripheral, 2<br>...<br>5'h1f: DMA channel is waiting for event, or peripheral, 31 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RO          | 0x0                | channel_status<br>Channel 1 status.<br>4'h0: Stopped<br>4'h1: Executing<br>4'h2: Cache miss<br>4'h3: Updating PC<br>4'h4: Waiting for event<br>4'h5: At barrier<br>4'h7: Waiting for peripheral<br>4'h8: Killing<br>4'h9: Completing<br>4'he: Faulting completing<br>4'hf: Faulting<br>Others: Reserved |

**DMAC CPC1**

Address: Operational Base + offset (0x010c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pc_chnl<br>Program counter for the DMA channel 1 thread |

**DMAC CSR2**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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               | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for.<br>5'h0: DMA channel is waiting for event, or peripheral, 0<br>5'h1: DMA channel is waiting for event, or peripheral, 1<br>5'h2: DMA channel is waiting for event, or peripheral, 2<br>...<br>5'h1f: DMA channel is waiting for event, or peripheral, 31 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RO          | 0x0                | channel_status<br>Channel 2 status.<br>4'h0: Stopped<br>4'h1: Executing<br>4'h2: Cache miss<br>4'h3: Updating PC<br>4'h4: Waiting for event<br>4'h5: At barrier<br>4'h7: Waiting for peripheral<br>4'h8: Killing<br>4'h9: Completing<br>4'he: Faulting completing<br>4'hf: Faulting<br>Others: Reserved |

**DMAC CPC2**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pc_chnl<br>Program counter for the DMA channel 2 thread |

**DMAC CSR3**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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               | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for.<br>5'h0: DMA channel is waiting for event, or peripheral, 0<br>5'h1: DMA channel is waiting for event, or peripheral, 1<br>5'h2: DMA channel is waiting for event, or peripheral, 2<br>...<br>5'h1f: DMA channel is waiting for event, or peripheral, 31 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RO          | 0x0                | channel_status<br>Channel 3 status.<br>4'h0: Stopped<br>4'h1: Executing<br>4'h2: Cache miss<br>4'h3: Updating PC<br>4'h4: Waiting for event<br>4'h5: At barrier<br>4'h7: Waiting for peripheral<br>4'h8: Killing<br>4'h9: Completing<br>4'he: Faulting completing<br>4'hf: Faulting<br>Others: Reserved |

**DMAC CPC3**

Address: Operational Base + offset (0x011c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pc_chnl<br>Program counter for the DMA channel 3 thread |

**DMAC CSR4**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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               | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for.<br>5'h0: DMA channel is waiting for event, or peripheral, 0<br>5'h1: DMA channel is waiting for event, or peripheral, 1<br>5'h2: DMA channel is waiting for event, or peripheral, 2<br>...<br>5'h1f: DMA channel is waiting for event, or peripheral, 31 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RO          | 0x0                | channel_status<br>Channel 4 status.<br>4'h0: Stopped<br>4'h1: Executing<br>4'h2: Cache miss<br>4'h3: Updating PC<br>4'h4: Waiting for event<br>4'h5: At barrier<br>4'h7: Waiting for peripheral<br>4'h8: Killing<br>4'h9: Completing<br>4'he: Faulting completing<br>4'hf: Faulting<br>Others: Reserved |

**DMAC CPC4**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pc_chnl<br>Program counter for the DMA channel 4 thread |

**DMAC CSR5**

Address: Operational Base + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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               | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for.<br>5'h0: DMA channel is waiting for event, or peripheral, 0<br>5'h1: DMA channel is waiting for event, or peripheral, 1<br>5'h2: DMA channel is waiting for event, or peripheral, 2<br>...<br>5'h1f: DMA channel is waiting for event, or peripheral, 31 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RO          | 0x0                | channel_status<br>Channel 5 status.<br>4'h0: Stopped<br>4'h1: Executing<br>4'h2: Cache miss<br>4'h3: Updating PC<br>4'h4: Waiting for event<br>4'h5: At barrier<br>4'h7: Waiting for peripheral<br>4'h8: Killing<br>4'h9: Completing<br>4'he: Faulting completing<br>4'hf: Faulting<br>Others: Reserved |

**DMAC CPC5**

Address: Operational Base + offset (0x012c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pc_chnl<br>Program counter for the DMA channel 5 thread |

**DMAC CSR6**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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               | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for.<br>5'h0: DMA channel is waiting for event, or peripheral, 0<br>5'h1: DMA channel is waiting for event, or peripheral, 1<br>5'h2: DMA channel is waiting for event, or peripheral, 2<br>...<br>5'h1f: DMA channel is waiting for event, or peripheral, 31 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RO          | 0x0                | channel_status<br>Channel 6 status.<br>4'h0: Stopped<br>4'h1: Executing<br>4'h2: Cache miss<br>4'h3: Updating PC<br>4'h4: Waiting for event<br>4'h5: At barrier<br>4'h7: Waiting for peripheral<br>4'h8: Killing<br>4'h9: Completing<br>4'he: Faulting completing<br>4'hf: Faulting<br>Others: Reserved |

**DMAC CPC6**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pc_chnl<br>Program counter for the DMA channel 6 thread |

**DMAC CSR7**

Address: Operational Base + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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               | wakeup_number<br>Indicate the event or peripheral number that the channel is waiting for.<br>5'h0: DMA channel is waiting for event, or peripheral, 0<br>5'h1: DMA channel is waiting for event, or peripheral, 1<br>5'h2: DMA channel is waiting for event, or peripheral, 2<br>...<br>5'h1f: DMA channel is waiting for event, or peripheral, 31 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RO          | 0x0                | channel_status<br>Channel 7 status.<br>4'h0: Stopped<br>4'h1: Executing<br>4'h2: Cache miss<br>4'h3: Updating PC<br>4'h4: Waiting for event<br>4'h5: At barrier<br>4'h7: Waiting for peripheral<br>4'h8: Killing<br>4'h9: Completing<br>4'he: Faulting completing<br>4'hf: Faulting<br>Others: Reserved |

**DMAC CPC7**

Address: Operational Base + offset (0x013c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pc_chnl<br>Program counter for the DMA channel 7 thread |

**DMAC SAR0**

Address: Operational Base + offset (0x0400)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | src_addr<br>Address of the source data for DMA channel 0 |

**DMAC DAR0**

Address: Operational Base + offset (0x0404)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dst_addr<br>Address of the Destination data for DMA channel 0 |

**DMAC CCR0**

Address: Operational Base + offset (0x0408)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                |
| 27:25      | RO          | 0x0                | 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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                                    |
| 21:18      | RO          | 0x0                | dst_burst_len<br>the destination data:<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>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.                                                   |
| 17:15      | RO          | 0x0                | dst_burst_size<br>3'h0: Writes 1 byte per beat<br>3'h1: Writes 2 bytes per beat<br>3'h2: Writes 4 bytes per beat<br>3'h3: Writes 8 bytes per beat<br>3'h4: Writes 16 bytes per beat<br>Others: Reserved<br>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. |
| 14         | RO          | 0x0                | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.                                                                                                                                                                                                                       |
| 13:11      | RO          | 0x0                | 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          | 0x0                | 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                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RO          | 0x0                | <p>src_burst_len<br/>4'h0: 1 data transfer<br/>4'h1: 2 data transfers<br/>4'h2: 3 data transfers<br/>...<br/>4'hf: 16 data transfers</p> <p>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.</p>                                                                        |
| 3:1        | RO          | 0x0                | <p>src_burst_size<br/>3'h0: Reads 1 byte per beat<br/>3'h1: Reads 2 bytes per beat<br/>3'h2: Reads 4 bytes per beat<br/>3'h3: Reads 8 bytes per beat<br/>3'h4: Reads 16 bytes per beat<br/>Others: Reserved</p> <p>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.</p> |
| 0          | RO          | 0x0                | <p>src_inc<br/>1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.<br/>1'b1: Incrementing-address burst. The DMAC signals ARBURST[0] HIGH.</p>                                                                                                                                                                                                                        |

**DMAC LC0\_0**

Address: Operational Base + offset (0x040c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

**DMAC LC1\_0**

Address: Operational Base + offset (0x0410)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 1 iterations |

**DMAC SAR1**

Address: Operational Base + offset (0x0420)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | src_addr<br>Address of the source data for DMA channel 1 |

**DMAC DAR1**

Address: Operational Base + offset (0x0424)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dst_addr<br>Address of the Destination data for DMA channel 1 |

**DMAC CCR1**

Address: Operational Base + offset (0x0428)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:25      | RO          | 0x0                | 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                                                                                                                                                    |
| 21:18      | RO          | 0x0                | dst_burst_len<br>the destination data:<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>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.                                                   |
| 17:15      | RO          | 0x0                | dst_burst_size<br>3'h0: Writes 1 byte per beat<br>3'h1: Writes 2 bytes per beat<br>3'h2: Writes 4 bytes per beat<br>3'h3: Writes 8 bytes per beat<br>3'h4: Writes 16 bytes per beat<br>Others: Reserved<br>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. |
| 14         | RO          | 0x0                | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.                                                                                                                                                                                                                       |
| 13:11      | RO          | 0x0                | 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                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RO          | 0x0                | 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          | 0x0                | src_burst_len<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.                                                                       |
| 3:1        | RO          | 0x0                | src_burst_size<br>3'h0: Reads 1 byte per beat<br>3'h1: Reads 2 bytes per beat<br>3'h2: Reads 4 bytes per beat<br>3'h3: Reads 8 bytes per beat<br>3'h4: Reads 16 bytes per beat<br>Others: Reserved<br>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of 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 ARBURST[0] HIGH.                                                                                                                                                                                                                |

**DMAC LC0\_1**

Address: Operational Base + offset (0x042c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

**DMAC LC1\_1**

Address: Operational Base + offset (0x0430)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 1 iterations |

**DMAC SAR2**

Address: Operational Base + offset (0x0440)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | src_addr<br>Address of the source data for DMA channel 2 |

**DMAC DAR2**

Address: Operational Base + offset (0x0444)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dst_addr<br>Address of the Destination data for DMA channel 2 |

**DMAC CCR2**

Address: Operational Base + offset (0x0448)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                            |
| 27:25      | RO          | 0x0                | 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                                                                                                                                                    |
| 21:18      | RO          | 0x0                | dst_burst_len<br>the destination data:<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>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.                                                   |
| 17:15      | RO          | 0x0                | dst_burst_size<br>3'h0: Writes 1 byte per beat<br>3'h1: Writes 2 bytes per beat<br>3'h2: Writes 4 bytes per beat<br>3'h3: Writes 8 bytes per beat<br>3'h4: Writes 16 bytes per beat<br>Others: Reserved<br>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. |
| 14         | RO          | 0x0                | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:11      | RO          | 0x0                | 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          | 0x0                | 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          | 0x0                | src_burst_len<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.                                                                       |
| 3:1        | RO          | 0x0                | src_burst_size<br>3'h0: Reads 1 byte per beat<br>3'h1: Reads 2 bytes per beat<br>3'h2: Reads 4 bytes per beat<br>3'h3: Reads 8 bytes per beat<br>3'h4: Reads 16 bytes per beat<br>Others: Reserved<br>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of 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 ARBURST[0] HIGH.                                                                                                                                                                                                                |

**DMAC LC0\_2**

Address: Operational Base + offset (0x044c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

**DMAC LC1\_2**

Address: Operational Base + offset (0x0450)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 1 iterations |

**DMAC SAR3**

Address: Operational Base + offset (0x0460)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | src_addr<br>Address of the source data for DMA channel 3 |

**DMAC DAR3**

Address: Operational Base + offset (0x0464)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dst_addr<br>Address of the Destination data for DMA channel 3 |

**DMAC CCR3**

Address: Operational Base + offset (0x0468)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                          |
| 27:25      | RO          | 0x0                | 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                                                                                                  |
| 21:18      | RO          | 0x0                | dst_burst_len<br>the destination data:<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>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. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:15      | RO          | 0x0                | <p>dst_burst_size<br/>           3'h0: Writes 1 byte per beat<br/>           3'h1: Writes 2 bytes per beat<br/>           3'h2: Writes 4 bytes per beat<br/>           3'h3: Writes 8 bytes per beat<br/>           3'h4: Writes 16 bytes per beat<br/>           Others: Reserved<br/>           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.</p> |
| 14         | RO          | 0x0                | <p>dst_inc<br/>           1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br/>           1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.</p>                                                                                                                                                                                                                                                                                   |
| 13:11      | RO          | 0x0                | <p>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</p>                                                                                                                     |
| 10:8       | RO          | 0x0                | <p>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</p>                                                                                                                              |
| 7:4        | RO          | 0x0                | <p>src_burst_len<br/>           4'h0: 1 data transfer<br/>           4'h1: 2 data transfers<br/>           4'h2: 3 data transfers<br/>           ...<br/>           4'hf: 16 data transfers<br/>           The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.</p>                                                                                          |
| 3:1        | RO          | 0x0                | <p>src_burst_size<br/>           3'h0: Reads 1 byte per beat<br/>           3'h1: Reads 2 bytes per beat<br/>           3'h2: Reads 4 bytes per beat<br/>           3'h3: Reads 8 bytes per beat<br/>           3'h4: Reads 16 bytes per beat<br/>           Others: Reserved<br/>           The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.</p>        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 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 ARBURST[0] HIGH. |

**DMAC LC0\_3**

Address: Operational Base + offset (0x046c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

**DMAC LC1\_3**

Address: Operational Base + offset (0x0470)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 1 iterations |

**DMAC SAR4**

Address: Operational Base + offset (0x0480)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | src_addr<br>Address of the source data for DMA channel 4 |

**DMAC DAR4**

Address: Operational Base + offset (0x0484)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dst_addr<br>Address of the Destination data for DMA channel 4 |

**DMAC CCR4**

Address: Operational Base + offset (0x0488)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                |
| 27:25      | RO          | 0x0                | 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        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:18      | RO          | 0x0                | <p>dst_burst_len<br/>the destination data:<br/>4'h0: 1 data transfer<br/>4'h1: 2 data transfers<br/>4'h2: 3 data transfers<br/>...<br/>4'hf: 16 data transfers</p> <p>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.</p>                                                   |
| 17:15      | RO          | 0x0                | <p>dst_burst_size<br/>3'h0: Writes 1 byte per beat<br/>3'h1: Writes 2 bytes per beat<br/>3'h2: Writes 4 bytes per beat<br/>3'h3: Writes 8 bytes per beat<br/>3'h4: Writes 16 bytes per beat<br/>Others: Reserved</p> <p>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.</p> |
| 14         | RO          | 0x0                | <p>dst_inc<br/>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br/>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.</p>                                                                                                                                                                                                                               |
| 13:11      | RO          | 0x0                | <p>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</p>                                                                                                                                              |
| 10:8       | RO          | 0x0                | <p>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</p>                                                                                                                                                       |
| 7:4        | RO          | 0x0                | <p>src_burst_len<br/>4'h0: 1 data transfer<br/>4'h1: 2 data transfers<br/>4'h2: 3 data transfers<br/>...<br/>4'hf: 16 data transfers</p> <p>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.</p>                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1        | RO          | 0x0                | <p>src_burst_size<br/>           3'h0: Reads 1 byte per beat<br/>           3'h1: Reads 2 bytes per beat<br/>           3'h2: Reads 4 bytes per beat<br/>           3'h3: Reads 8 bytes per beat<br/>           3'h4: Reads 16 bytes per beat<br/>           Others: Reserved</p> <p>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.</p> |
| 0          | RO          | 0x0                | <p>src_inc<br/>           1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.<br/>           1'b1: Incrementing-address burst. The DMAC signals ARBURST[0] HIGH.</p>                                                                                                                                                                                                                                                                    |

**DMAC LC0\_4**

Address: Operational Base + offset (0x048c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                |
| 7:0        | RO          | 0x00               | <p>loop_counter_iterations<br/>           Loop counter 0 iterations</p> |

**DMAC LC1\_4**

Address: Operational Base + offset (0x0490)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                |
| 7:0        | RO          | 0x00               | <p>loop_counter_iterations<br/>           Loop counter 1 iterations</p> |

**DMAC SAR5**

Address: Operational Base + offset (0x04a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>src_addr<br/>           Address of the source data for DMA channel 5</p> |

**DMAC DAR5**

Address: Operational Base + offset (0x04a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>dst_addr<br/>           Address of the Destination data for DMA channel 5</p> |

**DMAC CCR5**

Address: Operational Base + offset (0x04a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                   |
| 27:25      | RO          | 0x0                | <p>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</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                                    |
| 21:18      | RO          | 0x0                | dst_burst_len<br>the destination data:<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>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.                                                   |
| 17:15      | RO          | 0x0                | dst_burst_size<br>3'h0: Writes 1 byte per beat<br>3'h1: Writes 2 bytes per beat<br>3'h2: Writes 4 bytes per beat<br>3'h3: Writes 8 bytes per beat<br>3'h4: Writes 16 bytes per beat<br>Others: Reserved<br>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. |
| 14         | RO          | 0x0                | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.                                                                                                                                                                                                                       |
| 13:11      | RO          | 0x0                | 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          | 0x0                | 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                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RO          | 0x0                | <p>src_burst_len<br/>4'h0: 1 data transfer<br/>4'h1: 2 data transfers<br/>4'h2: 3 data transfers<br/>...<br/>4'hf: 16 data transfers</p> <p>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.</p>                                                                        |
| 3:1        | RO          | 0x0                | <p>src_burst_size<br/>3'h0: Reads 1 byte per beat<br/>3'h1: Reads 2 bytes per beat<br/>3'h2: Reads 4 bytes per beat<br/>3'h3: Reads 8 bytes per beat<br/>3'h4: Reads 16 bytes per beat<br/>Others: Reserved</p> <p>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.</p> |
| 0          | RO          | 0x0                | <p>src_inc<br/>1'b0: Fixed-address burst. The DMAC signals ARBURST[0] LOW.<br/>1'b1: Incrementing-address burst. The DMAC signals ARBURST[0] HIGH.</p>                                                                                                                                                                                                                        |

**DMAC LC0\_5**

Address: Operational Base + offset (0x04ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

**DMAC LC1\_5**

Address: Operational Base + offset (0x04b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 1 iterations |

**DMAC SAR6**

Address: Operational Base + offset (0x04c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | src_addr<br>Address of the source data for DMA channel 6 |

**DMAC DAR6**

Address: Operational Base + offset (0x04c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dst_addr<br>Address of the Destination data for DMA channel 6 |

**DMAC CCR6**

Address: Operational Base + offset (0x04c8)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:25      | RO          | 0x0                | 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                                                                                                                                                    |
| 21:18      | RO          | 0x0                | dst_burst_len<br>the destination data:<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>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.                                                   |
| 17:15      | RO          | 0x0                | dst_burst_size<br>3'h0: Writes 1 byte per beat<br>3'h1: Writes 2 bytes per beat<br>3'h2: Writes 4 bytes per beat<br>3'h3: Writes 8 bytes per beat<br>3'h4: Writes 16 bytes per beat<br>Others: Reserved<br>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. |
| 14         | RO          | 0x0                | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.                                                                                                                                                                                                                       |
| 13:11      | RO          | 0x0                | 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                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RO          | 0x0                | 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          | 0x0                | src_burst_len<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.                                                                       |
| 3:1        | RO          | 0x0                | src_burst_size<br>3'h0: Reads 1 byte per beat<br>3'h1: Reads 2 bytes per beat<br>3'h2: Reads 4 bytes per beat<br>3'h3: Reads 8 bytes per beat<br>3'h4: Reads 16 bytes per beat<br>Others: Reserved<br>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of 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 ARBURST[0] HIGH.                                                                                                                                                                                                                |

**DMAC LC0 6**

Address: Operational Base + offset (0x04cc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

**DMAC LC1 6**

Address: Operational Base + offset (0x04d0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 1 iterations |

**DMAC SAR7**

Address: Operational Base + offset (0x04e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | src_addr<br>Address of the source data for DMA channel 7 |

**DMAC DAR7**

Address: Operational Base + offset (0x04e4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | dst_addr<br>Address of the Destination data for DMA channel 7 |

**DMAC CCR7**

Address: Operational Base + offset (0x04e8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                            |
| 27:25      | RO          | 0x0                | 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                                                                                                                                                    |
| 21:18      | RO          | 0x0                | dst_burst_len<br>the destination data:<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>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.                                                   |
| 17:15      | RO          | 0x0                | dst_burst_size<br>3'h0: Writes 1 byte per beat<br>3'h1: Writes 2 bytes per beat<br>3'h2: Writes 4 bytes per beat<br>3'h3: Writes 8 bytes per beat<br>3'h4: Writes 16 bytes per beat<br>Others: Reserved<br>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. |
| 14         | RO          | 0x0                | dst_inc<br>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:11      | RO          | 0x0                | 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          | 0x0                | 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          | 0x0                | src_burst_len<br>4'h0: 1 data transfer<br>4'h1: 2 data transfers<br>4'h2: 3 data transfers<br>...<br>4'hf: 16 data transfers<br>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of src_burst_len and src_burst_size.                                                                       |
| 3:1        | RO          | 0x0                | src_burst_size<br>3'h0: Reads 1 byte per beat<br>3'h1: Reads 2 bytes per beat<br>3'h2: Reads 4 bytes per beat<br>3'h3: Reads 8 bytes per beat<br>3'h4: Reads 16 bytes per beat<br>Others: Reserved<br>The total number of bytes that the DMAC reads into the MFIFO when it executes a DMA LD instruction is the product of 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 ARBURST[0] HIGH.                                                                                                                                                                                                                |

**DMAC LC0** **7**

Address: Operational Base + offset (0x04ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 0 iterations |

**DMAC LC1** **7**

Address: Operational Base + offset (0x04f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                             |
| 7:0        | RO          | 0x00               | loop_counter_iterations<br>Loop counter 1 iterations |

**DMAC\_DBGSTATUS**

Address: Operational Base + offset (0x0d00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:1       | RO          | 0x0                | reserved                              |
| 0          | RO          | 0x0                | dbgstatus<br>1'b0: Idle<br>1'b1: Busy |

**DMAC\_DBGCMD**

Address: Operational Base + offset (0x0d04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x0                | reserved                                                                                                   |
| 1:0        | WO          | 0x0                | dbgcmd<br>2'b00: Execute the instruction that the DMAC_DBGINST [1:0] Registers contain<br>Others: Reserved |

**DMAC\_DBGINST0**

Address: Operational Base + offset (0x0d08)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:24      | WO          | 0x00               | instruction_byte1<br>Instruction byte 1                                                                                   |
| 23:16      | WO          | 0x00               | instruction_byte0<br>Instruction byte 0                                                                                   |
| 15:11      | RO          | 0x0                | reserved                                                                                                                  |
| 10:8       | WO          | 0x0                | channel_number<br>3'b000: DMA channel 0<br>3'b001: DMA channel 1<br>3'b010: DMA channel 2<br>...<br>3'b111: DMA channel 7 |
| 7:1        | RO          | 0x0                | reserved                                                                                                                  |
| 0          | WO          | 0x0                | debug_thread<br>1'b0: DMA manager thread<br>1'b1: DMA channel                                                             |

**DMAC\_DBGINST1**

Address: Operational Base + offset (0x0d0c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:24      | WO          | 0x00               | instruction_byte5<br>Instruction byte 5 |
| 23:16      | WO          | 0x00               | instruction_byte4<br>Instruction byte 4 |
| 15:8       | WO          | 0x00               | instruction_byte3<br>Instruction byte 3 |
| 7:0        | WO          | 0x00               | instruction_byte2<br>Instruction byte 2 |

**DMAC\_CRO**

Address: Operational Base + offset (0x0e00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x0                | reserved                                                                                                                                                                                    |
| 21:17      | RO          | 0x0f               | num_events<br>5'h0: 1 interrupt output, irq[0]<br>5'h1: 2 interrupt outputs, irq[1:0]<br>5'h2: 3 interrupt outputs, irq[2:0]<br>...<br>5'h1f: 32 interrupt outputs, irq[31:0]               |
| 16:12      | RO          | 0x13               | num_periph_req<br>5'h0: 1 peripheral request interface<br>5'h1: 2 peripheral request interfaces<br>5'h2: 3 peripheral request interfaces<br>...<br>5'h1f: 32 peripheral request interfaces  |
| 11:7       | RO          | 0x0                | reserved                                                                                                                                                                                    |
| 6:4        | RO          | 0x7                | 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          | 0x1                | 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                | 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 interfaces that the num_periph_req field specifies |

**DMAC CR1**

Address: Operational Base + offset (0x0e04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0                | reserved                                                                                                                                 |
| 7:4        | RO          | 0xb                | 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          | 0x5                | i_cache_len<br>3'b010: 4 bytes<br>3'b011: 8 bytes<br>3'b100: 16 bytes<br>3'b101: 32 bytes<br>Others: Reserved                            |

**DMAC CR2**

Address: Operational Base + offset (0x0e08)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | boot_addr<br>Provides the value of boot_addr[31:0] when the DMAC exited from reset |

**DMAC CR3**

Address: Operational Base + offset (0x0e0c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x0000ffff         | 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 |

**DMAC CR4**

Address: Operational Base + offset (0x0e10)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x000fffff         | 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 state |

**DMAC CRDn**

Address: Operational Base + offset (0x0e14)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                               |
| 29:20      | RO          | 0x07f              | data_buffer_dep<br>10'b000000000: 1 line<br>10'b000000001: 2 lines<br>...<br>10'b111111111: 1024 lines |
| 19:16      | RO          | 0xf                | 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          | 0x7                | rd_cap<br>3'b000: 1<br>3'b001: 2<br>...<br>3'b111: 8                                                   |
| 11:8       | RO          | 0xf                | 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          | 0x7                | wr_cap<br>3'b000: 1<br>3'b001: 2<br>...<br>3'b111: 8                                                   |
| 3          | RO          | 0x0                | reserved                                                                                               |

| Bit | Attr | Reset Value | Description                                                                          |
|-----|------|-------------|--------------------------------------------------------------------------------------|
| 2:0 | RO   | 0x3         | data_width<br>3'b010: 32-bit<br>3'b011: 64-bit<br>3'b100: 128-bit<br>Others:Reserved |

**DMAC WD**

Address: Operational Base + offset (0x0e80)

| Bit  | Attr | Reset Value | Description                                                                                                                             |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x0         | reserved                                                                                                                                |
| 0    | RW   | 0x0         | wd_irq_only<br>1'b0: The DMAC aborts all of the contributing DMA channels and sets irq_abort HIGH<br>1'b1: The DMAC sets irq_abort HIGH |

## 10.5 Timing Diagram

Following picture shows the relationship between dma\_req and dma\_ack.



Fig. 10-3 DMAC Request and Acknowledge Timing

## 10.6 Application Notes

### 10.6.1 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 DMAC\_DBGSTATUS Register to ensure that debug is idle, that is, the dbgstatus bit is 0.
4. Write to the DMAC\_DBGINST0 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 DMAC\_DBGCMD Register. The DMAC starts the DMA channel thread and sets the dbgstatus bit to 1.

### 10.6.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 DMAC\_FSRD Register, see Fault Status DMA Manager
3. Sets the dmago\_err bit in the DMAC\_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 DMAC\_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 DMAC\_FSRD Register, see Fault Status DMA Manager Register.
3. Sets the mgr\_evnt\_err bit in the DMAC\_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 DMAC\_FSRD Register, see Fault Status DMA Manager Register.
3. Sets the mgr\_evnt\_err bit in the DMAC\_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 DMAC\_CR3 Register.

**DMASEV**

The DMAC creates the event-interrupt, irrespective of the security state of the corresponding INS bit, in the DMAC\_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 DMAC\_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 DMAC\_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 DMAC\_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 DMAC\_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 DMAC\_FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_evnt\_err bit in the DMAC\_FTRn(n=0~7) 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 DMAC\_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 DMAC\_FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_evnt\_err bit in the DMAC\_FTRn(n=0~7) 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 DMAC\_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 DMAC\_FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_periph\_err bit in the DMAC\_FTRn(n=0~7) 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 DMAC\_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 DMAC\_FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_periph\_err bit in the DMAC\_FTRn(n=0~7) 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 DMAC\_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 DMAC\_FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_periph\_err bit in the DMAC\_FTRn(n=0~7) 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 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 DMAC\_FSRC Register that corresponds to the DMA channel number. See Fault Status DMA Channel Register.
3. Sets the ch\_rdwr\_err bit in the DMAC\_FTrn(n=0~7) Register, see Fault Type DMA Channel Registers.
4. Moves the DMA channel thread to the Faulting completing state.

### **10.6.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 DMAC\_CCRn(n=0~7) Register
- the DMAC\_SARn(n=0~7) 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 DMAC\_CCRn(n=0~7) Register
- the DMAC\_DARn(n=0~7) 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 DMAC\_CCRn(n=0~7) Register, to enable a DMA channel to perform an endian swap then you must set the corresponding DMAC\_SARn(n=0~7) Register and the corresponding DMAC\_DARn(n=0~7) 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 DMA LD and DMA ST instructions, the values you program in to the DMAC\_CCRn(n=0~7) Register, DMAC\_SARn(n=0~7) Register, and DMAC\_DARn(n=0~7) 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.

### **10.6.4 Unaligned Transfers**

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 split 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 split 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 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 10-2 Source Size in DMAC\_CCRn

| <b>Source size in<br/>DMAC_CCRn</b> | <b>Allowed offset between DMAC_SARn and<br/>DMAC_DARn</b> |
|-------------------------------------|-----------------------------------------------------------|
| SS8                                 | any offset allowed.                                       |
| SS16                                | 0,2,4,6,8,10,12,14                                        |
| SS32                                | 0,4,8,12                                                  |
| SS64                                | 0,8                                                       |

### 10.6.5 Interrupt Sharing between Channels

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

### 10.6.6 Instruction Sets

Table 10-3 DMAC Instruction Sets

| <b>Mnemonic</b> | <b>Instruction</b>          | <b>Thread Usage</b> |
|-----------------|-----------------------------|---------------------|
| DMAADDH         | Add Halfword                | C                   |
| DMAEND          | End                         | M/C                 |
| DMAFLUSHP       | Flush and notify Peripheral | C                   |
| DMAGO           | Go                          | M                   |
| DMAKILL         | Kill                        | C                   |
| DMALD           | Load                        | C                   |
| DMALDP          | Load Peripheral             | C                   |
| DMALP           | Loop                        | C                   |
| DMALPEND        | Loop End                    | C                   |
| DMALPFE         | Loop Forever                | C                   |
| DMAMOV          | Move                        | C                   |
| DMANOP          | No operation                | M/C                 |

|         |                             |     |
|---------|-----------------------------|-----|
| DMARMB  | Read Memory Barrier         | C   |
| DMASEV  | Send Event                  | M/C |
| DMAST   | Store                       | C   |
| DMASTP  | Store and notify Peripheral | C   |
| DMASTZ  | Store Zero                  | C   |
| DMAWFE  | Wait For Event M            | M/C |
| DMAWFP  | Wait For Peripheral         | C   |
| DMAWMB  | Write Memory Barrier        | C   |
| DMAADNH | Add Negative Halfword       | C   |

Notes: Thread usage: C=DMA channel, M=DMA manager

### 10.6.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 DMAC\_SARn(n=0~7) Register or DMAC\_DARn(n=0~7) 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 0xFFFFFFFF 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 10-4 DMAC Instruction Encoding

|           |          |   |   |   |   |   |   |    |   |
|-----------|----------|---|---|---|---|---|---|----|---|
| 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

DMAC\_SARn(n=0~7) Register and sets ra to 0.

DAR

DMAC\_DARn(n=0~7) 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, 0xFFFF causes the value 0xFFFFFFF0 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 11 Temperature-Sensor ADC (TS-ADC)

### 11.1 Overview

TS-ADC Controller is used to control and get the temperature information. TS-ADC will convert for each enabled channel in loop after the initial setting and can be stopped by software. If you find that the temperature is High in a period of time, an interrupt is generated to the processor down-measures taken; if the temperature over a period of time High, the resulting TSHUT gave CRU module, let it reset the entire chip, or via GPIO give PMIC. Also, if you find that the temperature Low in a period of time, an interrupt can be generated.

TS-ADC Controller supports the following features:

- The temperature for High and Low interrupt can be configurable
- The temperature of system reset can be configurable
- The time interval of temperature detection can be configurable
- When detecting a high temperature, the time interval of temperature detection can be configurable
- High temperature debounce can be configurable
- An interrupt can be generated after TS-ADC converts all setting channel
- -40~125°C temperature range and 0.6°C temperature resolution

### 11.2 Block Diagram

TS-ADC controller comprises with:

- APB Interface
- TS-ADC control logic



Fig. 11-1 TS-ADC Controller Block Diagram

### 11.3 Function Description

#### 11.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.

#### 11.3.2 TS-ADC Controller

This block is used to control the TS-ADC PHY to meet the conversion timing and receive the temperature information from TS-ADC PHY.

### 11.4 Register Description

#### 11.4.1 Registers Summary

| Name                        | Offset | Size | Reset Value | Description                                       |
|-----------------------------|--------|------|-------------|---------------------------------------------------|
| TSADC USER CON              | 0x0000 | W    | 0x00000000  | User control                                      |
| TSADC AUTO CON              | 0x0004 | W    | 0x00000000  | Auto control                                      |
| TSADC AUTO STATUS           | 0x0008 | W    | 0x00000000  | Status used in auto mode                          |
| TSADC AUTO SRC              | 0x000C | W    | 0x00000000  | Channel sel for tsadc in auto mode                |
| TSADC LT EN                 | 0x0010 | W    | 0x00000000  | Low temperature check logic enable                |
| TSADC HT INT EN             | 0x0014 | W    | 0x00000000  | High temperature interrupt enable                 |
| TSADC CRU EN                | 0x001C | W    | 0x00000000  | Temperature violation to cru enable               |
| TSADC LT INT EN             | 0x0020 | W    | 0x00000000  | Low temperature interrupt enable                  |
| TSADC HLT INT PD            | 0x0024 | W    | 0x00000000  | High and low temperature interrupt status         |
| TSADC EOC HSHUT PD          | 0x0028 | W    | 0x00000000  | High temperature shut and round int status        |
| TSADC DATA0                 | 0x002C | W    | 0x00000000  | Channel0 data                                     |
| TSADC COMPO INT             | 0x006C | W    | 0x00000000  | High temperature interrupt threshold for channel0 |
| TSADC COMPO SHUT            | 0x010C | W    | 0x00000000  | High temperature shut threshold for channel0      |
| TSADC HIGH INT DEBO UNCE    | 0x014C | W    | 0x00000003  | High interrupt debounce                           |
| TSADC HIGHT TSHUT D EBOUNCE | 0x0150 | W    | 0x00000003  | High shut debounce                                |
| TSADC AUTO PERIOD           | 0x0154 | W    | 0x00010000  | Auto conversion period                            |
| TSADC AUTO PERIOD H T       | 0x0158 | W    | 0x00010000  | Auto conversion period for high temperture        |
| TSADC COMPO LOW INT         | 0x015C | W    | 0x00000000  | Low temperature threshold for channel0            |
| TSADC T SETUP               | 0x019C | W    | 0x0000005F  | Timing for setup                                  |
| TSADC T PW EN               | 0x0200 | W    | 0x00000000  | Timing for pw_en                                  |
| TSADC T EN CLK              | 0x0204 | W    | 0x00000001  | Timing for en_clk                                 |
| TSADC T NON OV              | 0x0208 | W    | 0x00000002  | Timong for non_ov                                 |
| TSADC T HOLD                | 0x020C | W    | 0x00000013  | Timing for hold                                   |
| TSADC Q MAX                 | 0x0210 | W    | 0x00000200  | Max data used for data inversion                  |
| TSADC FLOW CON              | 0x0218 | W    | 0x00000003  | Flow control                                      |
| TSADC T PW CLK              | 0x0220 | W    | 0x00000030  | Timing for pw_clk                                 |

Notes:**S**ize:**B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 11.4.2 Detail Registers Description

#### TSADC USER CON

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |
| 15:9  | RO   | 0x00        | reserved                                                                                                                          |
| 8     | RO   | 0x0         | adc_status<br>1'b0: ADC stop<br>1'b1: Conversion in progress                                                                      |

| Bit | Attr   | Reset Value | Description                                                                                                                                                                                                |
|-----|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | R/W SC | 0x0         | start<br>When software writes 1 to this bit, start-of-conversion will be asserted.<br>This bit will be cleared after TSADC access finishing.<br>Only when TSADC_USER_CON[5] = 1'b1, this bit takes effect. |
| 6   | RW     | 0x0         | eoc_inten<br>Enable eoc interrupt for each conversion.<br>1'b1: Enable<br>1'b0: Disable                                                                                                                    |
| 5   | RW     | 0x0         | start_mode<br>Start mode.<br>1'b0: TSADC controller will assert start_of_conversion after power-up.<br>1'b1: The start_of_conversion will be controlled by TSADC_USER_CON[7].                              |
| 4   | RW     | 0x0         | power_control<br>ADC power control<br>1'b0: power down<br>1'b1: power up<br>This bit is not enabled when TSADC_AUTO_CON[0] is set to 1.                                                                    |
| 3:0 | RO     | 0x0         | reserved                                                                                                                                                                                                   |

**TSADC AUTO CON**

Address: Operational Base + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                                                              |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable                                        |
| 15:9  | RO   | 0x00        | reserved                                                                                                                                                                 |
| 8     | RW   | 0x0         | tshut_polarity<br>This bit is used to control the output signal polarity to GPIO when the temperature is higher than threshold.<br>1'b0: Low active<br>1'b1: High active |
| 7:3   | RO   | 0x00        | reserved                                                                                                                                                                 |
| 2     | RW   | 0x0         | round_int_en<br>Int enable for round model. Used for auto model all channel set is sampled.<br>1'b1: Enable<br>1'b0: Disable                                             |
| 1     | RW   | 0x0         | q_sel<br>1'b0: Use tsadc_q as output (positive temperature coefficient)<br>1'b1: Use (q_max - tsadc_q) as output (negative temperature coefficient)                      |
| 0     | RW   | 0x0         | auto_en<br>Auto conversion enable<br>1'b0: TSADC controller works at user-defined mode<br>1'b1: TSADC controller works at auto mode                                      |

**TSADC AUTO STATUS**

Address: Operational Base + offset (0x0008)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:4 | RO   | 0x00000000  | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | ht_wram<br>High-temperature status<br>1'b0: TSADC data is not higher than ht shut temperature<br>1'b1: TSADC data is higher than ht shut temperature |
| 2          | RW          | 0x0                | auto_status<br>TSADC auto mode status<br>1'b0: Auto mode stop<br>1'b1: Auto mode in progress                                                         |
| 1          | W0<br>C     | 0x0                | last_tshut_cru<br>Status for cru reset latest tshut, write 1 to clear.                                                                               |
| 0          | W1<br>C     | 0x0                | last_tshut_gpio<br>Status for GPIO latest tshut, write 1 to clear.                                                                                   |

**TSADC AUTO SRC**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                             |
| 15:0       | RW          | 0x0000             | auto_src<br>Enable channel for TSADC in auto mode. Each bit can enable for one channel.<br>In this chip onlu channel 0 is enable, so this bit should be set to 1'b1. |

**TSADC LT EN**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |
| 15:0       | RW          | 0x0000             | low_temperature_vio_en<br>Low-temperature violation logic enable, only bit0 is used.<br>1'b1: Enable<br>1'b0: Disable             |

**TSADC HT INT EN**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |
| 15:0       | RW          | 0x0000             | high_temperature_int_en<br>Temperature violation to GPIO enable, only bit0 is used.<br>1'b1: Enable<br>1'b0: Disable              |

**TSADC CRU EN**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | cru_en<br>Temperature violation to cru reset enable, only bit0 is used.<br>1'b1: Enable<br>1'b0: Disable |

**TSADC\_LT\_INT\_EN**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b1: Write access enable<br>1'b0: Write access disable |
| 15:0       | RW          | 0x0000             | low_temperture_int_en<br>Low-temperature interrupt enable, only bit0 is used.<br>1'b1: Enable<br>1'b0: Disable                    |

**TSADC\_HLT\_INT\_PD**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31:16      | W1C         | 0x0000             | lt_int_status<br>Low-temperature interrupt status for each channel.  |
| 15:0       | W1C         | 0x0000             | ht_int_status<br>High-temperature interrupt status for each channel. |

**TSADC\_EOC\_HSHUT\_PD**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                                |
| 17         | W1C         | 0x0                | round_int_pd<br>Auto model interrupt for each round of all set channel. |
| 16         | W1C         | 0x0                | usr_eoc_irq_pd<br>User model end interrupt status.                      |
| 15:0       | W1C         | 0x0000             | ht_shut_pd<br>High temperature shut down status for each channel.       |

**TSADC\_DATA0**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                |
| 11:0       | RO          | 0x000              | adc_data<br>A/D value of the channel 0 last conversion. |

**TSADC\_COMPO\_INT**

Address: Operational Base + offset (0x006C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                                     |
| 11:0       | RW          | 0x000              | tsadc_comp_src0<br>TSADC high-temperature level.<br>TSADC output is bigger than tsadc_comp, which means the temperature is high.<br>TSADC_INT will be valid. |

**TSADC\_COMPO\_SHUT**

Address: Operational Base + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                                     |
| 11:0       | RW          | 0x000              | tsadc_comp_src0<br>TSADC high-temperature level.<br>TSADC output is bigger than tsadc_comp, which means the temperature is too high.<br>TSHUT will be valid. |

**TSADC HIGH INT DEBOUNCE**

Address: Operational Base + offset (0x014C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                              |
| 7:0        | RW          | 0x03               | debounce<br>TSADC controller will only generate interrupt or TSHUT when the temperature is higher than COMP_INT for "debounce" times. |

**TSADC HIGHT TSHUT DEBOUNCE**

Address: Operational Base + offset (0x0150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                               |
| 7:0        | RW          | 0x03               | debounce<br>TSADC controller will only generate interrupt or TSHUT when the temperature is higher than COMP_SHUT for "debounce" times. |

**TSADC AUTO PERIOD**

Address: Operational Base + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00010000         | auto_period<br>When auto mode is enabled, this register controls the interleave between every conversion for all channels enabled of TSADC. |

**TSADC AUTO PERIOD HT**

Address: Operational Base + offset (0x0158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00010000         | auto_period<br>This register controls the interleave between every conversion for all channels enabled of TSADC after the temperature is higher than COMP_SHUT or COMP_INT. |

**TSADC COMPO LOW INT**

Address: Operational Base + offset (0x015C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                                      |
| 11:0       | RW          | 0x000              | tsadc_comp_src0<br>TSADC low-temperature level.<br>TSADC output is lower than tsadc_comp, which means the temperature is low.<br>TSADC_LOW_INT will be valid. |

**TSADC T SETUP**

Address: Operational Base + offset (0x019C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                           |
| 15:0       | RW          | 0x005f             | t_setup<br>The timing between TSADC power up and start conversion. |

**TSADC T PW EN**

Address: Operational Base + offset (0x0200)

| Bit   | Attr | Reset Value | Description                                                           |
|-------|------|-------------|-----------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                              |
| 15:0  | RW   | 0x0000      | t_pw_en<br>The timing assert start conversion signal(EN_TEMP_SEN_TS). |

**TSADC T EN CLK**

Address: Operational Base + offset (0x0204)

| Bit  | Attr | Reset Value | Description                                                                                                  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                     |
| 7:0  | RW   | 0x01        | t_en_clk<br>The timing between dis-assert start conversion signal (EN_TEMP_SEN_TS) and assert CLK_SEN_TS[8]. |

**TSADC T NON OV**

Address: Operational Base + offset (0x0208)

| Bit  | Attr | Reset Value | Description                                                        |
|------|------|-------------|--------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                           |
| 7:0  | RW   | 0x02        | t_non_ov<br>The timing between each bit assertion of CLK_SENSE_TS. |

**TSADC T HOLD**

Address: Operational Base + offset (0x020C)

| Bit   | Attr | Reset Value | Description                                                                |
|-------|------|-------------|----------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                                   |
| 15:0  | RW   | 0x0013      | t_hold<br>The timing between dis-assert CLK_SENSE_TS and TSADC data valid. |

**TSADC Q MAX**

Address: Operational Base + offset (0x0210)

| Bit   | Attr | Reset Value | Description                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------|
| 31:13 | RO   | 0x00000     | reserved                                                                     |
| 12:0  | RW   | 0x0200      | q_max<br>This register used for TSADC_AUTO_CON[1] for inversion output data. |

**TSADC FLOW CON**

Address: Operational Base + offset (0x0218)

| Bit  | Attr | Reset Value | Description                                                                                                |
|------|------|-------------|------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                                                                   |
| 4    | RW   | 0x0         | as_pd_mode<br>When this bit set to 1'b1, TSADC PHY will come to low power mode between the two conversion. |
| 3:2  | RO   | 0x0         | reserved                                                                                                   |
| 1    | RW   | 0x1         | pd_soc_mode<br>Not used in this chip.                                                                      |
| 0    | RW   | 0x1         | eoc_mode<br>Not used in this chip.                                                                         |

**TSADC T PW CLK**

Address: Operational Base + offset (0x0220)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:16 | RO   | 0x0000      | reserved    |

| Bit  | Attr | Reset Value | Description                                                           |
|------|------|-------------|-----------------------------------------------------------------------|
| 15:0 | RW   | 0x0030      | t_pw_clk<br>The timing for the assertion of each bit of CLK_SENSE_TS. |

## 11.5 Application Notes

### 11.5.1 Coverision Flow

The system works as follows

- 1) Temperature violation and other configurations may be set.
- 2) Assert tsadc\_tsen\_en and tsadc\_ana\_reg0/1/2, which could be found in VOGRF.
- 3) Set the bit[0] in register TSADC\_AUTO\_CON, then TS-ADC will work.
- 4) Then temperature information can be read from the APB interface.
- 5) If TS-ADC needs to be closed, set bit[0] in register TSADC\_AUTO\_CON to 1'b0.

### 11.5.2 Timing Diagram

When TS-ADC start to work, the timing will follow the Fig.1-2

The timing requirement is also listed as follows.



Fig. 11-2 Timing diagram for TS-ADC

Table 11-1 TS-ADC Start Timing

| parameter | min  |
|-----------|------|
| t1        | 10us |
| t2        | 0us  |
| t3        | 90us |

### 11.5.3 Temperature-to-Code Mapping

Table 11-2 TS-ADC Look up Table

| temperature (°C) | typical output |
|------------------|----------------|
| -40              | 628            |
| -35              | 620            |
| -30              | 612            |
| 0                | 561            |
| 5                | 553            |
| 10               | 545            |
| 25               | 520            |
| 30               | 512            |
| 80               | 427            |
| 85               | 419            |
| 115              | 368            |
| 120              | 359            |

| <b>temperature (°C)</b> | <b>typical output</b> |
|-------------------------|-----------------------|
| 125                     | 351                   |

**Note:**

*Code to Temperature mapping of the Temperature sensor is a linear curve. Any temperature, code falling between to 2 given temperatures can be linearly interpolated.*

*Code to Temperature mapping should be updated based on silicon results.*

Rockchip Confidential

## Chapter 12 Pulse Width Modulation (PWM)

### 12.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
- Support 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 an input filter to remove glitch
- Support continuous mode or one-shot mode
  - 32-bit period counter
  - 32-bit duty register
  - 32-bit current value register
  - PWM output polarity in inactive state and duty cycle polarity can be configured
  - 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
  - Support global lock register to control shadow register effective time
  - Support IR transmission in NEC with full repeat, NEC with simple repeat, TC9012 or SONY mode
- Pre-scaled operation to clk\_pwm and then further scaled
- Available low-power mode to reduce power consumption when the channel is inactive.

### 12.2 Block Diagram



Fig. 12-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.

## 12.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.

### 12.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. 12-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.

### 12.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. 12-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. 12-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).

### 12.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. 12-5 PWM One-shot Center-aligned Output Mode

## 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.

### 12.4.2 Registers Summary

| Name                | Offset | Size | Reset Value | Description                                                  |
|---------------------|--------|------|-------------|--------------------------------------------------------------|
| PWM_PWM0_CNT        | 0x0000 | W    | 0x00000000  | PWM Channel 0 Counter Register                               |
| PWM_PWM0_PERIOD_HPR | 0x0004 | W    | 0x00000000  | PWM Channel 0 Period Register/High Polarity Capture Register |
| PWM_PWM0_DUTY_LPR   | 0x0008 | W    | 0x00000000  | PWM Channel 0 Duty 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_PWM1_PERIOD_HPR | 0x0014 | W    | 0x00000000  | PWM Channel 1 Period Register/High Polarity Capture Register |
| PWM_PWM1_DUTY_LPR   | 0x0018 | W    | 0x00000000  | PWM Channel 1 Duty Register/Low Polarity Capture Register    |
| PWM_PWM1_CTRL       | 0x001C | W    | 0x00000000  | PWM Channel 1 Control Register                               |
| PWM_PWM2_CNT        | 0x0020 | W    | 0x00000000  | PWM Channel 2 Counter Register                               |
| PWM_PWM2_PERIOD_HPR | 0x0024 | W    | 0x00000000  | PWM Channel 2 Period Register/High Polarity Capture Register |
| PWM_PWM2_DUTY_LPR   | 0x0028 | W    | 0x00000000  | PWM Channel 2 Duty Register/Low Polarity Capture Register    |
| PWM_PWM2_CTRL       | 0x002C | W    | 0x00000000  | PWM Channel 2 Control Register                               |
| PWM_PWM3_CNT        | 0x0030 | W    | 0x00000000  | PWM Channel 3 Counter Register                               |
| PWM_PWM3_PERIOD_HPR | 0x0034 | W    | 0x00000000  | PWM Channel 3 Period Register/High Polarity Capture Register |

| Name                      | Offset | Size | Reset Value | Description                                               |
|---------------------------|--------|------|-------------|-----------------------------------------------------------|
| PWM PWM3_DUTY_LPR         | 0x0038 | W    | 0x00000000  | PWM Channel 3 Duty Register/Low Polarity Capture Register |
| PWM PWM3_CTRL             | 0x003C | W    | 0x00000000  | PWM Channel 3 Control Register                            |
| PWM INTSTS                | 0x0040 | W    | 0x00000000  | Interrupt Status Register                                 |
| PWM INT_EN                | 0x0044 | W    | 0x00000000  | Interrupt Enable Register                                 |
| PWM FIFO_CTRL             | 0x0050 | W    | 0x00000000  | PWM Channel 3 FIFO Mode Control Register                  |
| PWM FIFO_INTSTS           | 0x0054 | W    | 0x00000010  | FIFO Interrupts Status Register                           |
| PWM FIFO_TOUTTHR          | 0x0058 | W    | 0x00000000  | FIFO Timeout Threshold Register                           |
| PWM VERSION_ID            | 0x005C | W    | 0x03120B34  | PWM Version ID Register                                   |
| PWM FIFO                  | 0x0060 | W    | 0x00000000  | FIFO Register                                             |
| PWM PWRMATCH_CTRL         | 0x0080 | W    | 0x00000000  | Power Key Match Control Register                          |
| PWM PWRMATCH_LPREG        | 0x0084 | W    | 0x238C22C4  | Power Key Match Of Low Preload Register                   |
| PWM PWRMATCH_HPRE         | 0x0088 | W    | 0x11F81130  | Power Key Match Of High Preload Register                  |
| PWM PWRMATCH_LD           | 0x008C | W    | 0x029401CC  | Power Key Match Of Low Data Register                      |
| PWM PWRMATCH_HD_ZERO      | 0x0090 | W    | 0x029401CC  | Power Key Match Of High Data For Zero Register            |
| PWM PWRMATCH_HD_ONE       | 0x0094 | W    | 0x06FE0636  | Power Key Match Of High Data For One Register             |
| PWM PWRMATCH_VALUE_0      | 0x0098 | W    | 0x00000000  | Power Key Match Value 0 Register                          |
| PWM PWRMATCH_VALUE_1      | 0x009C | W    | 0x00000000  | Power Key Match Value 1 Register                          |
| PWM PWRMATCH_VALUE_2      | 0x00A0 | W    | 0x00000000  | Power Key Match Value 2 Register                          |
| PWM PWRMATCH_VALUE_3      | 0x00A4 | W    | 0x00000000  | Power Key Match Value 3 Register                          |
| PWM PWRMATCH_VALUE_4      | 0x00A8 | W    | 0x00000000  | Power Key Match Value 4 Register                          |
| PWM PWRMATCH_VALUE_5      | 0x00AC | W    | 0x00000000  | Power Key Match Value 5 Register                          |
| PWM PWRMATCH_VALUE_6      | 0x00B0 | W    | 0x00000000  | Power Key Match Value 6 Register                          |
| PWM PWRMATCH_VALUE_7      | 0x00B4 | W    | 0x00000000  | Power Key Match Value 7 Register                          |
| PWM PWRMATCH_VALUE_8      | 0x00B8 | W    | 0x00000000  | Power Key Match Value 8 Register                          |
| PWM PWRMATCH_VALUE_9      | 0x00BC | W    | 0x00000000  | Power Key Match Value 9 Register                          |
| PWM PWM3_PWRCAPTURE_VALUE | 0x00CC | W    | 0x00000000  | Channel 3 Power Key Capture Value Register                |
| PWM FILTER_CTRL           | 0x00D0 | W    | 0x00000000  | Filter Control Register                                   |
| PWM PWM0_OFFSET           | 0x00E0 | W    | 0x00000000  | Channel0 Output Offset                                    |
| PWM PWM1_OFFSET           | 0x00E4 | W    | 0x00000000  | Channel1 Output Offset                                    |
| PWM PWM2_OFFSET           | 0x00E8 | W    | 0x00000000  | Channel2 Output Offset                                    |
| PWM PWM3_OFFSET           | 0x00EC | W    | 0x00000000  | Channel3 Output Offset                                    |
| PWM IR_TRANS_CTRL         | 0x0100 | W    | 0x00001F02  | IR Transmission control register                          |
| PWM IR_TRANS_PRE          | 0x0104 | W    | 0x11942328  | IR transmission preload period                            |

| Name                     | Offset | Size | Reset Value | Description                               |
|--------------------------|--------|------|-------------|-------------------------------------------|
| PWM_IR_TRANS_SPRE        | 0x0108 | W    | 0x0000008CA | IR transmission simple preload low period |
| PWM_IR_TRANS_LD          | 0x010C | W    | 0x000000230 | IR Trans Out Data Low Period              |
| PWM_IR_TRANS_HD          | 0x0110 | W    | 0x069A0230  | IR Trans Out High Period                  |
| PWM_IR_TRANS_BURST_FRAME | 0x0114 | W    | 0x2261A5E0  | IR transmission frame and burst period    |
| PWM_IR_TRANS_DATA_VALUE  | 0x0118 | W    | 0x000000000 | IR Trans Output Data Value                |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 12.4.3 Detail Registers Description

#### PWM\_PWM0\_CNT

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x000000000 | CNT<br>The 32-bit indicates current value of PWM Channel 0 counter. The 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 | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x000000000 | PERIOD_HPR<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the period of the output waveform. Note that, if the PWM is operated at the center-aligned mode, the period should be an even one, and therefore only the bit [31:1] is taken into account and bit [0] always considered as 0.<br>If PWM is operated at the capture mode, this value indicates the effective high polarity cycles of input waveform. This value is 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 | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x000000000 | DUTY_LPR<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the duty cycle of the output waveform. The PWM starts the output waveform with duty cycle. Note that, if the PWM is operated at the center-aligned mode, the period should be an even one, and therefore only the [31:1] is taken into account.<br>If PWM is operated at the capture mode, this value indicates the effective low polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to ( $2^{32}-1$ ). |

#### PWM\_PWM0\_CTRL

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | rpt<br>This field defines the repeated effective periods of output waveform in one-shot mode. The value N means N+1 repeated effective periods.                                                                                                    |
| 23:16      | RW          | 0x00               | scale<br>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          | 0x0                | prescale<br>This field defines the prescale factor applied to input clock. The value N means that the input clock is divided by 2^N.                                                                                                               |
| 11         | RW          | 0x0                | aligned_vld_n<br>0: Aligned Mode Valid<br>1: Aligned Mode Invalid                                                                                                                                                                                  |
| 10         | RW          | 0x0                | clk_src_sel<br>1'b0: Select clk_pwm as root clock source, Clock is from PLL and the frequency can be configured.<br>1'b1: Select clk_pwm_capture as root clock source, Clock is from crystal oscillator and the frequency is fixed.                |
| 9          | RW          | 0x0                | clk_sel<br>1'b0: Non-scaled clock is selected as PWM clock source. It means that the prescale clock is directly used as the PWM clock source.<br>1'b1: Scaled clock is selected as PWM clock source.                                               |
| 8          | RW          | 0x0                | force_clk_en<br>1'b0: Disabled, when PWM channel is inactive state, the clk_pwm to PWM Clock prescale module is blocked to reduce power consumption.<br>1'b1: Enabled, the clk_pwm to PWM Clock prescale module is always enabled.                 |
| 7          | RW          | 0x0                | ch_cnt_en<br>1'b0: Disabled<br>1'b1: Enabled                                                                                                                                                                                                       |
| 6          | RW          | 0x0                | conlock<br>pwm period and duty lock to previous configuration<br>1'b0: Disable lock<br>1'b1: Enable lock                                                                                                                                           |
| 5          | RW          | 0x0                | output_mode<br>1'b0: Left aligned mode<br>1'b1: Center aligned mode                                                                                                                                                                                |
| 4          | RW          | 0x0                | inactive_pol<br>This defines the output waveform polarity when PWM channel is in inactive state. The inactive state means that PWM finishes the complete waveform in one-shot mode or PWM channel is disabled.<br>1'b0: Negative<br>1'b1: Positive |
| 3          | RW          | 0x0                | duty_pol<br>This defines the polarity for duty cycle. PWM starts the output waveform with duty cycle.<br>1'b0: Negative<br>1'b1: Positive                                                                                                          |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                    |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:1 | RW   | 0x0         | pwm_mode<br>2'b00: One shot mode, PWM produces the waveform within the repeated times defined by PWMx_CTRL_rpt .<br>2'b01: Continuous mode, PWM produces the waveform continuously.<br>2'b10: Capture mode, PWM measures the cycles of high/low polarity of input waveform.<br>2'b11: Reserved |
| 0   | RW   | 0x0         | pwm_en<br>1'b0: Disabled<br>1'b1: Enabled<br>If the PWM is worked in the one-shot mode, this bit will be cleared at the end of operation.                                                                                                                                                      |

**PWM\_PWM1\_CNT**

Address: Operational Base + offset (0x0010)

| Bit  | Attr | Reset Value | Description                                                                                                                                                  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | CNT<br>The 32-bit indicates current value of PWM Channel 1 counter. The counter runs at the rate of PWM clock.<br>The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_PWM1\_PERIOD\_HPR**

Address: Operational Base + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | PERIOD_HPR<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the period of the output waveform. Note that, if the PWM is operated at the center-aligned mode, the period should be an even one, and therefore only the bit [31:1] is taken into account and bit [0] always considered as 0.<br>If PWM is operated at the capture mode, this value indicates the effective high polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_PWM1\_DUTY\_LPR**

Address: Operational Base + offset (0x0018)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | DUTY_LPR<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the duty cycle of the output waveform. The PWM starts the output waveform with duty cycle. Note that, if the PWM is operated at the center-aligned mode, the period should be an even one, and therefore only the [31:1] is taken into account.<br>If PWM is operated at the capture mode, this value indicates the effective low polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_PWM1\_CTRL**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | rpt<br>This field defines the repeated effective periods of output waveform in one-shot mode. The value N means N+1 repeated effective periods.                                                                                                    |
| 23:16      | RW          | 0x00               | scale<br>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          | 0x0                | prescale<br>This field defines the prescale factor applied to input clock. The value N means that the input clock is divided by 2^N.                                                                                                               |
| 11         | RW          | 0x0                | aligned_vld_n<br>0: Aligned Mode Valid<br>1: Aligned Mode Invalid                                                                                                                                                                                  |
| 10         | RW          | 0x0                | clk_src_sel<br>1'b0: Select clk_pwm as root clock source, Clock is from PLL and the frequency can be configured.<br>1'b1: Select clk_pwm_capture as root clock source, Clock is from crystal oscillator and the frequency is fixed.                |
| 9          | RW          | 0x0                | clk_sel<br>1'b0: Non-scaled clock is selected as PWM clock source. It means that the prescale clock is directly used as the PWM clock source.<br>1'b1: Scaled clock is selected as PWM clock source.                                               |
| 8          | RW          | 0x0                | force_clk_en<br>1'b0: Disabled, when PWM channel is inactive state, the clk_pwm to PWM Clock prescale module is blocked to reduce power consumption.<br>1'b1: Enabled, the clk_pwm to PWM Clock prescale module is always enabled.                 |
| 7          | RW          | 0x0                | ch_cnt_en<br>1'b0: Disabled<br>1'b1: Enabled                                                                                                                                                                                                       |
| 6          | RW          | 0x0                | conlock<br>pwm period and duty lock to previous configuration<br>1'b0: Disable lock<br>1'b1: Enable lock                                                                                                                                           |
| 5          | RW          | 0x0                | output_mode<br>1'b0: Left aligned mode<br>1'b1: Center aligned mode                                                                                                                                                                                |
| 4          | RW          | 0x0                | inactive_pol<br>This defines the output waveform polarity when PWM channel is in inactive state. The inactive state means that PWM finishes the complete waveform in one-shot mode or PWM channel is disabled.<br>1'b0: Negative<br>1'b1: Positive |
| 3          | RW          | 0x0                | duty_pol<br>This defines the polarity for duty cycle. PWM starts the output waveform with duty cycle.<br>1'b0: Negative<br>1'b1: Positive                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:1        | RW          | 0x0                | pwm_mode<br>2'b00: One shot mode, PWM produces the waveform within the repeated times defined by PWMx_CTRL_rpt.<br>2'b01: Continuous mode, PWM produces the waveform continuously.<br>2'b10: Capture mode, PWM measures the cycles of high/low polarity of input waveform.<br>2'b11: Reserved |
| 0          | RW          | 0x0                | pwm_en<br>1'b0: Disabled<br>1'b1: Enabled<br>If the PWM is worked in the one-shot mode, this bit will be cleared at the end of operation.                                                                                                                                                     |

**PWM\_PWM2\_CNT**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | CNT<br>The 32-bit indicates current value of PWM Channel 2 counter. The counter runs at the rate of PWM clock.<br>The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_PWM2\_PERIOD\_HPR**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | PERIOD_HPR<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the period of the output waveform. Note that, if the PWM is operated at the center-aligned mode, the period should be an even one, and therefore only the bit [31:1] is taken into account and bit [0] always considered as 0.<br>If PWM is operated at the capture mode, this value indicates the effective high polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_PWM2\_DUTY\_LPR**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | DUTY_LPR<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the duty cycle of the output waveform. The PWM starts the output waveform with duty cycle. Note that, if the PWM is operated at the center-aligned mode, the period should be an even one, and therefore only the [31:1] is taken into account.<br>If PWM is operated at the capture mode, this value indicates the effective low polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_PWM2\_CTRL**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | rpt<br>This field defines the repeated effective periods of output waveform in one-shot mode. The value N means N+1 repeated effective periods.                                                                                                    |
| 23:16      | RW          | 0x00               | scale<br>This fields 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          | 0x0                | prescale<br>This field defines the prescale factor applied to input clock. The value N means that the input clock is divided by 2^N.                                                                                                               |
| 11         | RW          | 0x0                | aligned_vld_n<br>0: Aligned Mode Valid<br>1: Aligned Mode Invalid                                                                                                                                                                                  |
| 10         | RW          | 0x0                | clk_src_sel<br>1'b0: Select clk_pwm as root clock source, Clock is from PLL and the frequency can be configured.<br>1'b1: Select clk_pwm_capture as root clock source, Clock is from crystal oscillator and the frequency is fixed.                |
| 9          | RW          | 0x0                | clk_sel<br>1'b0: Non-scaled clock is selected as PWM clock source. It means that the prescale clock is directly used as the PWM clock source.<br>1'b1: Scaled clock is selected as PWM clock source.                                               |
| 8          | RW          | 0x0                | force_clk_en<br>1'b0: Disabled, when PWM channel is inactive state, the clk_pwm to PWM Clock prescale module is blocked to reduce power consumption.<br>1'b1: Enabled, the clk_pwm to PWM Clock prescale module is always enabled.                 |
| 7          | RW          | 0x0                | ch_cnt_en<br>1'b0: Disabled<br>1'b1: Enabled                                                                                                                                                                                                       |
| 6          | RW          | 0x0                | conlock<br>pwm period and duty lock to previous configuration<br>1'b0: Disable lock<br>1'b1: Enable lock                                                                                                                                           |
| 5          | RW          | 0x0                | output_mode<br>1'b0: Left aligned mode<br>1'b1: Center aligned mode                                                                                                                                                                                |
| 4          | RW          | 0x0                | inactive_pol<br>This defines the output waveform polarity when PWM channel is in inactive state. The inactive state means that PWM finishes the complete waveform in one-shot mode or PWM channel is disabled.<br>1'b0: Negative<br>1'b1: Positive |
| 3          | RW          | 0x0                | duty_pol<br>This defines the polarity for duty cycle. PWM starts the output waveform with duty cycle.<br>1'b0: Negative<br>1'b1: Positive                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:1        | RW          | 0x0                | pwm_mode<br>2'b00: One shot mode, PWM produces the waveform within the repeated times defined by PWMx_CTRL_rpt.<br>2'b01: Continuous mode, PWM produces the waveform continuously.<br>2'b10: Capture mode. PWM measures the cycles of high/low polarity of input waveform.<br>2'b11: Reserved |
| 0          | RW          | 0x0                | pwm_en<br>1'b0: Disabled<br>1'b1: Enabled<br>If the PWM is worked in the one-shot mode, this bit will be cleared at the end of operation.                                                                                                                                                     |

**PWM\_PWM3\_CNT**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | CNT<br>The 32-bit indicates current value of PWM Channel 3 counter. The 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | PERIOD_HPR<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the period of the output waveform. Note that, if the PWM is operated at the center-aligned mode, the period should be an even one, and therefore only the bit [31:1] is taken into account and bit [0] always considered as 0.<br>If PWM is operated at the capture mode, this value indicates the effective high polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_PWM3\_DUTY\_LPR**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | DUTY_LPR<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the duty cycle of the output waveform. The PWM starts the output waveform with duty cycle. Note that, if the PWM is operated at the center-aligned mode, the period should be an even one, and therefore only the [31:1] is taken into account.<br>If PWM is operated at the capture mode, this value indicates the effective low polarity cycles of input waveform.<br>This value is based on the PWM clock. The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_PWM3\_CTRL**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | rpt<br>This field defines the repeated effective periods of output waveform in one-shot mode. The value N means N+1 repeated effective periods.                                                                                                    |
| 23:16      | RW          | 0x00               | scale<br>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          | 0x0                | prescale<br>This field defines the prescale factor applied to input clock. The value N means that the input clock is divided by 2^N.                                                                                                               |
| 11         | RW          | 0x0                | aligned_vld_n<br>0: Aligned Mode Valid<br>1: Aligned Mode Invalid                                                                                                                                                                                  |
| 10         | RW          | 0x0                | clk_src_sel<br>1'b0: Select clk_pwm as root clock source, Clock is from PLL and the frequency can be configured.<br>1'b1: Select clk_pwm_capture as root clock source, Clock is from crystal oscillator and the frequency is fixed.                |
| 9          | RW          | 0x0                | clk_sel<br>1'b0: Non-scaled clock is selected as PWM clock source. It means that the prescale clock is directly used as the PWM clock source.<br>1'b1: Scaled clock is selected as PWM clock source.                                               |
| 8          | RW          | 0x0                | force_clk_en<br>1'b0: Disabled, when PWM channel is inactive state, the clk_pwm to PWM Clock prescale module is blocked to reduce power consumption.<br>1'b1: Enabled, the clk_pwm to PWM Clock prescale module is always enabled.                 |
| 7          | RW          | 0x0                | ch_cnt_en<br>1'b0: Disabled<br>1'b1: Enabled                                                                                                                                                                                                       |
| 6          | RW          | 0x0                | conlock<br>pwm period and duty lock to previous configuration<br>1'b0: Disable lock<br>1'b1: Enable lock                                                                                                                                           |
| 5          | RW          | 0x0                | output_mode<br>1'b0: Left aligned mode<br>1'b1: Center aligned mode                                                                                                                                                                                |
| 4          | RW          | 0x0                | inactive_pol<br>This defines the output waveform polarity when PWM channel is in inactive state. The inactive state means that PWM finishes the complete waveform in one-shot mode or PWM channel is disabled.<br>1'b0: Negative<br>1'b1: Positive |
| 3          | RW          | 0x0                | duty_pol<br>This defines the polarity for duty cycle. PWM starts the output waveform with duty cycle.<br>1'b0: Negative<br>1'b1: Positive                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:1        | RW          | 0x0                | pwm_mode<br>2'b00: One shot mode, PWM produces the waveform within the repeated times defined by PWMx_CTRL_rpt<br>2'b01: Continuous mode, PWM produces the waveform continuously.<br>2'b10: Capture mode, PWM measures the cycles of high/low polarity of input waveform.<br>2'b11: Reserved |
| 0          | RW          | 0x0                | pwm_en<br>1'b0: Disabled<br>1'b1: Enabled<br>If the PWM is worked in the one-shot mode, this bit will be cleared at the end of operation.                                                                                                                                                    |

**PWM\_INTSTS**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 11         | RO          | 0x0                | CH3_Pol<br>This bit is used in capture mode in order to identify the transition of the input waveform when interrupt is generated. When bit is 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. |
| 10         | RO          | 0x0                | CH2_Pol<br>This bit is used in capture mode in order to identify the transition of the input waveform when interrupt is generated. 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. |
| 9          | RO          | 0x0                | CH1_Pol<br>This bit is used in capture mode in order to identify the transition of the input waveform when interrupt is generated. When bit is 1, please refer to PWM1_PERIOD_HPR to know the 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. |
| 8          | RO          | 0x0                | CH0_Pol<br>This bit is used in capture mode in order to identify the transition of the input waveform when interrupt is generated. When bit is 1, please refer to PWM0_PERIOD_HPR to know the 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. |
| 7          | W1C         | 0x0                | CH3_pwr_IntSts<br>1'b0: Channel 3 power key Interrupt not generated<br>1'b1: Channel 3 power key Interrupt generated                                                                                                                                                                                                                                                                               |
| 6          | W1C         | 0x0                | CH2_pwr_IntSts<br>1'b0: Channel 2 power key Interrupt not generated<br>1'b1: Channel 2 power key Interrupt generated                                                                                                                                                                                                                                                                               |
| 5          | W1C         | 0x0                | CH1_pwr_IntSts<br>1'b0: Channel 1 power keyInterrupt not generated<br>1'b1: Channel 1 power key Interrupt generated                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 4          | W1<br>C     | 0x0                | CH0_pwr_Intsts<br>1'b0: Channel 0 power key Interrupt not generated<br>1'b1: Channel 0 power key Interrupt generated |
| 3          | W1<br>C     | 0x0                | CH3_Intsts<br>1'b0: Channel 3 Interrupt not generated<br>1'b1: Channel 3 Interrupt generated                         |
| 2          | W1<br>C     | 0x0                | CH2_Intsts<br>1'b0: Channel 2 Interrupt not generated<br>1'b1: Channel 2 Interrupt generated                         |
| 1          | W1<br>C     | 0x0                | CH1_Intsts<br>1'b0: Channel 1 Interrupt not generated<br>1'b1: Channel 1 Interrupt generated                         |
| 0          | W1<br>C     | 0x0                | CH0_Intsts<br>1'b0: Channel 0 Interrupt not generated<br>1'b1: Channel 0 Interrupt generated                         |

**PWM INT EN**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                      |
| 7          | RW          | 0x0                | CH3_pwr_Int_en<br>1'b0: Channel 3 power key Interrupt disabled<br>1'b1: Channel 3 power key Interrupt enabled |
| 6          | RW          | 0x0                | CH2_pwr_Int_en<br>1'b0: Channel 2 power key Interrupt disabled<br>1'b1: Channel 2 power key Interrupt enabled |
| 5          | RW          | 0x0                | CH1_pwr_Int_en<br>1'b0: Channel 1 power key Interrupt disabled<br>1'b1: Channel 1 power key Interrupt enabled |
| 4          | RW          | 0x0                | CH0_pwr_Int_en<br>1'b0: Channel 0 power key Interrupt disabled<br>1'b1: Channel 0 power key Interrupt enabled |
| 3          | RW          | 0x0                | CH3_Int_en<br>1'b0: Channel 3 Interrupt disabled<br>1'b1: Channel 3 Interrupt enabled                         |
| 2          | RW          | 0x0                | CH2_Int_en<br>1'b0: Channel 2 Interrupt disabled<br>1'b1: Channel 2 Interrupt enabled                         |
| 1          | RW          | 0x0                | CH1_Int_en<br>1'b0: Channel 1 Interrupt disabled<br>1'b1: Channel 1 Interrupt enabled                         |
| 0          | RW          | 0x0                | CH0_Int_en<br>1'b0: Channel 0 Interrupt disabled<br>1'b1: Channel 0 Interrupt enabled                         |

**PWM FIFO CTRL**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x000000           | reserved                                                                                           |
| 13:12      | RW          | 0x0                | 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                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | dma_ch_sel_en<br>1'b1: Enable, use dma_ch_sel to select the channel to FIFO mode and DMA mode.<br>1'b0: Disable, select the channel PWM3 to FIFO mode and DMA mode. |
| 9          | RW          | 0x0                | timeout_en<br>FIFO timeout enable                                                                                                                                   |
| 8          | RW          | 0x0                | 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                     |
| 4          | RO          | 0x1                | fifo_empty_status<br>This bit indicates the FIFO is empty.                   |
| 3          | W1C         | 0x0                | timieout_intsts<br>Timeout interrupt                                         |
| 2          | W1C         | 0x0                | fifo_watermark_full_intsts<br>This bit indicates the FIFO is Watermark Full. |
| 1          | W1C         | 0x0                | fifo_overflow_intsts<br>This bit indicates the FIFO is overflow.             |
| 0          | W1C         | 0x0                | fifo_full_intsts<br>This bit indicates the FIFO is full.                     |

**PWM FIFO TOUTTHR**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                |
| 19:0       | RW          | 0x00000            | timeout_threshold<br>FIFO Timeout value(unit pwm clock) |

**PWM VERSION ID**

Address: Operational Base + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x03               | main_version<br>Main version<br>8'h0: Base version<br>8'h1: Support DMA mode<br>8'h2: Support DMA mode and Power key mode<br>8'h3: Support DMA mode and Power key mode and IR transmission |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>             |
|------------|-------------|--------------------|--------------------------------|
| 23:16      | RO          | 0x12               | minor_version<br>Minor version |
| 15:0       | RO          | 0x0b34             | svn_version<br>SVN version     |

**PWM FIFO**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | pol<br>This bit indicates the polarity of the lower 31-bit counter.<br>1'b0: Low<br>1'b1: High |
| 30:0       | RO          | 0x00000000         | cycle_cnt<br>This 31-bit counter indicates the effective cycles of high/low waveform.          |

**PWM PWRMATCH CTRL**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                 |
| 15         | RW          | 0x0                | CH3_pwrkey_int_ctrl<br>1'b0: Assert interrupt after key capture with power key match<br>1'b1: Assert interrupt after key capture without power key match |
| 14:12      | RO          | 0x0                | reserved                                                                                                                                                 |
| 11         | RW          | 0x0                | CH3_pwrkey_capture_ctrl<br>1'b0: Capture the value after interrupt<br>1'b1: Capture the value directly                                                   |
| 10:8       | RO          | 0x0                | reserved                                                                                                                                                 |
| 7          | RW          | 0x0                | CH3_pwrkey_polarity<br>1'b0: PWM in polarity is positive<br>1'b1: PWM in polarity is negative                                                            |
| 6:4        | RO          | 0x0                | reserved                                                                                                                                                 |
| 3          | RW          | 0x0                | CH3_pwrkey_enable<br>1'b0: Disabled<br>1'b1: Enabled                                                                                                     |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                                 |

**PWM PWRMATCH LPRE**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:16      | RW          | 0x238c             | cnt_max<br>The maximum counter value |
| 15:0       | RW          | 0x22c4             | cnt_min<br>The minimum counter value |

**PWM PWRMATCH HPRE**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:16      | RW          | 0x11f8             | cnt_max<br>The maximum counter value |
| 15:0       | RW          | 0x1130             | cnt_min<br>The minimum counter value |

**PWM PWRMATCH LD**

Address: Operational Base + offset (0x008C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:16      | RW          | 0x0294             | cnt_max<br>The maximum counter value |
| 15:0       | RW          | 0x01cc             | cnt_min<br>The minimum counter value |

**PWM\_PWRMATCH HD ZERO**

Address: Operational Base + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:16      | RW          | 0x0294             | cnt_max<br>The maximum counter value |
| 15:0       | RW          | 0x01cc             | cnt_min<br>The minimum counter value |

**PWM\_PWRMATCH HD ONE**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:16      | RW          | 0x06fe             | cnt_max<br>The maximum counter value |
| 15:0       | RW          | 0x0636             | cnt_min<br>The minimum counter value |

**PWM\_PWRMATCH VALUE0**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value0<br>Power key match value 0 |

**PWM\_PWRMATCH VALUE1**

Address: Operational Base + offset (0x009C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value1<br>Power key match value 1 |

**PWM\_PWRMATCH VALUE2**

Address: Operational Base + offset (0x00A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value2<br>Power key match value 2 |

**PWM\_PWRMATCH VALUE3**

Address: Operational Base + offset (0x00A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value3<br>Power key match value 3 |

**PWM\_PWRMATCH VALUE4**

Address: Operational Base + offset (0x00A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value4<br>Power key match value 4 |

**PWM\_PWRMATCH VALUE5**

Address: Operational Base + offset (0x00AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value5<br>Power key match value 5 |

**PWM\_PWRMATCH\_VALUE6**

Address: Operational Base + offset (0x00B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value6<br>Power key match value 6 |

**PWM\_PWRMATCH\_VALUE7**

Address: Operational Base + offset (0x00B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value7<br>Power key match value 7 |

**PWM\_PWRMATCH\_VALUE8**

Address: Operational Base + offset (0x00B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value8<br>Power key match value 8 |

**PWM\_PWRMATCH\_VALUE9**

Address: Operational Base + offset (0x00BC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:0       | RW          | 0x00000000         | pwrkey_match_value9<br>Power key match value 9 |

**PWM\_PWM3\_PWR\_CAPTURE\_VALUE**

Address: Operational Base + offset (0x00CC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:0       | RO          | 0x00000000         | pwrkey_capture_value<br>Power key capture value |

**PWM FILTER CTRL**

Address: Operational Base + offset (0x00D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                                                                  |
| 23         | RW          | 0x0                | pwm3_global_lock<br>PWM3 disable/enable lock to previous configuration<br>0: PWM3 disable lock to previous configuration<br>1: PWM3 enable lock to previous configuration |
| 22         | RW          | 0x0                | pwm2_global_lock<br>PWM2 disable/enable lock to previous configuration<br>0: PWM2 disable lock to previous configuration<br>1: PWM2 enable lock to previous configuration |
| 21         | RW          | 0x0                | Pwm1_global_lock<br>PWM1 disable/enable lock to previous configuration<br>0: PWM1 disable lock to previous configuration<br>1: PWM1 enable lock to previous configuration |
| 20         | RW          | 0x0                | Pwm0_global_lock<br>PWM0 disable/enable lock to previous configuration<br>0: PWM0 disable lock to previous configuration<br>1: PWM0 enable lock to previous configuration |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 18         | RW          | 0x0                | CH2_and_CH3_switch_en<br>1'b0: Disabled<br>1'b1: Enabled   |
| 17         | RW          | 0x0                | CH1_and_CH3_switch_en<br>1'b0: Disabled<br>1'b1: Enabled   |
| 16         | RW          | 0x0                | CH0_and_CH3_switch_en<br>1'b0: Disabled<br>1'b1: Enabled   |
| 15:13      | RO          | 0x0                | reserved                                                   |
| 12:4       | RW          | 0x000              | filter_number<br>Filter window number                      |
| 3          | RW          | 0x0                | CH3_input_filter_enable<br>1'b0: Disabled<br>1'b1: Enabled |
| 2          | RW          | 0x0                | CH2_input_filter_enable<br>1'b0: Disabled<br>1'b1: Enabled |
| 1          | RW          | 0x0                | CH1_input_filter_enable<br>1'b0: Disabled<br>1'b1: Enabled |
| 0          | RW          | 0x0                | CH0_input_filter_enable<br>1'b0: Disabled<br>1'b1: Enabled |

**PWM\_PWM0\_OFFSET**

Address: Operational Base + offset (0x00E0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | Channel Output Offset<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the offset of the output waveform.<br><br>This value is based on the PWM clock. The value ranges from 0 to (period-duty).<br><br>This register takes effective when output aligned mode is invalid. |

**PWM\_PWM1\_OFFSET**

Address: Operational Base + offset (0x00E4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | Channel Output Offset<br>If PWM is operated at the continuous mode or one-shot mode, this value defines the offset of the output waveform.<br><br>This value is based on the PWM clock. The value ranges from 0 to (period-duty).<br><br>This register takes effective when output aligned mode is invalid. |

**PWM\_PWM2\_OFFSET**

Address: Operational Base + offset (0x00E8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>Channel Output Offset<br/>If PWM is operated at the continuous mode or one-shot mode, this value defines the offset of the output waveform.</p> <p>This value is based on the PWM clock. The value ranges from 0 to (period-duty).</p> <p>This register takes effective when output aligned mode is invalid.</p> |

**PWM\_PWM3\_OFFSET**

Address: Operational Base + offset (0x00EC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>Channel Output Offset<br/>If PWM is operated at the continuous mode or one-shot mode, this value defines the offset of the output waveform.</p> <p>This value is based on the PWM clock. The value ranges from 0 to (period-duty).</p> <p>This register takes effective when output aligned mode is invalid.</p> |

**PWM\_IR\_TRANS\_CTRL**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                                                                                                      |
| 12:8       | RW          | 0x1f               | PWM IR Trans length within one frame<br>0x00~0x1F represent data length 1~32                                                  |
| 7:4        | RW          | 0x0                | PWM IR Trans format<br>0:NEC with simple repeat code<br>1:NEC with full repeat code<br>2:TC9012<br>3:SONY<br>0x4~0xf:reserved |
| 3:2        | RO          | 0x0                | reserved                                                                                                                      |
| 1          | RO          | 0x1                | PWM IR State Idle<br>0:PWM IR Trans Busy<br>1:PWM IR Trans Idle                                                               |
| 0          | RW          | 0x0                | PWM IR Trans Out enable<br>0:disable PWM IR Trans Out Function<br>1:enable PWM IR Trans Out Function                          |

**PWM\_IR\_TRANS\_PRE**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:16      | RW          | 0x1194             | PWM IR Trans Out High Preload<br>IR Trans Out High Preload Register |
| 15:0       | RW          | 0x2328             | PWM IR Trans Out Low Preload<br>IR Trans Out Low Preload Register   |

**PWM\_IR\_TRANS\_SPRE**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                            |
| 15:0       | RW          | 0x08ca             | PWM IR Trans Out Low Simple Preload<br>PWM IR Trans Out Low Simple Preload Register |

**PWM IR TRANS LD**

Address: Operational Base + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                  |
| 15:0       | RW          | 0x0230             | PWM IR Trans Out Data Low Period<br>IR Trans Out Data Low Period Register |

**PWM IR TRANS HD**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:16      | RW          | 0x069a             | IR Trans Out High Period For One<br>IR Trans Out High Period For One Register   |
| 15:0       | RW          | 0x0230             | IR Trans Out High Period For Zero<br>IR Trans Out High Period For Zero Register |

**PWM IR TRANS BURST FRAME**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                |
| 29:20      | RW          | 0x226              | PWM IR Trans Out Burst Period<br>PWM IR Trans Out Burst Period Register |
| 19:18      | RO          | 0x0                | reserved                                                                |
| 17:0       | RW          | 0x1a5e0            | PWM IR Trans Out Frame Period Register<br>PWM IR Trans Out Frame Period |

**PWM IR TRANS DATA VALUE**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | PWM IR Trans Out Value<br>PWM IR Trans Out Value Register |

## 12.5 Interface Description

Table 12-1 PWM Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>                                                                             | <b>IOMUX Setting</b>                             |
|-------------------|------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------|
| PWM0m0            | I/O              | VICAP_D0_M1/AVS_ARM/PWM0_M0/GPIO1_A2_d                                                      | VCCIO1_IOC_GP<br>IO1A_IOMUX_S<br>EL_L[10:8]=3'h1 |
| PWM0m1            | I/O              | DSMAUDIO_P/PWM0_M1/SPI0_CS1n_M0/UART5_RX_M1/I2C3_SDA_M1/VICAP_VSYNC_M1/LCD_VSYNC/GPIO1_D2_d | VCCIO6_IOC_GP<br>IO1D_IOMUX_S<br>EL_L[10:8]=3'h6 |
| PWM1m0            | I/O              | PWM1_M0/PMIC_SLEEP_M0/GPIO0_A4_d                                                            | PMU_IOC_GPIO0A_IOMUX_SEL_H[2:0]=3'h2             |
| PWM1m1            | I/O              | PWM1_M1/ADCIN1/GPIO4_C1_z                                                                   | VCCIO2_IOC_GP<br>IO4C_IOMUX_S                    |

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>                                                                       | <b>IOMUX Setting</b>                              |
|-------------------|------------------|---------------------------------------------------------------------------------------|---------------------------------------------------|
|                   |                  |                                                                                       | EL_L[6:4]=3'h2                                    |
| PWM1m2            | I/O              | PWM1_M2/VICAP_D15/GPIO3_D3_d                                                          | VCCIO7_IOC_GP<br>IO3D_IOMUX_S<br>EL_L[14:12]=3'h2 |
| PWM2m0            | I/O              | TEST_CLK6_OUT/PWM2_M0/UART0_TX_M0/GPIO0_A1_d                                          | PMU_IOC_GPIO0A_IOMUX_SEL_L[6:4]=3'h2              |
| PWM2m1            | I/O              | FLASH_TRIG_OUT/I2C3_SCL_M0/PWM2_M1/LCD_D14/I2S0_SDO2_SD12/UART0_RTSN_M1/GPIO2_A6_d    | VCCIO5_IOC_GP<br>IO2A_IOMUX_S<br>EL_H[10:8]=3'h4  |
| PWM2m2            | I/O              | SDMMC1_D1_M1/SPI0_CS0n_M0/PWM2_M2/VICAP_D2_M1/LCD_D7/GPIO1_C0_d                       | VCCIO6_IOC_GP<br>IO1C_IOMUX_S<br>EL_L[2:0]=3'h3   |
| PWM3m0            | I/O              | TEST_CLK7_OUT//PWM3_IR_M0/GPIO0_A2_d                                                  | PMU_IOC_GPIO0A_IOMUX_SEL_L[10:8]=3'h1             |
| PWM3m1            | I/O              | PWM3_IR_M1/UART4_RX_M0/GPIO1_B0_d                                                     | VCCIO1_IOC_GP<br>IO1B_IOMUX_SEL_L_L[2:0]=3'h2     |
| PWM3m2            | I/O              | UART3_TX_M1/UART5_RTSN_M1/PWM3_IR_M2/VICAP_CLKIN_M1/LCD_DEN/GPIO1_D0_d                | VCCIO6_IOC_GP<br>IO1D_IOMUX_S<br>EL_L[2:0]=3'h3   |
| PWM4m0            | I/O              | PWM4_M0/PMU_DEBUG/I2C2_SDA_M0/UART3_RX_M0/GPIO1_A1_d                                  | VCCIO1_IOC_GP<br>IO1A_IOMUX_S<br>EL_L[6:4]=3'h4   |
| PWM4m1            | I/O              | PRELIGHT_TRIG_OUT/I2C3_SDA_M0/PWM4_M1/LCD_D15/I2S0_SDO1_SD13/UART0_CTSN_M1/GPIO2_A7_d | VCCIO5_IOC_GP<br>IO2A_IOMUX_S<br>EL_H[14:12]=3'h4 |
| PWM4m2            | I/O              | SDMMC1_D0_M1/SPI0_CLK_M0/PWM4_M2/VICAP_D3_M1/LCD_D6/GPIO1_C1_d                        | VCCIO6_IOC_GP<br>IO1C_IOMUX_S<br>EL_L[6:4]=3'h3   |
| PWM5m0            | I/O              | PWM5_M0/UART1_RTSN_M0/I2C1_SCL_M0/GPIO0_A5_d                                          | PMU_IOC_GPIO0A_IOMUX_SEL_H[6:4]=3'h3              |
| PWM5m1            | I/O              | TEST_CLK4_OUT/PWM5_M1/LCD_D16/I2C1_SDA_M1/UART0_RX_M1/GPIO2_B0_d                      | VCCIO5_IOC_GP<br>IO2B_IOMUX_SEL_L_L[2:0]=3'h4     |
| PWM5m2            | I/O              | SPI0_MOSI_M0/SDMMC1_CLK_M1/I2C4_SCL_M1/PWM5_M2/VICAP_D4_M1/LCD_D5/GPIO1_C2_d          | VCCIO6_IOC_GP                                     |

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>                                                              | <b>IOMUX Setting</b>                              |
|-------------------|------------------|------------------------------------------------------------------------------|---------------------------------------------------|
|                   |                  |                                                                              | IO1C_IOMUX_S<br>EL_L[10:8]=3'h3                   |
| PWM6m0            | I/O              | PWM6_M0/UART1_CTSN_M0/I2C1_SDA_M0/GPIO0_A6_d                                 | PMU_IOC_GPIO0A_IOMUX_SEL_H[10:8]=3'h3             |
| PWM6m1            | I/O              | TEST_CLK5_OUT/PWM6_M1/LCD_D17/I2C1_SCL_M1/UART0_TX_M1/GPIO2_B1_d             | VCCIO5_IOC_GP<br>IO2B_IOMUX_SEL_L_L[6:4]=3'h4     |
| PWM6m2            | I/O              | SPI0_MISO_M0/SDMMC1_CMD_M1/I2C4_SDA_M1/PWM6_M2/VICAP_D5_M1/LCD_D4/GPIO1_C3_d | VCCIO6_IOC_GP<br>IO1C_IOMUX_S<br>EL_L[14:12]=3'h3 |
| PWM7m0            | I/O              | PWM7_IR_M0/I2C2_SCL_M0/UART3_TX_M0/GPIO1_A0_d                                | VCCIO1_IOC_GP<br>IO1A_IOMUX_S<br>EL_L[2:0]=3'h3   |
| PWM7m1            | I/O              | VICAP_D1_M1/SPI1_CS1n_M0/PWM7_IR_M1/UART4_TX_M0/GPIO1_B1_d                   | VCCIO1_IOC_GP<br>IO1B_IOMUX_SEL_L_L[6:4]=3'h2     |
| PWM7m2            | I/O              | MIPI_REFCLK_OUT1/PWM7_IR_M2/VICAP_D10/GPIO3_C6_d                             | VCCIO7_IOC_GP<br>IO3C_IOMUX_S<br>EL_H[10:8]=3'h2  |
| PWM8m0            | I/O              | PWM8_M0/TEST_CLK1_OUT/UART2_RX_M0/SDMMC0_D0/GPIO3_A3_u                       | VCCIO4_IOC_GP<br>IO3A_IOMUX_S<br>EL_L[14:12]=3'h4 |
| PWM8m1            | I/O              | SDMMC1_D3_M1/UART4_RX_M1/PWM8_M1/VICAP_D6_M1/LCD_D3/GPIO1_C4_d               | VCCIO6_IOC_GP<br>IO1C_IOMUX_S<br>EL_H[2:0]=3'h3   |
| PWM9m0            | I/O              | PWM9_M0/TEST_CLK0_OUT/UART2_TX_M0/SDMMC0_D1/GPIO3_A2_u                       | VCCIO4_IOC_GP<br>IO3A_IOMUX_S<br>EL_L[10:8]=3'h4  |
| PWM9m1            | I/O              | SDMMC1_D2_M1/UART4_TX_M1/PWM9_M1/VICAP_D7_M1/LCD_D2/GPIO1_C5_d               | VCCIO6_IOC_GP<br>IO1C_IOMUX_S<br>EL_H[6:4]=3'h3   |
| PWM10_m0          | I/O              | PWM10_M0/LPMCU_JTAG_TCK_M1/I2C0_SCL_M2/UART5_RTSN_M0/SDMMC0_CLK/GPIO3_A4_d   | VCCIO4_IOC_GP<br>IO3A_IOMUX_S<br>EL_L[2:0]=3'h5   |
| PWM10_m1          | I/O              | UART4_RTSN_M1/PWM10_M1/VICAP_D8_M1/LCD_D1/GPIO1_C6_d                         | VCCIO6_IOC_GP<br>IO1C_IOMUX_S<br>EL_H[10:8]=3'h3  |

| Module Pin | Direction | Pad Name                                                                           | IOMUX Setting                                     |
|------------|-----------|------------------------------------------------------------------------------------|---------------------------------------------------|
| PWM10_m2   | I/O       | UART3_RX_M1/UART5_CTSN_M1/PWM10_M2/VICAP_HSYNC_M1/LCD_HSYNC/GPIO1_D1_d             | VCCIO6_IOC_GP<br>IO1D_IOMUX_S<br>EL_L[6:4]=3'h3   |
| PWM11_m0   | I/O       | PWM11_IR_M0/LPMCU_JTAG_TMS_M1/I2C0_SDA_M2/UART5_CTSN_M0/SDMMC0_CMD/GPIO3_A5_u      | VCCIO4_IOC_GP<br>IO3A_IOMUX_S<br>EL_H[6:4]=3'h5   |
| PWM11_m1   | I/O       | UART4_CTSN_M1/PWM11_IR_M1/VICAP_D9_M1/LCD_D0/GPIO1_C7_d                            | VCCIO6_IOC_GP<br>IO1C_IOMUX_S<br>EL_H[14:12]=3'h3 |
| PWM11_m2   | I/O       | DSMAUDIO_N//PWM11_IR_M2/UART5_TX_M1/I2C3_SCL_M1/VICAP_CLKOUT_M1/LCD_CLK/GPIO1_D3_d | VCCIO6_IOC_GP<br>IO1D_IOMUX_S<br>EL_L[14:12]=3'h5 |

Notes: I=input, O=output, I/O=input/output, bidirectional

## 12.6 Application Notes

### 12.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.

### 12.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 transfer 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.

### 12.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\_LPREG, 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.

#### **12.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 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.

#### **12.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.

#### **12.6.6 Multi-channel synchronous start Usage Flow**

1. Set PWM\_PWMx\_CTRL.pwm\_en to '0' to disable the PWM channel.
2. Set PWM\_FILTER\_CTRL.PWMx\_global\_lock '1' to lock previous configuration.
3. 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.
4. 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.
5. Set the PWM\_PWMx\_CTRL.rpt if the channel is desired to work in the one-shot mode.
6. Configure the channel to work in the one-shot mode or the continuous mode.
7. Enable the PWM\_INT\_EN.chx\_int\_en to enable the interrupt generation if the channel is desired to work in the one-shot mode.
8. Set PWM\_PWMx\_CTRL.pwm\_en to '1' to start pwm.
9. Set PWM\_FILTER\_CTRL.PWMx\_global\_lock '0' to unlock previous configuration and the

- latest configuration will be take effective immediately.
10. 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.

### **12.6.7 Multi-channel synchronous stop or frequency change Usage Flow**

1. Set PWM\_FILTER\_CTRL.PWMx\_global\_lock '1' to lock previous configuration.
2. Set PWM\_PWMx\_CTRL.pwm\_en to '0' to stop pwm or set PWM\_PWMx\_PERIOD\_HPC and PWM\_PWMx\_DUTY\_LPC to change frequency.
3. Set PWM\_FILTER\_CTRL.PWMx\_global\_lock '0' to unlock previous configuration and the latest configuration will be take effective immediately.

### **12.6.8 IR transmission Usage Flow**

1. Set PWM\_PWM2\_CTRL.pwm\_en to '0' to disable the PWM channel.
2. Set PWM\_IR\_TRANS\_CTRL.transout\_en to '1' enable PWM IR Trans Out Function.
3. Set PWM\_IR\_TRANS\_CTRL.format, PWM\_IR\_TRANS\_CTRL.length, PWM\_IR\_TRANS\_PRE, PWM\_IR\_TRANS\_DATA\_VALUE .et.
4. Choose the prescale factor and the scale factor for clk\_pwm by programming PWM\_PWM2\_CTRL.prescale and PWM\_PWM2\_CTRL.scale, and select the clock needed by setting PWM\_PWM2\_CTRL.clk\_sel. The clock should be 1 MHz after division.
5. Choose the output mode by setting PWM\_PWM2\_CTRL.output\_mode, and set the duty polarity and inactive polarity by programming PWM\_PWM2\_CTRL.duty\_pol and PWM\_PWM2\_CTRL.inactive\_pol.
6. Set the PWM\_PWM2\_CTRL.rpt if the channel is desired to work in the one-shot mode.
7. Enable the channel by writing '1' to PWM\_PWM3\_CTRL.pwm\_en bit to start the channel.
8. If you want to disable the output waveform, write '0' PWM\_PWM2\_CTRL.pwm\_en, and the channel will be disable at the end of one frame. Please refer to PWM\_IR\_TRANS\_CTRL.idle to see if the channel is true stop.

### **12.6.9 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 13 UART

### 13.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 6 independent UART controller: UART0-UART5
- All contain two 64 Bytes FIFOs for data receive and transmit
- All 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

### 13.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. 13-1 UART Architecture

#### 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 clock along 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.

### Serial Receiver

Converts the serial data character (as specified by the control register) received to parallel form. Parity error detection, framing error detection and line break detection is carried out in this block.

## 13.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. 13-2 UART Serial protocol

### 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.



Fig. 13-3 UART baud rate

### 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 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. 13-4 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. 13-5 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)



Fig. 13-6 UART AUTO CTS TIMING

## 13.4 Register Description

### 13.4.1 Registers Summary

| Name       | Offset | Size | Reset Value | Description                      |
|------------|--------|------|-------------|----------------------------------|
| UART_RBR   | 0x0000 | W    | 0x00000000  | Receive Buffer Register          |
| UART_DLL   | 0x0000 | W    | 0x00000000  | Divisor Latch Low                |
| UART_THR   | 0x0000 | W    | 0x00000000  | Transmit Buffer Register         |
| UART_DLH   | 0x0004 | W    | 0x00000000  | Divisor Latch High               |
| UART_IER   | 0x0004 | W    | 0x00000000  | Interrupt Enable Register        |
| UART_FCR   | 0x0008 | W    | 0x00000000  | FIFO Enable                      |
| UART_IIR   | 0x0008 | W    | 0x00000001  | Interrupt Identity Register      |
| UART_LCR   | 0x000C | W    | 0x00000000  | Line Control Register            |
| UART_MCR   | 0x0010 | W    | 0x00000000  | Modem Control Register           |
| UART_LSR   | 0x0014 | W    | 0x00000060  | Line Status Register             |
| UART_MSR   | 0x0018 | W    | 0x00000000  | Modem Status Register            |
| UART_SCR   | 0x001C | W    | 0x00000000  | Scratchpad Register              |
| UART_SRBR  | 0x0030 | W    | 0x00000000  | Shadow Receive Buffer Register   |
| UART_STHR  | 0x0030 | W    | 0x00000000  | Shadow Transmit Holding Register |
| UART_FAR   | 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    | 0x00000006  | UART Status Register             |
| UART_TFL   | 0x0080 | W    | 0x00000000  | Transmit FIFO level              |
| UART_RFL   | 0x0084 | W    | 0x00000000  | Receive FIFO level               |
| UART_SRR   | 0x0088 | W    | 0x00000000  | 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    | 0x00000000  | Shadow FIFO enable               |
| UART_SRT   | 0x009C | W    | 0x00000000  | Shadow RCVR Trigger              |

| Name       | Offset | Size | Reset Value | Description                  |
|------------|--------|------|-------------|------------------------------|
| UART_STET  | 0x00A0 | W    | 0x00000000  | Shadow TX Empty Trigger      |
| UARTHTX    | 0x00A4 | W    | 0x00000000  | Halt TX                      |
| UART_DMASA | 0x00A8 | W    | 0x00000000  | DMA Software Acknowledge     |
| UART_CPR   | 0x00F4 | W    | 0x00043FF2  | Component Parameter Register |
| UART_UCV   | 0x00F8 | W    | 0x3430322A  | UART Component Version       |
| UART_CTR   | 0x00FC | W    | 0x44570110  | Component Type Register      |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 13.4.2 Detail Registers Description

#### UART\_RBR

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7:0  | RO   | 0x00        | <p>data_input<br/>Data byte received on the serial input port (sin) in UART mode, or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line Status Register (LCR) is set. If in non-FIFO mode (FIFO_MODE == NONE) or FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it is overwritten, resulting in an over-run error.</p> <p>If in FIFO mode (FIFO_MODE != NONE) and FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO is preserved, but any incoming data will be lost and an over-run error occurs.</p> |

#### UART\_DLL

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7:0  | RW   | 0x00        | <p>baud_rate_divisor_l<br/>Lower 8 bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set and the UART is not busy (USR[0] is zero). The output baud rate is equal to the serial clock (pclk if one clock design, sclk if two clock design (CLOCK_MODE == Enabled)) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).</p> <p>Note that with the Divisor Latch Registers (DLL and DLH) set to zero, the baud clock is disabled and no serial communications occur. Also, once the DLL is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.</p> |

#### UART\_THR

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x0000000   | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | WO   | 0x00        | <p>data_output<br/>Data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If in non-FIFO mode or FIFOs are disabled (FCR[0] = 0) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten.</p> <p>If in FIFO mode and FIFOs are enabled (FCR[0] = 1) and THRE is set, 64 characters of data may be written to the THR before the FIFO is full.. Any attempt to write data when the FIFO is full results in the write data being lost.</p> |

**UART\_DLH**

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:0  | RW   | 0x00        | <p>baud_rate_divisor_h<br/>Upper 8-bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set and the UART is not busy (USR[0] is zero). The output baud rate is equal to the serial clock (pclk if one clock design, sclk if two clock design CLOCK_MODE == Enabled)) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).</p> <p>Note that with the Divisor Latch Registers (DLL and DLH) set to zero, the baud clock is disable and no serial communications occur. Also, once the DLH is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.</p> |

**UART\_IER**

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                               |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                                  |
| 7    | RW   | 0x0         | <p>prog_thre_int_en<br/>Programmable THRE Interrupt Mode Enable that can be written to only when THRE_MODE_USER == Enabled, always readable. This is used to enable/disable the generation of THRE Interrupt.</p> <p>1'b0: Disabled<br/>1'b1: Enabled</p> |
| 6:4  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                  |
| 3    | RW   | 0x0         | <p>modem_status_int_en<br/>Enable Modem Status Interrupt. This is used to enable/disable the generation of Modem Status Interrupt. This is the fourth highest priority interrupt.</p> <p>1'b0: Disabled<br/>1'b1: Enabled</p>                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | <p>receive_line_status_int_en<br/>Enable Receiver Line Status Interrupt. This is used to enable/disable the generation of Receiver Line Status Interrupt. This is the highest priority interrupt.<br/>1'b0: Disabled<br/>1'b1: Enabled</p>                                                                                            |
| 1          | RW          | 0x0                | <p>trans_hold_empty_int_en<br/>Enable Transmit Holding Register Empty Interrupt. This is used to enable/disable the generation of Transmitter Holding Register Empty Interrupt. This is the third highest priority interrupt.<br/>1'b0: Disabled<br/>1'b1: Enabled</p>                                                                |
| 0          | RW          | 0x0                | <p>receive_data_available_int_en<br/>Enable Received Data Available Interrupt. This is used to enable/disable the generation of Received Data Available Interrupt and the Character Timeout Interrupt (if in FIFO mode and FIFOs enabled). These are the second highest priority interrupts.<br/>1'b0: Disabled<br/>1'b1: Enabled</p> |

**UART\_FCR**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:6        | WO          | 0x0                | <p>rcvr_trigger<br/>At which the Received Data Available Interrupt is generated. In auto flow control mode, it is used to determine when the rts_n signal is de-asserted. It also determines when the dma_rx_req_n signal is asserted in certain modes of operation. For details on DMA support, refer to "DMA Support". The following trigger 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 full</p>                                         |
| 5:4        | WO          | 0x0                | <p>tx_empty_trigger<br/>TX Empty Trigger. Writes have no effect when THRE_MODE_USER == Disabled. This is used to select the empty threshold level at which the THRE Interrupts are generated when the mode is active. It also determines when the dma_tx_req_n signal is asserted when in certain modes of operation. For details on DMA support, refer to " DMA Support". The following trigger levels are 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</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | WO          | 0x0                | dma_mode<br>DMA Mode. This determines the DMA signaling mode used for the dma_tx_req_n and dma_rx_req_n output signals when additional DMA handshaking signals are not selected (DMA_EXTRA == No). For details on DMA support, refer to DMA Support.<br>1'b0: Mode 0<br>1'b1: Mode 1                                                     |
| 2          | WO          | 0x0                | xmit_fifo_reset<br>XMIT FIFO Reset. This resets the control portion of the transmit FIFO and treats the FIFO as empty. This also de-asserts the DMA TX request and single signals when additional DMA handshaking signals are selected (DMA_EXTRA == YES). Note that this bit is 'self-clearing'. It is not necessary to clear this bit. |
| 1          | WO          | 0x0                | rcvr_fifo_reset<br>RCVR FIFO Reset. This resets the control portion of the receive FIFO and treats the FIFO as empty. This also de-asserts the DMA RX request and single signals when additional DMA handshaking signals are selected (DMA_EXTRA == YES). Note that this bit is 'self-clearing'. It is not necessary to clear this bit.  |
| 0          | WO          | 0x0                | fifo_en<br>FIFO Enable. This enables/disables the transmit (XMIT) and receive (RCVR) FIFOs. Whenever the value of this bit is changed both the XMIT and RCVR controller portion of FIFOs is reset.                                                                                                                                       |

**UART\_IIR**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7:6        | RO          | 0x0                | fifos_en<br>FIFOs Enabled. This is used to indicate whether the FIFOs are enabled or disabled.<br>2'b00: Disabled<br>2'b11: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3:0        | RO          | 0x1                | int_id<br>Interrupt ID. This indicates the highest priority pending interrupt which can be one of the following types:<br>4'b0000: Modem status<br>4'b0001: No interrupt pending<br>4'b0010: THR empty<br>4'b0100: Received data available<br>4'b0110: Receiver line status<br>4'b0111: Busy detect<br>4'b1100: Character timeout<br>The interrupt priorities are split into four levels that are detailed in Table X.<br>Bit 3 indicates an interrupt can only occur when the FIFOs are enabled and used to distinguish a Character Timeout condition interrupt. |

**UART\_LCR**

Address: Operational Base + offset (0x000C)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RW   | 0x0         | div_lat_access<br>Divisor Latch Access Bit. Writable only when UART is not busy (USR[0] is zero), always readable. This bit is used to enable reading and writing of the Divisor Latch register (DLL and DLH) to set the baud rate of the UART. This bit must be cleared after initial baud rate setup in order to access other registers.                                                                                                                                                                                                                                                                                                   |
| 6   | RW   | 0x0         | break_ctrl<br>Break Control Bit. This is used to cause a break condition to be transmitted to the receiving device. If set to one the serial output is forced to the spacing (logic 0) state. When not in Loopback Mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared. If SIR_MODE == Enabled and active (MCR[6] set to one) the sir_out_n line is continuously pulsed. When in Loopback Mode, the break condition is internally looped back to the receiver and the sir_out_n line is forced low.                                                                                                    |
| 5   | RW   | 0x0         | stick_parity<br>If UART_16550_COMPATIBLE = NO, then writable only when UART is not busy (USR[0] is 0); otherwise always writable and always readable. This bit is used to force parity value. When PEN, EPS and Stick Parity are set to 1, the parity bit is transmitted and checked as logic 0. If PEN and Stick Parity are set to 1 and EPS is a logic 0, then parity bit is transmitted and checked as a logic 1. If this bit is set to 0, Stick Parity is disabled.                                                                                                                                                                      |
| 4   | RW   | 0x0         | even_parity_sel<br>Even Parity Select. Writable only when UART is not busy (USR[0] is zero), always readable. This is used to select between even and odd parity, when parity is enabled (PEN set to one). If set to one, an even number of logic 1s is transmitted or checked. If set to zero, an odd number of logic 1s is transmitted or checked.                                                                                                                                                                                                                                                                                         |
| 3   | RW   | 0x0         | parity_en<br>Parity Enable. Writable only when UART is not busy (USR[0] is zero), always readable. This bit is used to enable and disable parity generation and detection in transmitted and received serial character respectively.<br>1'b0: Parity disabled<br>1'b1: Parity enabled                                                                                                                                                                                                                                                                                                                                                        |
| 2   | RW   | 0x0         | stop_bits_num<br>Number of stop bits. Writable only when UART is not busy (USR[0] is zero), always readable. This is used to select the number of stop bits per character that the peripheral transmits and receives. If set to zero, one stop bit is transmitted in the serial data. If set to one and the data bits are set to 5 (LCR[1:0] set to zero) one and a half stop bits is transmitted. Otherwise, two stop bits are transmitted. Note that regardless of the number of stop bits selected, the receiver checks only the first stop bit.<br>1'b0: 1 stop bit<br>1'b1: 1.5 stop bits when DLS (LCR[1:0]) is zero, else 2 stop bit. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | <p>data_length_sel<br/>Data Length Select. Writable only when UART is not busy (USR[0] is zero), always readable. This is used to select the number of data bits per character that the peripheral transmits and receives.</p> <p>The number of bit that may be selected areas follows:</p> <ul style="list-style-type: none"> <li>2'b00: 5 bits</li> <li>2'b01: 6 bits</li> <li>2'b10: 7 bits</li> <li>2'b11: 8 bits</li> </ul> |

**UART MCR**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6          | RW          | 0x0                | <p>sir_mode_en<br/>SIR Mode Enable. Writeable only when SIR_MODE == Enabled, always readable. This is used to enable/disable the IrDA SIR Mode features as described in "IrDA 1.0 SIR Protocol".</p> <ul style="list-style-type: none"> <li>1'b0: IrDA SIR Mode disabled</li> <li>1'b1: IrDA SIR Mode enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5          | RW          | 0x0                | <p>auto_flow_ctrl_en<br/>Auto Flow Control Enable. Writeable only when AFCE_MODE == Enabled, always readable. When FIFOs are enabled and the Auto Flow Control Enable (AFCE) bit is set, Auto Flow Control features are enabled as described in "Auto Flow Control".</p> <ul style="list-style-type: none"> <li>1'b0: Auto Flow Control Mode disabled</li> <li>1'b1: Auto Flow Control Mode enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                       |
| 4          | RW          | 0x0                | <p>loopback<br/>LoopBack Bit. This is used to put the UART into a diagnostic mode for test purposes. If operating in UART mode (SIR_MODE != Enabled or not active, MCR[6] set to zero), data on the sout line is held high, while serial data output is looped back to the sin line, internally. In this mode all the interrupts are fully functional. Also, in loopback mode, the modem control inputs (dsr_n, cts_n, ri_n, dcd_n) are disconnected and the modem control outputs (dtr_n, rts_n, out1_n, out2_n) are looped back to the inputs, internally. If operating in infrared mode (SIR_MODE == Enabled AND active, MCR[6] set to one), data on the sir_out_n line is held low, while serial data output is inverted and looped back to the sir_in line.</p> |
| 3          | RW          | 0x0                | <p>out2<br/>OUT2. This is used to directly control the user-designated Output2 (out2_n) output. The value written to this location is inverted and driven out on out2_n, that is:</p> <ul style="list-style-type: none"> <li>1'b0: Out2_n de-asserted (logic 1)</li> <li>1'b1: Out2_n asserted (logic 0)</li> </ul> <p>Note that in Loopback mode (MCR[4] set to one), the out2_n output is held inactive high while the value of this location is internally looped back to an input.</p>                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | <p>out1<br/>OUT1. This is used to directly control the user-designated Output1 (out1_n) output. The value written to this location is inverted and driven out on out1_n, that is:</p> <p>1'b0: Out1_n de-asserted (logic 1)<br/>1'b1: Out1_n asserted (logic 0)</p> <p>Note that in Loopback mode (MCR[4] set to one), the out1_n output is held inactive high while the value of this location is internally looped back to an input.</p>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1          | RW          | 0x0                | <p>req_to_send<br/>Request to Send. This is used to directly control the Request to Send (rts_n) output. The Request To Send (rts_n) output is used to inform the modem or data set that the UART is ready to exchange data. When Auto RTS Flow Control is not enabled (MCR[5] set to zero), the rts_n signal is set low by programming MCR[1] (RTS) to a high. In Auto Flow Control, AFCE_MODE == Enabled and active (MCR[5] set to one) and FIFOs enable (FCR[0] set to one), the rts_n output is controlled in the same way, but is also gated with the receiver FIFO threshold trigger (rts_n is inactive high when above the threshold). The rts_n signal is de-asserted when MCR[1] is set low. Note that in Loopback mode (MCR[4] set to one), the rts_n output is held inactive high while the value of this location is internally looped back to an input.</p> |
| 0          | RW          | 0x0                | <p>data_terminal_ready<br/>Data Terminal Ready. This is used to directly control the Data Terminal Ready (dtr_n) output. The value written to this location is inverted and driven out on dtr_n, that is:</p> <p>1'b0: dtr_n de-asserted (logic 1)<br/>1'b1: dtr_n asserted (logic 0)</p> <p>The Data Terminal Ready output is used to inform the modem or data set that the UART is ready to establish communications. Note that in Loopback mode (MCR[4] set to one), the dtr_n output is held inactive</p>                                                                                                                                                                                                                                                                                                                                                            |

**UART LSR**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7          | RO          | 0x0                | <p>receiver_fifo_error<br/>Receiver FIFO Error bit. This bit is only relevant when FIFO_MODE != NONE AND FIFOs are enabled (FCR[0] set to one). This is used to indicate if there is at least one parity error, framing error, or break indication in the FIFO.</p> <p>1'b0: No error in RX FIFO<br/>1'b1: Error in RX FIFO</p> <p>This bit is cleared when the LSR is read and the character with the error is at the top of the receiver FIFO and there are no subsequent errors in the FIFO.</p> |
| 6          | RO          | 0x1                | <p>trans_empty<br/>Transmitter Empty bit. If in FIFO mode (FIFO_MODE != NONE) and FIFOs enabled (FCR[0] set to one), this bit is set whenever the Transmitter Shift Register and the FIFO are both empty. If in non-FIFO mode or FIFOs are disabled, this bit is set whenever the Transmitter Holding Register and the Transmitter Shift Register are both empty.</p>                                                                                                                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RO   | 0x1         | <p>trans_hold_reg_empty<br/>Transmit Holding Register Empty bit. If THRE_MODE_USER == Disabled or 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.</p> <p>This bit is set whenever data is transferred from the THR or TX 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 THRE_MODE_USER == Enabled AND FIFO_MODE != NONE and both modes are active (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.</p>                                                                                                                     |
| 4   | RO   | 0x0         | <p>break_int<br/>Break Interrupt bit. This is used to indicate the detection of a break sequence on the serial input data. If in UART mode (SIR_MODE == Disabled), it is set whenever the serial input, sin, is held in a logic '0' state for longer than the sum of start time + data bits + parity + stop bits. If in infrared mode (SIR_MODE == Enabled), it is set whenever the serial input, sir_in, is continuously pulsed to logic '0' for longer than the sum of start time + data bits + parity + stop bits. A break condition on serial input causes one and only one character, consisting of all zeros, to be received by the UART. In the FIFO mode, the character associated with the break condition is carried through the FIFO and is revealed when the character is at the top of the FIFO.</p> <p>Reading the LSR clears the BI bit. In the non-FIFO mode, the BI indication occurs immediately and persists until the LSR is read.</p> |
| 3   | RO   | 0x0         | <p>framing_error<br/>Framing Error bit. This is used to indicate the occurrence of a framing error in the receiver. A framing error occurs when the receiver does not detect a valid STOP bit in the received data. In the FIFO mode, since the framing error is associated with a character received, it is revealed when the character with the framing error is at the top of the FIFO. When a framing error occurs, the UART tries to resynchronize. It does this by assuming that the error was due to the start bit of the next character and then continues receiving the other bit i.e. data, and/or parity and stop. It should be noted that the Framing Error (FE) bit (LSR[3]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).</p> <p>1'b0: No framing error<br/>1'b1: Framing error</p> <p>Reading the LSR clears the FE bit.</p>                                                                 |
| 2   | RO   | 0x0         | <p>parity_error<br/>Parity Error bit. This is used to indicate the occurrence of a parity error in the receiver if the Parity Enable (PEN) bit (LCR[3]) is set. In the FIFO mode, since the parity error is associated with a character received, it is revealed when the character with the parity error arrives at the top of the FIFO. It should be noted that the Parity Error (PE) bit (LSR[2]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).</p> <p>1'b0: No parity error<br/>1'b1: Parity error</p> <p>Reading the LSR clears the PE bit.</p>                                                                                                                                                                                                                                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | RO   | 0x0         | <p>overrun_error<br/>Overrun error bit. 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. In the non-FIFO mode, the OE bit is set when a new character arrives in the receiver before the previous character was read from the RBR. When this happens, the data in the RBR is overwritten. In the FIFO mode, an overrun error occurs when the FIFO is full and a new character arrives at the receiver. The data in the FIFO is retained and the data in the receive shift register is lost.</p> <p>1'b0: No overrun error<br/>1'b1: Overrun error<br/>Reading the LSR clears the OE bit.</p> |
| 0   | RO   | 0x0         | <p>data_ready<br/>Data Ready bit. This is used to indicate that the receiver contains at least one character in the RBR or the receiver FIFO.</p> <p>1'b0: No data ready<br/>1'b1: Data ready<br/>This bit is cleared when the RBR is read in non-FIFO mode, or when the receiver FIFO is empty, in FIFO mode.</p>                                                                                                                                                                                                                                                                                                                                                                           |

**UART MSR**

Address: Operational Base + offset (0x0018)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7    | RO   | 0x0         | <p>data_carrier_detect<br/>Data Carrier Detect. This is used to indicate the current state of the modem control line dcd_n. This bit is the complement of dcd_n. When the Data Carrier Detect input (dcd_n) is asserted it is an indication that the carrier has been detected by the modem or data set.</p> <p>1'b0: dcd_n input is de-asserted (logic 1)<br/>1'b1: dcd_n input is asserted (logic 0)<br/>In Loopback Mode (MCR[4] set to one), DCD is the same as MCR[3] (Out2).</p>   |
| 6    | RO   | 0x0         | <p>ring_indicator<br/>Ring Indicator. This is used to indicate the current state of the modem control line ri_n. This bit is the complement of ri_n. When the Ring Indicator input (ri_n) is asserted it is an indication that a telephone ringing signal has been received by the modem or data set.</p> <p>1'b0: ri_n input is de-asserted (logic 1)<br/>1'b1: ri_n input is asserted (logic 0)<br/>In Loopback Mode (MCR[4] set to one), RI is the same as MCR[2] (Out1).</p>         |
| 5    | RO   | 0x0         | <p>data_set_ready<br/>Data Set Ready. This is used to indicate the current state of the modem control line dsr_n. This bit is the complement of dsr_n. When the Data Set Ready input (dsr_n) is asserted it is an indication that the modem or data set is ready to establish communications with the UART.</p> <p>1'b0: dsr_n input is de-asserted (logic 1)<br/>1'b1: dsr_n input is asserted (logic 0)<br/>In Loopback Mode (MCR[4] set to one), DSR is the same as MCR[0] (DTR).</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | <p>clear_to_send<br/>Clear to Send. This is used to indicate the current state of the modem control line cts_n. This bit is the complement of cts_n. When the Clear to Send input (cts_n) is asserted it is an indication that the modem or data set is ready to exchange data with the UART.</p> <p>1'b0: cts_n input is de-asserted (logic 1)<br/>1'b1: cts_n input is asserted (logic 0)</p> <p>In Loopback Mode (MCR[4] = 1), CTS is the same as MCR[1] (RTS).</p>                                                                                                                                               |
| 3          | RO          | 0x0                | <p>delta_data_carrier_detect<br/>Delta Data Carrier Detect. This is used to indicate that the modem control line dcd_n has changed since the last time the MSR was read.</p> <p>1'b0: No change on dcd_n since last read of MSR<br/>1'b1: Change on dcd_n since last read of MSR</p> <p>Reading the MSR clears the DDCD bit. In Loopback Mode (MCR[4] = 1), DDCD reflects changes on MCR[3] (Out2). Note, if the DDCD bit is not set and the dcd_n signal is asserted (low) and a reset occurs (software or otherwise), then the DDCD bit is set when the reset is removed if the dcd_n signal remains asserted.</p> |
| 2          | RO          | 0x0                | <p>trailing_edge_ring_indicator<br/>Trailing Edge of Ring Indicator. This is used to indicate that a change on the input ri_n (from an active-low to an inactive-high state) has occurred since the last time the MSR was read.</p> <p>1'b0: No change on ri_n since last read of MSR<br/>1'b1: Change on ri_n since last read of MSR</p> <p>Reading the MSR clears the TERI bit. In Loopback Mode (MCR[4] = 1), TERI reflects when MCR[2] (Out1) has changed state from a high to a low.</p>                                                                                                                        |
| 1          | RO          | 0x0                | <p>delta_data_set_ready<br/>Delta Data Set Ready. This is used to indicate that the modem control line dsr_n has changed since the last time the MSR was read.</p> <p>1'b0: No change on dsr_n since last read of MSR<br/>1'b1: Change on dsr_n since last read of MSR</p> <p>Reading the MSR clears the DDSR bit. In Loopback Mode (MCR[4] = 1), DDSR reflects changes on MCR[0] (DTR). Note, if the DDSR bit is not set and the dsr_n signal is asserted (low) and a reset occurs (software or otherwise), then the DDSR bit is set when the reset is removed if the dsr_n signal remains asserted.</p>            |
| 0          | RO          | 0x0                | <p>delta_clear_to_send<br/>Delta Clear to Send. This is used to indicate that the modem control line cts_n has changed since the last time the MSR was read.</p> <p>1'b0: No change on ctsdsr_n since last read of MSR<br/>1'b1: Change on ctsdsr_n since last read of MSR</p> <p>Reading the MSR clears the DCTS bit. In Loopback Mode (MCR[4] = 1), DCTS reflects changes on MCR[1] (RTS). Note, if the DCTS bit is not set and the cts_n signal is asserted (low) and a reset occurs (software or otherwise), then the DCTS bit is set when the reset is removed if the cts_n signal remains asserted.</p>        |

**UART SCR**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                              |
| 7:0        | RW          | 0x00               | temp_store_space<br>Scratchpad register. This register is for programmers to use as a temporary storage space. It has no defined purpose in the UART. |

**UART SRBR**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:0        | RO          | 0x00               | shadow_rbr<br>This is a shadow register for the RBR and has been allocated sixteen 32-bit locations (0x30-0x6c) so as to accommodate burst accesses from the master. This register contains the data byte received on the serial input port (sin) in UART mode or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line status Register (LSR) is set. If in non-FIFO mode (FIFO_MODE == NONE) or FIFOs are disabled (FCR[0] set to zero), the data in the RBR must be read before the next data arrives, otherwise it is overwritten, resulting in an overrun error. If in FIFO mode (FIFO_MODE != NONE) and FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO are preserved, but any incoming data is lost. An overrun error also occurs. |

**UART STHR**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:0        | WO          | 0x00               | shadow_thr<br>This is a shadow register for the THR and has been allocated sixteen 32-bit locations(0x30-0x6c) so as to accommodate burst accesses from the master. This register contains data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set. If in non-FIFO mode or FIFOs are disabled (FCR[0] set to zero) and THRE is set, writing a single character to the THR clears the THRE. Any additional writes to the THR before the THRE is set again causes the THR data to be overwritten. If in FIFO mode and FIFOs are enabled (FCR[0] set to one) and THRE is set, x number of characters of data may be written to the THR before the FIFO is full. The number x (default=16) is determined by the value of FIFO Depth that you set during configuration. Any attempt to write data when the FIFO is full results in the write data being lost. |

**UART FAR**

Address: Operational Base + offset (0x0070)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | <p>fifo_access_test_en<br/>Writes have no effect when FIFO_ACCESS == No, always readable. This register is used to enable a FIFO access mode for testing, so that the receive FIFO can be written by the master and the transmit FIFO can be read by the master when FIFOs are implemented and enabled. When FIFOs are not implemented or not enabled it allows the RBR to be written by the master and the THR to be read by the master.</p> <p>1'b0: FIFO access mode disabled<br/>1'b1: FIFO access mode enabled</p> <p>Note, that when the FIFO access mode is enabled/disabled, the control portion of the receive FIFO and transmit FIFO is reset and the FIFOs are treated as empty.</p> |

**UART\_TFR**

Address: Operational Base + offset (0x0074)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7:0  | RO   | 0x00        | <p>trans_fifo_read<br/>Transmit FIFO Read. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one). When FIFOs are implemented and enabled, reading this register gives the data at the top of the transmit FIFO. Each consecutive read pops the transmit FIFO and gives the next data value that is currently at the top of the FIFO.</p> <p>When FIFOs are not implemented or not enabled, reading this register gives the data in the THR.</p> |

**UART\_RFW**

Address: Operational Base + offset (0x0078)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9     | WO   | 0x0         | <p>receive_fifo_framing_error<br/>Receive FIFO Framing Error. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one). When FIFOs are implemented and enabled, this bit is used to write framing error detection information to the receive FIFO. When FIFOs are not implemented or not enabled, this bit is used to write framing error detection information to the RBR.</p>                                                       |
| 8     | WO   | 0x0         | <p>receive_fifo_parity_error<br/>Receive FIFO Parity Error. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one). When FIFOs are implemented and enabled, this bit is used to write parity error detection information to the receive FIFO. When FIFOs are not implemented or not enabled, this bit is used to write parity error detection information to the RBR.</p>                                                           |
| 7:0   | WO   | 0x00        | <p>receive_fifo_write<br/>Receive FIFO Write Data. These bits are only valid when FIFO access mode is enabled (FAR[0] is set to one). When FIFOs are implemented and enabled, the data that is 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 are not implemented or not enabled, the data that is written to the RFWD is pushed into the RBR.</p> |

**UART\_USR**

Address: Operational Base + offset (0x007C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4          | RO          | 0x0                | receive_fifo_full<br>Receive FIFO Full. This bit is only valid when FIFO_STAT == YES. 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3          | RO          | 0x0                | receive_fifo_not_empty<br>Receive FIFO Not Empty. This bit is only valid when FIFO_STAT == YES. This is used to indicate that the receive FIFO contains one or more entries.<br>1'b0: Receive FIFO is empty<br>1'b1: Receive FIFO is not empty<br>This bit is cleared when the RX FIFO is empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2          | RO          | 0x1                | trans_fifo_empty<br>Transmit FIFO Empty. This bit is only valid when FIFO_STAT == YES. This is used to indicate that the transmit FIFO is completely empty.<br>1'b0: Transmit FIFO is not empty<br>1'b1: Transmit FIFO is empty<br>This bit is cleared when the TX FIFO is no longer empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1          | RO          | 0x1                | trans_fifo_not_full<br>Transmit FIFO Not Full. This bit is only valid when FIFO_STAT == YES. This is used to indicate that the transmit FIFO is not full.<br>1'b0: Transmit FIFO is full<br>1'b1: Transmit FIFO is not full<br>This bit is cleared when the TX FIFO is full.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0          | RO          | 0x0                | uart_busy<br>UART Busy. This indicates that a serial transfer is in progress, when cleared indicates that the DW_apb_uart is idle or inactive.<br>1'b0: UART is idle or inactive<br>1'b1: UART is busy (actively transferring data)<br>Note that it is possible for the UART Busy bit to be cleared even though a new character may have been sent from another device. That is, if the UART has no data in THR and RBR and there is no transmission in progress and a start bit of a new character has just reached the UART. This is due to the fact that a valid start is not seen until the middle of the bit period and this duration is dependent on the baud divisor that has been programmed. If a second system clock has been implemented (CLOCK_MODE == Enabled), the assertion of this bit is also delayed by several cycles of the slower clock. |

**UART\_TFL**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                 |
| 5:0        | RO          | 0x00               | trans_fifo_level<br>Transmit FIFO Level. This indicates the number of data entries in the transmit FIFO. |

**UART\_RFL**

Address: Operational Base + offset (0x0084)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 5:0        | RO          | 0x00               | receive_fifo_level<br>Receive FIFO Level. This indicates the number of data entries in the receive FIFO. |

**UART\_SRR**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2          | WO          | 0x0                | xmit_fifo_reset<br>XMIT FIFO Reset. This is a shadow register for the XMIT FIFO Reset bit (FCR[2]). This can be used to remove the burden on software having to store previously written FCR values (which are pretty static) just to reset the transmit FIFO. This resets the control portion of the transmit FIFO and treats the FIFO as empty. This also de-asserts the DMA TX request and single signals when additional DMA handshaking signals are selected (DMA_EXTRA == YES). Note that this bit is 'self-clearing'. It is not necessary to clear this bit.  |
| 1          | WO          | 0x0                | rcvr_fifo_reset<br>RCVR FIFO Reset. This is a shadow register for the RCVR FIFO Reset bit (FCR[1]). This can be used to remove the burden on software having to store previously written FCR values (which are pretty static) just to reset the receive FIFO. This resets the control portion of the receive FIFO and treats the FIFO as empty. This also de-asserts the DMA RX request and single signals when additional DMA handshaking signals are selected (DMA_EXTRA == YES).<br>Note that this bit is 'self-clearing'. It is not necessary to clear this bit. |
| 0          | WO          | 0x0                | uart_reset<br>UART Reset. 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0          | RW          | 0x0                | shadow_req_to_send<br>Shadow Request to Send. 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. This is used to directly control the Request to Send (rts_n) output. The Request To Send (rts_n) output is used to inform the modem or data set that the UART is ready to exchange data. When Auto RTS Flow Control is not enabled (MCR[5] = 0), the rts_n signal is set low by programming MCR[1] (RTS) to a high. In Auto Flow Control, AFCE_MODE == Enabled and active (MCR[5] = 1) and FIFOs enable (FCR[0] = 1), the rts_n output is controlled in the same way, but is also gated with the receiver FIFO threshold trigger (rts_n is inactive high when above the threshold).<br>Note that in Loopback mode (MCR[4] = 1), the rts_n output is held inactive-high while the value of this location is internally looped back to an input. |

**UART\_SBCR**

Address: Operational Base + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0          | RW          | 0x0                | shadow_break_ctrl<br>Shadow Break Control Bit. 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. This is used to cause a break condition to be transmitted to the receiving device. If set to one the serial output is forced to the spacing (logic 0) state. When not in Loopback Mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared. If SIR_MODE == Enabled and active (MCR[6] = 1) the sir_out_n line is continuously pulsed. When in Loopback Mode, the break condition is internally looped back to the receiver. |

**UART SDMAM**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0          | RW          | 0x0                | shadow_dma_mode<br>Shadow DMA Mode. This is a shadow register for the DMA mode bit (FCR[3]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the DMA Mode bit gets updated. This determines the DMA signalling mode used for the dma_tx_req_n and dma_rx_req_n output signals when additional DMA handshaking signals are not selected (DMA_EXTRA == NO).<br>1'b0: Mode 0<br>1'b1: Mode 1 |

**UART SFE**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0          | RW          | 0x0                | shadow_fifo_en<br>Shadow FIFO Enable. This is a shadow register for the FIFO enable bit (FCR[0]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the FIFO enable bit gets updated. This enables/disables the transmit (XMIT) and receive (RCVR) FIFOs. If this bit is set to zero (disabled) after being enabled then both the XMIT and RCVR controller portion of FIFOs are reset. |

**UART SRT**

Address: Operational Base + offset (0x009C)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | <p>shadow_rcvr_trigger<br/>Shadow RCVR Trigger. This is a shadow register for the RCVR trigger bits (FCR[7:6]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the RCVR trigger bit gets updated. This is used to select the trigger level in the receiver FIFO at which the Received Data Available Interrupt is generated. It also determines when the dma_rx_req_n signal is asserted when DMA Mode (FCR[3]) = 1. The following trigger levels are supported:</p> <ul style="list-style-type: none"> <li>2'b00: 1 character in the FIFO</li> <li>2'b01: FIFO 1/4 full</li> <li>2'b10: FIFO 1/2 full</li> <li>2'b11: FIFO 2 less than full</li> </ul> |

**UART STET**

Address: Operational Base + offset (0x00A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1:0        | RW          | 0x0                | <p>shadow_tx_empty_trigger<br/>Shadow TX Empty Trigger. This is a shadow register for the TX empty trigger bits (FCR[5:4]). This can be used to remove the burden of having to store the previously written value to the FCR in memory and having to mask this value so that only the TX empty trigger bit gets updated. This is used to select the empty threshold level at which the THRE Interrupts are generated when the mode is active. The following trigger levels are supported:</p> <ul style="list-style-type: none"> <li>2'b00: FIFO empty</li> <li>2'b01: 2 characters in the FIFO</li> <li>2'b10: FIFO 1/4 full</li> <li>2'b11: FIFO 1/2 full</li> </ul> |

**UART HTX**

Address: Operational Base + offset (0x00A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0          | RW          | 0x0                | <p>halt_tx_en<br/>This register is used to halt transmissions for testing, so that the transmit FIFO can be filled by the master when FIFOs are implemented and enabled.</p> <ul style="list-style-type: none"> <li>1'b0: Halt TX disabled</li> <li>1'b1: Halt TX enabled</li> </ul> <p>Note, if FIFOs are implemented and not enabled, the setting of the halt TX register has no effect on operation.</p> |

**UART DMASA**

Address: Operational Base + offset (0x00A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0          | WO          | 0x0                | <p>dma_software_ack<br/>This register is used to perform a DMA software acknowledge if a transfer needs to be terminated due to an error condition. For example, if the DMA disables the channel, then the UART should clear its request. This causes the TX request, TX single, RX request and RX single signals to de-assert. Note that this bit is 'self-clearing'. It is not necessary to clear this bit.</p> |

**UART CPR**

Address: Operational Base + offset (0x00F4)

| Bit   | Attr | Reset Value | Description                                                            |
|-------|------|-------------|------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                               |
| 23:16 | RO   | 0x04        | fifo_mode<br>8'h4 means FIFO mode is 64.                               |
| 15:14 | RO   | 0x0         | reserved                                                               |
| 13    | RO   | 0x1         | dma_extra<br>1'b1 means DMA_EXTRA enabled.                             |
| 12    | RO   | 0x1         | uart_add_encoded_params<br>1'b1 means UART_ADD_ENCODED_PARAMS enabled. |
| 11    | RO   | 0x1         | shadow<br>1'b1 means SHADOW mode enabled.                              |
| 10    | RO   | 0x1         | fifo_stat<br>1'b1 means FIFO_STAT enabled.                             |
| 9     | RO   | 0x1         | fifo_access<br>1'b1 means FIFO ACCESS enabled.                         |
| 8     | RO   | 0x1         | new_feat<br>1'b1 means Additional features enabled.                    |
| 7     | RO   | 0x1         | sir_lp_mode<br>1'b1 means SIR_LP mode enabled.                         |
| 6     | RO   | 0x1         | sir_mode<br>1'b1 means SIR mode enabled.                               |
| 5     | RO   | 0x1         | thre_mode<br>1'b1 means THRE mode enabled.                             |
| 4     | RO   | 0x1         | afce_mode<br>1'b1 means AFCE mode enabled.                             |
| 3:2   | RO   | 0x0         | reserved                                                               |
| 1:0   | RO   | 0x2         | apb_data_width<br>2'b10 means APB data width is 32bit.                 |

**UART UCV**

Address: Operational Base + offset (0x00F8)

| Bit  | Attr | Reset Value | Description                                        |
|------|------|-------------|----------------------------------------------------|
| 31:0 | RO   | 0x3430322a  | ver<br>ASCII value for each number in the version. |

**UART CTR**

Address: Operational Base + offset (0x00FC)

| Bit  | Attr | Reset Value | Description                                                                  |
|------|------|-------------|------------------------------------------------------------------------------|
| 31:0 | RO   | 0x44570110  | peripheral_id<br>This register contains the peripherals identification code. |

**13.5 Interface Description**

Table 13-1 UART0 Interface Description

| Module Pin    | Dir | Pad Name                                              | IOMUX Setting                            |
|---------------|-----|-------------------------------------------------------|------------------------------------------|
| <b>IOMUX0</b> |     |                                                       |                                          |
| uart_rx       | I   | RTC_CLKO/REF_CLK_OUT/CLKIO_32K/UART0_RX_M0/GPIO0_A0_z | PMU_IOC_GPIO0A_IO<br>MUX_SEL_L[2:0]=3'h1 |
| uart_tx       | O   | TEST_CLK6_OUT/PWM2_M0/UART0_TX_M0/GPIO0_A1_d          | PMU_IOC_GPIO0A_IO<br>MUX_SEL_L[6:4]=3'h1 |
| <b>IOMUX1</b> |     |                                                       |                                          |

|               |   |                                                                                       |                                           |
|---------------|---|---------------------------------------------------------------------------------------|-------------------------------------------|
| uart_rx       | I | TEST_CLK4_OUT/PWM5_M1/LCD_D16/I2C1_SDA_M1/UART0_RX_M1/GPIO2_B0_d                      | VO_IOC_GPIO2B_IOM<br>UX_SEL_L[2:0]=3'h1   |
| uart_tx       | O | TEST_CLK5_OUT/PWM6_M1/LCD_D17/I2C1_SCL_M1/UART0_TX_M1/GPIO2_B1_d                      | VO_IOC_GPIO2B_IOM<br>UX_SEL_L[6:4]=3'h1   |
| uart_cts_n    | I | PRELIGHT_TRIG_OUT/I2C3_SDA_M0/PWM4_M1/LCD_D15/I2S0_SDO1_SDID/UART0_CTSN_M1/GPIO2_A7_d | VO_IOC_GPIO2A_IOM<br>UX_SEL_H[14:12]=3'h1 |
| uart_rts_n    | O | FLASH_TRIG_OUT/I2C3_SCL_M0/PWM2_M1/LCD_D14/I2S0_SDO2_SDID/UART0_RTSN_M1/GPIO2_A6_d    | VO_IOC_GPIO2A_IOM<br>UX_SEL_H[10:8]=3'h1  |
| <b>IOMUX2</b> |   |                                                                                       |                                           |
| uart_rx       | I | TEST_CLK2_OUT/I2C0_SDA_M1/UART0_RX_M2/SPI1_MISO_M0/EMMC_D7/GPIO4_A0_u                 | PERI_IOC_GPIO4A_IO<br>MUX_SEL_L[2:0]=3'h3 |
| uart_tx       | O | TEST_CLK3_OUT/I2C0_SCL_M1/UART0_TX_M2/SPI1_MOSI_M0/EMMC_D6/GPIO4_A1_u                 | PERI_IOC_GPIO4A_IO<br>MUX_SEL_L[6:4]=3'h3 |

Table 13-2 UART1 Interface Description

| Module Pin    | Dir | Pad Name                                                           | IOMUX Setting                               |
|---------------|-----|--------------------------------------------------------------------|---------------------------------------------|
| <b>IOMUX0</b> |     |                                                                    |                                             |
| uart_rx       | I   | I2C0_SDA_M0/UART1_RX_M0/GPIO1_A4_d                                 | VENC_IOC_GPIO1A_I<br>OMUX_SEL_H[2:0]=3'h1   |
| uart_tx       | O   | I2C0_SCL_M0/UART1_TX_M0/GPIO1_A3_d                                 | VENC_IOC_GPIO1A_I<br>OMUX_SEL_L[14:12]=3'h1 |
| uart_cts_n    | I   | PWM6_M0/UART1_CTSN_M0/I2C1_SDA_M0/GPIO0_A6_d                       | PMU_IOC_GPIO0A_IO<br>MUX_SEL_H[10:8]=3'h2   |
| uart_rts_n    | O   | PWM5_M0/UART1_RTSN_M0/I2C1_SCL_M0/GPIO0_A5_d                       | PMU_IOC_GPIO0A_IO<br>MUX_SEL_H[6:4]=3'h2    |
| <b>IOMUX1</b> |     |                                                                    |                                             |
| uart_rx       | I   | UART1_RX_M1/LCD_D13/I2S0_SDID/SDMM_C1_D2_M0/GPIO2_A5_d             | VO_IOC_GPIO2A_IOM<br>UX_SEL_H[6:4]=3'h4     |
| uart_tx       | O   | UART1_TX_M1/LCD_D12/I2S0_SDO0/SDMM_C1_D3_M0/GPIO2_A4_d             | VO_IOC_GPIO2A_IOM<br>UX_SEL_H[2:0]=3'h4     |
| uart_cts_n    | I   | I2C4_SDA_M0/UART1_CTSN_M1/LCD_D8/I2S0_SCLK/SDMMC1_D1_M0/GPIO2_A0_d | VO_IOC_GPIO2A_IOM<br>UX_SEL_L[2:0]=3'h4     |
| uart_rts_n    | O   | I2C4_SCL_M0/UART1_RTSN_M1/LCD_D9/I2S0_LRCK/SDMMC1_D0_M0/GPIO2_A1_d | VO_IOC_GPIO2A_IOM<br>UX_SEL_L[6:4]=3'h4     |
| <b>IOMUX2</b> |     |                                                                    |                                             |
| uart_rx       | I   | I2C2_SCL_M1/UART1_RX_M2/SPI1_CLK_M0/EMMC_D5/GPIO4_A7_u             | PERI_IOC_GPIO4A_IO<br>MUX_SEL_H[14:12]=3'h3 |
| uart_tx       | O   | I2C2_SDA_M1/UART1_TX_M2/SPI1_CS0n_M0/EMMC_D4/GPIO4_A5_u            | PERI_IOC_GPIO4A_IO<br>MUX_SEL_H[6:4]=3'h3   |

Table 13-3 UART2 Interface Description

| Module Pin    | Dir | Pad Name                                               | IOMUX Setting                          |
|---------------|-----|--------------------------------------------------------|----------------------------------------|
| <b>IOMUX0</b> |     |                                                        |                                        |
| uart_rx       | I   | PWM8_M0/TEST_CLK1_OUT/UART2_RX_M0/SDMMC0_D0/GPIO3_A3_u | VI_IOC_GPIO3A_IOMU_X_SEL_L[14:12]=3'h2 |
| uart_tx       | O   | PWM9_M0/TEST_CLK0_OUT/UART2_TX_M0/SDMMC0_D1/GPIO3_A2_u | VI_IOC_GPIO3A_IOMU_X_SEL_L[10:8]=3'h2  |

| <b>IOMUX1</b> |   |                                                                           |                                             |
|---------------|---|---------------------------------------------------------------------------|---------------------------------------------|
| uart_rx       | I | LPMCU_JTAG_TMS_M0/HPMCU_JTAG_TMS_M0/UART2_RX_M1/A7_JTAG_TMS_M1/GPIO1_B3_u | VENC_IOC_GPIO1B_I<br>OMUX_SEL_L[14:12]=3'h2 |
| uart_tx       | O | LPMCU_JTAG_TCK_M0/HPMCU_JTAG_TCK_M0/UART2_TX_M1/A7_JTAG_TCK_M1/GPIO1_B2_d | VENC_IOC_GPIO1B_I<br>OMUX_SEL_L[10:8]=3'h2  |

Table 13-4 UART3 Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b>                                                        | <b>IOMUX Setting</b>                      |
|-------------------|------------|------------------------------------------------------------------------|-------------------------------------------|
| <b>IOMUX0</b>     |            |                                                                        |                                           |
| uart_rx           | I          | PWM4_M0/PMU_DEBUG/I2C2_SDA_M0/UART3_RX_M0/GPIO1_A1_d                   | VENC_IOC_GPIO1A_I<br>OMUX_SEL_L[6:4]=3'h1 |
| uart_tx           | O          | PWM7_IR_M0/I2C2_SCL_M0/UART3_TX_M0/GPIO1_A0_d                          | VENC_IOC_GPIO1A_I<br>OMUX_SEL_L[2:0]=3'h1 |
| <b>IOMUX1</b>     |            |                                                                        |                                           |
| uart_rx           | I          | UART3_RX_M1/UART5_CTSN_M1/PWM10_M2/VICAP_HSYNC_M1/LCD_HSYNC/GPIO1_D1_d | VENC_IOC_GPIO1D_I<br>OMUX_SEL_L[6:4]=3'h5 |
| uart_tx           | O          | UART3_TX_M1/UART5_RTSN_M1/PWM3_IR_M2/VICAP_CLKIN_M1/LCD_DEN/GPIO1_D0_d | VENC_IOC_GPIO1D_I<br>OMUX_SEL_L[2:0]=3'h5 |

Table 13-5 UART4 Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b>                                                | <b>IOMUX Setting</b>                        |
|-------------------|------------|----------------------------------------------------------------|---------------------------------------------|
| <b>IOMUX0</b>     |            |                                                                |                                             |
| uart_rx           | I          | PWM3_IR_M1/UART4_RX_M0/GPIO1_B0_d                              | VENC_IOC_GPIO1B_I<br>OMUX_SEL_L[2:0]=3'h1   |
| uart_tx           | O          | VICAP_D1_M1/SPI1_CS1n_M0/PWM7_IR_M1/UART4_TX_M0/GPIO1_B1_d     | VENC_IOC_GPIO1B_I<br>OMUX_SEL_L[6:4]=3'h1   |
| <b>IOMUX1</b>     |            |                                                                |                                             |
| uart_rx           | I          | SDMMC1_D3_M1/UART4_RX_M1/PWM8_M1/VICAP_D6_M1/LCD_D3/GPIO1_C4_d | VENC_IOC_GPIO1C_I<br>OMUX_SEL_H[2:0]=3'h4   |
| uart_tx           | O          | SDMMC1_D2_M1/UART4_TX_M1/PWM9_M1/VICAP_D7_M1/LCD_D2/GPIO1_C5_d | VENC_IOC_GPIO1C_I<br>OMUX_SEL_H[6:4]=3'h4   |
| uart_cts_n        | I          | UART4_CTSN_M1/PWM11_IR_M1/VICAP_D9_M1/LCD_D0/GPIO1_C7_d        | VENC_IOC_GPIO1C_I<br>OMUX_SEL_H[14:12]=3'h4 |
| uart_rts_n        | O          | UART4_RTSN_M1/PWM10_M1/VICAP_D8_M1/LCD_D1/GPIO1_C6_d           | VENC_IOC_GPIO1C_I<br>OMUX_SEL_H[10:8]=3'h4  |

Table 13-6 UART5 Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b>                                                   | <b>IOMUX Setting</b>                  |
|-------------------|------------|-------------------------------------------------------------------|---------------------------------------|
| <b>IOMUX0</b>     |            |                                                                   |                                       |
| uart_rx           | I          | HPMCU_JTAG_TCK_M1/A7_JTAG_TCK_M0/UART5_RX_M0/SDMMC0_D2/GPIO3_A7_u | VI_IOC_GPIO3A_IOMUX_SEL_H[14:12]=3'h2 |
| uart_tx           | O          | HPMCU_JTAG_TMS_M1/A7_JTAG_TMS_M0/UART5_TX_M0/SDMMC0_D3/GPIO3_A6_u | VI_IOC_GPIO3A_IOMUX_SEL_H[10:8]=3'h2  |
| uart_cts_n        | I          | PWM11_IR_M0/LPMCU_JTAG_TMS_M1/I2C0                                | VI_IOC_GPIO3A_IOMUX                   |

|               |   |                                                                                                     |                                                 |
|---------------|---|-----------------------------------------------------------------------------------------------------|-------------------------------------------------|
|               |   | _SDA_M2/UART5_CTSN_M0/SDMMC0_CMD/<br>GPIO3_A5_u                                                     | X_SEL_H[6:4]=3'h2                               |
| uart_rts_n    | O | PWM10_M0/LPMCU_JTAG_TCK_M1/I2C0_SC<br>L_M2/UART5_RTSN_M0/SDMMC0_CLK/GPIO<br>3_A4_d                  | VI_IOC_GPIO3A_IOMU<br>X_SEL_H[2:0]=3'h2         |
| <b>IOMUX1</b> |   |                                                                                                     |                                                 |
| uart_rx       | I | DSMAUDIO_P/PWM0_M1/SPI0_CS1n_M0/U<br>ART5_RX_M1/I2C3_SDA_M1/VICAP_VSYNC<br>_M1/LCD_VSYNC/GPIO1_D2_d | VENC_IOC_GPIO1D_I<br>OMUX_SEL_L[10:8]=3<br>'h4  |
| uart_tx       | O | DSMAUDIO_N//PWM11_IR_M2/UART5_TX_<br>M1/I2C3_SCL_M1/VICAP_CLKOUT_M1/LCD_<br>CLK/GPIO1_D3_d          | VENC_IOC_GPIO1D_I<br>OMUX_SEL_L[14:12]=<br>3'h4 |
| uart_cts_n    | I | UART3_RX_M1/UART5_CTSN_M1/PWM10_M<br>2/VICAP_HSYNC_M1/LCD_HSYNC/GPIO1_D<br>1_d                      | VENC_IOC_GPIO1D_I<br>OMUX_SEL_L[6:4]=3'<br>h4   |
| uart_rts_n    | O | UART3_TX_M1/UART5_RTSN_M1/PWM3_IR<br>M2/VICAP_CLKIN_M1/LCD_DEN/GPIO1_D0_d                           | VENC_IOC_GPIO1D_I<br>OMUX_SEL_L[2:0]=3'<br>h4   |
| <b>IOMUX2</b> |   |                                                                                                     |                                                 |
| uart_rx       | I | I2C4_SDA_M2/UART5_RX_M2/VICAP_D12/<br>GPIO3_D0_d                                                    | VI_IOC_GPIO3D_IOM<br>UX_SEL_L[2:0]=3'h2         |
| uart_tx       | O | I2C4_SCL_M2/UART5_TX_M2/VICAP_D11/G<br>PIO3_C7_d                                                    | VI_IOC_GPIO3C_IOMU<br>X_SEL_H[14:12]=3'h2       |
| uart_cts_n    | I | I2C3_SDA_M2/UART5_CTSN_M2/VICAP_D1<br>4/GPIO3_D2_d                                                  | VI_IOC_GPIO3D_IOM<br>UX_SEL_L[10:8]=3'h2        |
| uart_rts_n    | O | I2C3_SCL_M2/UART5_RTSN_M2/VICAP_D13<br>/GPIO3_D1_d                                                  | VI_IOC_GPIO3D_IOM<br>UX_SEL_L[6:4]=3'h2         |

## 13.6 Application Notes

### 13.6.1 No FIFO Mode Transfer Flow



Fig. 13-7 UART none fifo mode

### 13.6.2 FIFO Mode Transfer Flow



Fig. 13-8 UART fifo mode

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.

### 13.6.3 Baud Rate Calculation

#### UART clock generation

The following figures shows the UART clock generation. UARTs source clocks can be selected from different PLL outputs. UART clocks can be generated by 1 to 64 division of its source clock, or can be fractionally divided again, or be provided by XIN24M.



Fig. 13-9 UART0-UART2 clock generation



Fig. 13-10 UART3-UART5 clock generation

**UART baud rate configuration**

The following table provides some reference configuration for different UART baud rates.

Table 13-7 UART baud rate configuration

| Baud Rate  | Reference Configuration                                                                                                       |
|------------|-------------------------------------------------------------------------------------------------------------------------------|
| 115.2 Kbps | Configure PLL to get 648MHz clock output; Divide 648MHz clock by 1152/50625 to get 14.7456MHz clock; Configure UART_DLL to 8. |
| 460.8 Kbps | Configure PLL to get 648MHz clock output; Divide 648MHz clock by 1152/50625 to get 14.7456MHz clock; Configure UART_DLL to 2. |
| 921.6 Kbps | Configure PLL to get 648MHz clock output; Divide 648MHz clock by 1152/50625 to get 14.7456MHz clock; Configure UART_DLL to 1. |
| 1.5 Mbps   | Choose PLL to get 384MHz clock output; Divide 384MHz clock by 16 to get 24MHz clock; Configure UART_DLL to 1.                 |
| 3 Mbps     | Choose PLL to get 384MHz clock output; Divide 384MHz clock by 8 to get 48MHz clock; Configure UART_DLL to 1.                  |
| 4 Mbps     | Configure PLL to get 384MHz clock output; Divide 384MHz clock by 6 to get 64MHz clock; Configure UART_DLL to 1.               |

## Chapter 14 GPIO

### 14.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 can also read back the data on external pads using memory-mapped registers.

GPIO supports the following features:

- 32 bits APB data bus width
- Up to 32 independently configurable signals
- Software control registers with write mask for each bit of each signal
- Configurable debounce logic with a slow clock to debounce interrupts
- Configurable interrupt mode
- Two virtual OS with independent control registers can be supported
- In two virtual OS models, each OS has an independent interrupt
- Not in two virtual OS models, two interrupts with priority can be set

### 14.2 Block Diagram



Fig. 14-1 GPIO Block Diagram

GPIO is comprised of:

- APB Interface

The APB Interface implements the APB slave operation. Its data bus width is 32 bits.

- I/O Port Interface

External data interface to or from I/O pads.

- Interrupt Detection

Interrupt interface to or from interrupt controller.

### 14.3 Function Description

#### 14.3.1 Data Control

Under software control, the data and direction control for the signal are sourced from the port data registers (GPIO\_SWPORT\_DR\_L/GPIO\_SWPORT\_DR\_H) and direction control registers (GPIO\_SWPORT\_DRR\_L/GPIO\_SWPORT\_DRR\_H).

The direction of the external I/O pad is controlled by the value of the port data direction registers. The data written to these memory-mapped registers gets mapped onto an output signal (gpio\_port\_ddr) of the GPIO peripheral. This output signal controls the direction of an external I/O pad. The default data direction is Input.

The data written to the port data registers drives the output buffer (gpio\_port\_dr) of the I/O pad.

External data are input on the external data signal (gpio\_ext\_port). Reading the external signal register (GPIO\_EXT\_PORT) shows the value of this signal, regardless of the direction. This register is read-only, meaning that it cannot be written from the APB software

interface.

### **14.3.2 Interrupts**

I/O port 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\_INT\_MASK\_L/GPIO\_INT\_MASK\_H registers. The interrupt status can be read before masking (GPIO\_INT\_RAWSTATUS) and after masking (GPIO\_INT\_STATUS).

For edge-sensitive interrupts, the Interrupt Service Routine (ISR) can clear the interrupt by writing a 1 to the corresponding bit of the GPIO\_PORT\_EOI\_L/GPIO\_PORT\_EOI\_H registers. This write operation also clears the interrupt status and raw status registers. Writing to the interrupt clear registers has no effect on level-sensitive interrupts. If level-sensitive interrupts cause the processor to interrupt, then the ISR can poll the interrupt raw status register until the interrupt source disappears, or it can write to the interrupt mask 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.

The interrupts are combined into an active-high interrupt output signal. 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 I/O port is configured for interrupts, the data direction must be set to Input. If the data direction is reprogrammed to Output, then any pending edge-sensitive interrupts are not lost. However, no new interrupts are generated, and level-sensitive interrupts are lost.

Interrupt signals are internally synchronized to a system clock pclk\_intr, which is connected to the APB bus clock pclk. Therefore, the pclk needs to be running for interrupt detection.

### **14.3.3 Debounce Operation**

The external signal can be debounced to remove any spurious glitches that are less than one period of the external debouncing clock.

When an input interrupt signal is debounced using a slow debounce clock (external input clock dbclk or internally divided clock dbclk\_div), the signal must be active for a minimum of two cycles of the debounce clock to guarantee that it is 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 rising edge, it is not registered.

The debounce function can be controlled by programming the debounce enable registers (GPIO\_DEBOUNCE\_L/GPIO\_DEBOUNCE\_H), debounce clock divide enable registers (GPIO\_DBCLK\_DIV\_EN\_L/GPIO\_DBCLK\_DIV\_EN\_H) and debounce clock divide control register (GPIO\_DBCLK\_DIV\_CON).

### **14.3.4 Two OS Operation and Tow Interrupt**

To select this model, a virtual enable register should be set(GPIO\_VIRTUAL\_EN). Then all the configure can be allotted to two OS (for example OS\_A and OS\_B). OS\_A will use the original address offset, OS\_B will use the offset + 0x1000. The 32 bit I/O port should also be allotted to the OS by setting reg group registers(GPIO\_REG\_GROUP\_L and GPIO\_REG\_GROUP\_H). Once reg group is set, the I/O operation can only be used by the setting address offset. Each OS has its own interrupt for I/O port, this is depended on reg

group.

If the virtual enable register is disabled, reg group can also be used to allotted I/O interrupt. These two independent interrupts may be used for priority interrupt settings.

## 14.4 Register Description

### 14.4.1 Registers Summary

| Name                  | Offset | Size | Reset Value | Description                              |
|-----------------------|--------|------|-------------|------------------------------------------|
| GPIO_SWPORT_DR_L      | 0x0000 | W    | 0x00000000  | Port Data Register (Low)                 |
| GPIO_SWPORT_DR_H      | 0x0004 | W    | 0x00000000  | Port Data Register (High)                |
| GPIO_SWPORT_DDR_L     | 0x0008 | W    | 0x00000000  | Port Data Direction Register (Low)       |
| GPIO_SWPORT_DDR_H     | 0x000C | W    | 0x00000000  | Port Data Direction Register (High)      |
| GPIO_INT_EN_L         | 0x0010 | W    | 0x00000000  | Interrupt Enable Register (Low)          |
| GPIO_INT_EN_H         | 0x0014 | W    | 0x00000000  | Interrupt Enable Register (High)         |
| GPIO_INT_MASK_L       | 0x0018 | W    | 0x00000000  | Interrupt Mask Register (Low)            |
| GPIO_INT_MASK_H       | 0x001C | W    | 0x00000000  | Interrupt Mask Register (High)           |
| GPIO_INT_TYPE_L       | 0x0020 | W    | 0x00000000  | Interrupt Level Register (Low)           |
| GPIO_INT_TYPE_H       | 0x0024 | W    | 0x00000000  | Interrupt Level Register (High)          |
| GPIO_INT_POLARITY_L   | 0x0028 | W    | 0x00000000  | Interrupt Polarity Register (Low)        |
| GPIO_INT_POLARITY_H   | 0x002C | W    | 0x00000000  | Interrupt Polarity Register (High)       |
| GPIO_INT_BOTHEDGE_L   | 0x0030 | W    | 0x00000000  | Interrupt Both Edge Type Register (Low)  |
| GPIO_INT_BOTHEDGE_H   | 0x0034 | W    | 0x00000000  | Interrupt Both Edge Type Register (High) |
| GPIO_DEBOUNCE_L       | 0x0038 | W    | 0x00000000  | Debounce Enable Register (Low)           |
| GPIO_DEBOUNCE_H       | 0x003C | W    | 0x00000000  | Debounce Enable Register (High)          |
| GPIO_DBCLK_DIV_EN_L   | 0x0040 | W    | 0x00000000  | DBCLK Divide Enable Register (Low)       |
| GPIO_DBCLK_DIV_EN_H   | 0x0044 | W    | 0x00000000  | DBCLK Divide Enable Register (High)      |
| GPIO_DBCLK_DIV_CON    | 0x0048 | W    | 0x00000001  | DBCLK Divide Control Register            |
| GPIO_INT_STATUS       | 0x0050 | W    | 0x00000000  | Interrupt Status Register                |
| GPIO_INT_RAWSTATUS    | 0x0058 | W    | 0x00000000  | Interrupt Raw Status Register            |
| GPIO_PORT_EOI_L       | 0x0060 | W    | 0x00000000  | Interrupt Clear Register (Low)           |
| GPIO_PORT_EOI_H       | 0x0064 | W    | 0x00000000  | Interrupt Clear Register (High)          |
| GPIO_EXT_PORT         | 0x0070 | W    | 0x00000000  | External Port Data Register              |
| GPIO_VER_ID           | 0x0078 | W    | 0x0101157C  | Version ID Register                      |
| GPIO_GPIO_REG_GROUP_L | 0x0100 | W    | 0x00000000  | GPIO Group Control                       |
| GPIO_GPIO_REG_GROUP_H | 0x0104 | W    | 0x0000FFFF  | GPIO Group Control                       |
| GPIO_GPIO_VIRTUAL_EN  | 0x0108 | W    | 0x00000000  | GPIO Virtual Enable                      |

Notes:B- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 14.4.2 Detail Registers Description

#### GPIO\_SWPORT\_DR\_L

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>swport_dr_low<br/>Output data for the lower 16 bits of I/O Port, each bit is individual.<br/>1'b0: Low<br/>1'b1: High</p> <p>Values written to this register are output on the I/O signals for the lower 16 bits of I/O Port if the corresponding data direction bits for I/O Port are set to Output mode. The value read back is equal to the last value written to this register.</p> |

**GPIO\_SWPORT\_DR\_H**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                  |
| 15:0       | RW          | 0x0000             | <p>swport_dr_high<br/>Output data for the upper 16 bits of I/O Port, each bit is individual.<br/>1'b0: Low<br/>1'b1: High</p> <p>Values written to this register are output on the I/O signals for the upper 16 bits of I/O Port if the corresponding data direction bits for I/O Port are set to Output mode. The value read back is equal to the last value written to this register.</p> |

**GPIO\_SWPORT\_DDR\_L**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                      |
| 15:0       | RW          | 0x0000             | <p>swport_ddr_low<br/>Data direction for the lower 16 bits of I/O Port, each bit is individual.<br/>1'b0: Input<br/>1'b1: Output</p> <p>Values written to this register independently control the direction of the corresponding data bit in the lower 16 bits of I/O Port.</p> |

**GPIO\_SWPORT\_DDR\_H**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                       |
| 15:0       | RW          | 0x0000             | <p>swport_ddr_high<br/>Data direction for the upper 16 bits of I/O Port, each bit is individual.<br/>1'b0: Input<br/>1'b1: Output</p> <p>Values written to this register independently control the direction of the corresponding data bit in the upper 16 bits of I/O Port.</p> |

**GPIO INT EN L**

Address: Operational Base + offset (0x0010)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                     |
| 15:0  | RW   | 0x0000      | int_en_low<br>Allows each bit of the lower 16 bits of I/O Port to be configured for interrupts.<br>1'b0: Interrupt is disabled<br>1'b1: Interrupt is enabled<br>Whenever a 1 is written to a bit of this register, it configures the corresponding bit on I/O Port to become an interrupt source; otherwise, I/O Port operates as a normal GPIO signal. Interrupts are disabled on the corresponding bits of I/O Port if the corresponding data direction register is set to Output. |

**GPIO INT EN H**

Address: Operational Base + offset (0x0014)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                                                      |
| 15:0  | RW   | 0x0000      | int_en_high<br>Allows each bit of the upper 16 bits of I/O Port to be configured for interrupts.<br>1'b0: Interrupt is disabled<br>1'b1: Interrupt is enabled<br>Whenever a 1 is written to a bit of this register, it configures the corresponding bit on I/O Port to become an interrupt source; otherwise, I/O Port operates as a normal GPIO signal. Interrupts are disabled on the corresponding bits of I/O Port if the corresponding data direction register is set to Output. |

**GPIO INT MASK L**

Address: Operational Base + offset (0x0018)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                 |
| 15:0  | RW   | 0x0000      | int_mask_low<br>Controls whether an interrupt on the lower 16 bits of I/O Port can create an interrupt for the interrupt controller by not masking it.<br>1'b0: Interrupt is unmasked<br>1'b1: Interrupt is masked<br>Whenever a 1 is written to a bit in this register, it masks the interrupt generation capability for this signal; otherwise interrupts are allowed through. |

**GPIO INT MASK H**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                  |
| 15:0       | RW          | 0x0000             | int_mask_high<br>Controls whether an interrupt on the upper 16 bits of I/O Port can create an interrupt for the interrupt controller by not masking it.<br>1'b0: Interrupt is unmasked<br>1'b1: Interrupt is masked<br>Whenever a 1 is written to a bit in this register, it masks the interrupt generation capability for this signal; otherwise interrupts are allowed through. |

**GPIO INT TYPE L**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                |
| 15:0       | RW          | 0x0000             | int_type_low<br>Controls the type of interrupt that can occur on the lower 16 bits of I/O Port.<br>1'b0: Level-sensitive<br>1'b1: Edge-sensitive<br>Whenever a 1 is written to a bit of this register, it configures the interrupt type to be edge-sensitive; otherwise, it is level-sensitive. |

**GPIO INT TYPE H**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                 |
| 15:0       | RW          | 0x0000             | int_type_high<br>Controls the type of interrupt that can occur on the upper 16 bits of I/O Port.<br>1'b0: Level-sensitive<br>1'b1: Edge-sensitive<br>Whenever a 1 is written to a bit of this register, it configures the interrupt type to be edge-sensitive; otherwise, it is level-sensitive. |

**GPIO INT POLARITY L**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0x0000      | <p>int_polarity_low<br/>Controls the polarity of edge or level sensitivity that can occur on the lower 16 bits of I/O Port.<br/>1'b0: Active-low<br/>1'b1: Active-high<br/>Whenever a 1 is written to a bit of this register, it configures the interrupt type to rising-edge or active-high sensitive; otherwise, it is falling-edge or active-low sensitive.</p> |

**GPIO INT POLARITY H**

Address: Operational Base + offset (0x002C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                          |
| 15:0  | RW   | 0x0000      | <p>int_polarity_high<br/>Controls the polarity of edge or level sensitivity that can occur on the upper 16 bits of I/O Port.<br/>1'b0: Active-low<br/>1'b1: Active-high<br/>Whenever a 1 is written to a bit of this register, it configures the interrupt type to rising-edge or active-high sensitive; otherwise, it is falling-edge or active-low sensitive.</p> |

**GPIO INT BOTHEDGE L**

Address: Operational Base + offset (0x0030)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15:0  | RW   | 0x0000      | <p>int_bothedge_low<br/>Controls the edge type of interrupt that can occur on the lower 16 bits of I/O Port.<br/>1'b0: Disable both-edge detection<br/>1'b1: Enable both-edge detection<br/>Whenever a particular bit is programmed to 1, it enables the generation of interrupts on both the rising edge and the falling edge of an external input signal corresponding to that bit on I/O Port. The values programmed in the registers int_type_low and int_polarity_low for this particular bit are not considered when the corresponding bit of this register is set to 1. Whenever a particular bit is programmed to 0, the interrupt type depends on the value of the corresponding bits in the int_type_low and int_polarity_low registers.</p> |

**GPIO INT BOTHEDGE H**

Address: Operational Base + offset (0x0034)

| Bit   | Attr | Reset Value | Description                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p> |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0x0000      | <p>int_bothedge_high<br/>Controls the edge type of interrupt that can occur on the upper 16 bits of I/O Port.<br/>1'b0: Disable both-edge detection<br/>1'b1: Enable both-edge detection</p> <p>Whenever a particular bit is programmed to 1, it enables the generation of interrupts on both the rising edge and the falling edge of an external input signal corresponding to that bit on I/O Port. The values programmed in the registers int_type_high and int_polarity_high for this particular bit are not considered when the corresponding bit of this register is set to 1. Whenever a particular bit is programmed to 0, the interrupt type depends on the value of the corresponding bits in the int_type_high and int_polarity_high registers.</p> |

**GPIO DEBOUNCE L**

Address: Operational Base + offset (0x0038)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                |
| 15:0  | RW   | 0x0000      | <p>debounce_low<br/>Controls whether an external signal of the lower 16 bits of I/O Port that is the source of an interrupt needs to be debounced to remove any spurious glitches.<br/>1'b0: Disable debounce<br/>1'b1: Enable debounce</p> <p>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.</p> |

**GPIO DEBOUNCE H**

Address: Operational Base + offset (0x003C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                 |
| 15:0  | RW   | 0x0000      | <p>debounce_high<br/>Controls whether an external signal of the lower 16 bits of I/O Port that is the source of an interrupt needs to be debounced to remove any spurious glitches.<br/>1'b0: Disable debounce<br/>1'b1: Enable debounce</p> <p>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.</p> |

**GPIO DBCLK DIV EN L**

Address: Operational Base + offset (0x0040)

| Bit   | Attr | Reset Value | Description                                                                                                                                |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>dbclk_div_en_low<br/>Controls whether to use the internal divided clock when debounce function is enabled for an external signal of the lower 16 bits of I/O Port.</p> <p>1'b0: Disable divider for debounce clock<br/>1'b1: Enable divider for debounce clock</p> <p>Whenever a 1 is written to a bit of this register, the clock divided from dbclk is used as debounce clock; otherwise, the original dbclk is used. The clock divider factor depends on the register dbclk_div_con. The values programmed in this register for this particular bit are not considered when the corresponding bit of the register debounce_low is set to 0.</p> |

**GPIO DBCLK DIV EN H**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15:0       | RW          | 0x0000             | <p>dbclk_div_en_high<br/>Controls whether to use the internal divided clock when debounce function is enabled for an external signal of the upper 16 bits of I/O Port.</p> <p>1'b0: Disable divider for debounce clock<br/>1'b1: Enable divider for debounce clock</p> <p>Whenever a 1 is written to a bit of this register, the clock divided from dbclk is used as debounce clock; otherwise, the original dbclk is used. The clock divider factor depends on the register dbclk_div_con. The values programmed in this register for this particular bit are not considered when the corresponding bit of the register debounce_high is set to 0.</p> |

**GPIO DBCLK DIV CON**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                         |
| 23:0       | RW          | 0x0000001          | <p>dbclk_div_con<br/><math>dbclk\_div = dbclk / (dbclk\_div\_con + 1)</math></p> |

**GPIO INT STATUS**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>int_status<br/>Interrupt status of I/O Port.</p> |

**GPIO INT RAWSTATUS**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>int_rawstatus<br/>Interrupt raw status of I/O Port (pre masking bits).</p> |

**GPIO PORT EOI L**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                            |
| 15:0       | R/W SC      | 0x0000             | port_eoi_low<br>Controls the clearing of edge type interrupts from the lower 16 bits of I/O Port.<br>1'b0: Nothing<br>1'b1: Clear edge-sensitive interrupt<br>When a 1 is written into a corresponding bit of this register, the interrupt is cleared and the bit is self cleared at once. Writing to this register has no effect on level-sensitive interrupts. All interrupts are cleared when I/O Port is not configured for interrupts. |

**GPIO PORT EOI H**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                             |
| 15:0       | R/W SC      | 0x0000             | port_eoi_high<br>Controls the clearing of edge type interrupts from the upper 16 bits of I/O Port.<br>1'b0: Nothing<br>1'b1: Clear edge-sensitive interrupt<br>When a 1 is written into a corresponding bit of this register, the interrupt is cleared and the bit is self cleared at once. Writing to this register has no effect on level-sensitive interrupts. All interrupts are cleared when I/O Port is not configured for interrupts. |

**GPIO EXT PORT**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | ext_port<br>This register always reflects the value of the signals on the external I/O Port. |

**GPIO VER ID**

Address: Operational Base + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>    |
|------------|-------------|--------------------|-----------------------|
| 31:0       | RO          | 0x0101157c         | ver_id<br>Version ID. |

**GPIO GPIO REG GROUP L**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_mask<br>Write enable for lower 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>gpio_reg_group_low<br/>This register controls the low 16 bit GPIO and each bit corresponds to each GPIO.<br/>When virtual_en=1'b1:<br/>1'b1: GPIO control by OS_A with offset 0x0000<br/>1'b0: GPIO control by OS_B with offset 0x1000<br/>When virtual_en=1'b0:<br/>1'b1: GPIO interrupt connect to gpio_int_flag<br/>1'b0: GPIO interrupt connect to gpio_int_flag_exp</p> |

**GPIO GPIO REG GROUP H**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                        |
| 15:0       | RW          | 0xffff             | <p>gpio_reg_group_high<br/>This register controls the high 16 bit GPIO and each bit corresponds to each GPIO.<br/>When virtual_en=1'b1:<br/>1'b1: GPIO control by OS_A with offset 0x0000<br/>1'b0: GPIO control by OS_B with offset 0x1000<br/>When virtual_en=1'b0:<br/>1'b1: GPIO interrupt connect to gpio_int_flag<br/>1'b0: GPIO interrupt connect to gpio_int_flag_exp</p> |

**GPIO GPIO VIRTUAL EN**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | <p>write_mask<br/>Write enable for lower 16 bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p> |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                                   |
| 0          | RW          | 0x0                | <p>gpio_virtual_en<br/>1'b1: Enable virtual, two OS supported<br/>1'b0: Disable virtual.</p>                                               |

**14.5 Interface Description**

Table 14-1 GPIO Interface Description

| <b>Module Pin</b>      | <b>Pad Name</b>                                       | <b>IOMUX Setting</b>                   |
|------------------------|-------------------------------------------------------|----------------------------------------|
| <b>GPIO0 Interface</b> |                                                       |                                        |
| gpio0_port[0]          | RTC_CLKO/REF_CLK_OUT/CLKIO_32K/UART0_RX_M0/GPIO0_A0_z | PMU_IOC_GPIO0A_IOMUX_SEL_L[2:0]=3'h0   |
| gpio0_port[1]          | TEST_CLK6_OUT/PWM2_M0/UART0_TX_M0/GPIO0_A1_d          | PMU_IOC_GPIO0A_IOMUX_SEL_L[6:4]=3'h0   |
| gpio0_port[2]          | TEST_CLK7_OUT//PWM3_IR_M0/GPI00_A2_d                  | PMU_IOC_GPIO0A_IOMUX_SEL_L[10:8]=3'h0  |
| gpio0_port[3]          | PMIC_SLEEP_M1/GPIO0_A3_u                              | PMU_IOC_GPIO0A_IOMUX_SEL_L[14:12]=3'h0 |
| gpio0_port[4]          | PWM1_M0/PMIC_SLEEP_M0/GPIO0_A4_d                      | PMU_IOC_GPIO0A_IOMUX_SEL_H[2:0]=3'h0   |
| gpio0_port[5]          | PWM5_M0/UART1_RTSN_M0/I2C1_S                          | PMU_IOC_GPIO0A_IOMUX_SEL               |

| <b>Module Pin</b>      | <b>Pad Name</b>                                                                        | <b>IOMUX Setting</b>                      |
|------------------------|----------------------------------------------------------------------------------------|-------------------------------------------|
|                        | CL_M0/GPIO0_A5_d                                                                       | _H[6:4]=3'h0                              |
| gpio0_port[6]          | PWM6_M0/UART1_CTSN_M0/I2C1_SDA_M0/GPIO0_A6_d                                           | PMU_IOC_GPIO0A_IOMUX_SEL_H[10:8]=3'h0     |
| <b>GPIO1 Interface</b> |                                                                                        |                                           |
| gpio1_port[0]          | PWM7_IR_M0/I2C2_SCL_M0/UART3_TX_M0/GPIO1_A0_d                                          | VCCIO1_IOC_GPIO1A_IOMUX_SEL_L[2:0]=3'h0   |
| gpio1_port[1]          | PWM4_M0/PMU_DEBUG/I2C2_SDA_M0/UART3_RX_M0/GPIO1_A1_d                                   | VCCIO1_IOC_GPIO1A_IOMUX_SEL_L[6:4]=3'h0   |
| gpio1_port[2]          | VICAP_D0_M1/AVS_ARM/PWM0_M0/GPIO1_A2_d                                                 | VCCIO1_IOC_GPIO1A_IOMUX_SEL_L[10:8]=3'h0  |
| gpio1_port[3]          | I2C0_SCL_M0/UART1_TX_M0/GPIO1_A3_d                                                     | VCCIO1_IOC_GPIO1A_IOMUX_SEL_L[14:12]=3'h0 |
| gpio1_port[4]          | I2C0_SDA_M0/UART1_RX_M0/GPIO1_A4_d                                                     | VCCIO1_IOC_GPIO1A_IOMUX_SEL_H[2:0]=3'h0   |
| gpio1_port[8]          | PWM3_IR_M1/UART4_RX_M0/GPIO1_B0_d                                                      | VCCIO1_IOC_GPIO1B_IOMUX_SEL_L[2:0]=3'h0   |
| gpio1_port[9]          | VICAP_D1_M1/SPI1_CS1n_M0/PWM7_IR_M1/UART4_TX_M0/GPIO1_B1_d                             | VCCIO1_IOC_GPIO1B_IOMUX_SEL_L[6:4]=3'h0   |
| gpio1_port[10]         | LPMCU_JTAG_TCK_M0/HPMCU_JTAG_TCK_M0/UART2_TX_M1/A7_JTAG_TC_K_M1/GPIO1_B2_d             | VCCIO1_IOC_GPIO1B_IOMUX_SEL_L[10:8]=3'h0  |
| gpio1_port[11]         | LPMCU_JTAG_TMS_M0/HPMCU_JTAG_TMS_M0/UART2_RX_M1/A7_JTAG_TMS_M1/GPIO1_B3_u              | VCCIO1_IOC_GPIO1B_IOMUX_SEL_L[14:12]=3'h0 |
| gpio1_port[16]         | SDMMC1_D1_M1/SPI0_CS0n_M0/PWM2_M2/VICAP_D2_M1/LCD_D7/GPIO1_C0_d                        | VCCIO6_IOC_GPIO1C_IOMUX_SEL_L[2:0]=3'h0   |
| gpio1_port[17]         | SDMMC1_D0_M1/SPI0_CLK_M0/PWM4_M2/VICAP_D3_M1/LCD_D6/GPIO1_C1_d                         | VCCIO6_IOC_GPIO1C_IOMUX_SEL_L[6:4]=3'h0   |
| gpio1_port[18]         | SPI0_MOSI_M0/SDMMC1_CLK_M1/I2C4_SCL_M1/PWM5_M2/VICAP_D4_M1/LCD_D5/GPIO1_C2_d           | VCCIO6_IOC_GPIO1C_IOMUX_SEL_L[10:8]=3'h0  |
| gpio1_port[19]         | SPI0_MISO_M0/SDMMC1_CMD_M1/I2C4_SDA_M1/PWM6_M2/VICAP_D5_M1/LCD_D4/GPIO1_C3_d           | VCCIO6_IOC_GPIO1C_IOMUX_SEL_L[14:12]=3'h0 |
| gpio1_port[20]         | SDMMC1_D3_M1/UART4_RX_M1/PWM8_M1/VICAP_D6_M1/LCD_D3/GPIO1_C4_d                         | VCCIO6_IOC_GPIO1C_IOMUX_SEL_H[2:0]=3'h0   |
| gpio1_port[21]         | SDMMC1_D2_M1/UART4_TX_M1/PWM9_M1/VICAP_D7_M1/LCD_D2/GPIO1_C5_d                         | VCCIO6_IOC_GPIO1C_IOMUX_SEL_H[6:4]=3'h0   |
| gpio1_port[22]         | UART4_RTSN_M1/PWM10_M1/VICAP_D8_M1/LCD_D1/GPIO1_C6_d                                   | VCCIO6_IOC_GPIO1C_IOMUX_SEL_H[10:8]=3'h0  |
| gpio1_port[23]         | UART4_CTSN_M1/PWM11_IR_M1/VICAP_D9_M1/LCD_D0/GPIO1_C7_d                                | VCCIO6_IOC_GPIO1C_IOMUX_SEL_H[14:12]=3'h0 |
| gpio1_port[24]         | UART3_TX_M1/UART5_RTSN_M1/PWM3_IR_M2/VICAP_CLKIN_M1/LCD_DEN/GPIO1_D0_d                 | VCCIO6_IOC_GPIO1D_IOMUX_SEL_L[2:0]=3'h0   |
| gpio1_port[25]         | UART3_RX_M1/UART5_CTSN_M1/PWM10_M2/VICAP_HSYNC_M1/LCD_HSYNC/NC/GPIO1_D1_d              | VCCIO6_IOC_GPIO1D_IOMUX_SEL_L[6:4]=3'h0   |
| gpio1_port[26]         | DSMAUDIO_P/PWM0_M1/SPI0_CS1n_M0/UART5_RX_M1/I2C3_SDA_M1/VICAP_VSYNC_M1/LCD_VSYNC/GPIO1 | VCCIO6_IOC_GPIO1D_IOMUX_SEL_L[10:8]=3'h0  |

| <b>Module Pin</b>      | <b>Pad Name</b>                                                                            | <b>IOMUX Setting</b>                      |
|------------------------|--------------------------------------------------------------------------------------------|-------------------------------------------|
| gpio1_port[27]         | _D2_d<br>DSMAUDIO_N/PWM11_IR_M2/UART5_TX_M1/I2C3_SCL_M1/VICAP_CLKOUT_M1/LCD_CLK/GPIO1_D3_d | VCCIO6_IOC_GPIO1D_IOMUX_SEL_L[14:12]=3'h0 |
| <b>GPIO2 Interface</b> |                                                                                            |                                           |
| gpio2_port[0]          | I2C4_SDA_M0/UART1_CTSN_M1/LCD_D8/I2S0_SCLK/SDMMC1_D1_M0/GPIO2_A0_d                         | VCCIO5_IOC_GPIO2A_IOMUX_SEL_L[2:0]=3'h0   |
| gpio2_port[1]          | I2C4_SCL_M0/UART1_RTSN_M1/LCD_D9/I2S0_LRCK/SDMMC1_D0_M0/GPIO2_A1_d                         | VCCIO5_IOC_GPIO2A_IOMUX_SEL_L[6:4]=3'h0   |
| gpio2_port[2]          | LCD_D10/I2S0_MCLK/SDMMC1_CLK_M0/GPIO2_A2_d                                                 | VCCIO5_IOC_GPIO2A_IOMUX_SEL_L[10:8]=3'h0  |
| gpio2_port[3]          | LCD_D11/I2S0_SDO3_SD1/SDMMC1_CMD_M0/GPIO2_A3_d                                             | VCCIO5_IOC_GPIO2A_IOMUX_SEL_L[14:12]=3'h0 |
| gpio2_port[4]          | UART1_TX_M1/LCD_D12/I2S0_SDO0/SDMMC1_D3_M0/GPIO2_A4_d                                      | VCCIO5_IOC_GPIO2A_IOMUX_SEL_H[2:0]=3'h0   |
| gpio2_port[5]          | UART1_RX_M1/LCD_D13/I2S0_SDI0/SDMMC1_D2_M0/GPIO2_A5_d                                      | VCCIO5_IOC_GPIO2A_IOMUX_SEL_H[6:4]=3'h0   |
| gpio2_port[6]          | FLASH_TRIG_OUT/I2C3_SCL_M0/PWM2_M1/LCD_D14/I2S0_SDO2_SD12/UART0_RTSN_M1/GPIO2_A6_d         | VCCIO5_IOC_GPIO2A_IOMUX_SEL_H[10:8]=3'h0  |
| gpio2_port[7]          | PRELIGHT_TRIG_OUT/I2C3_SDA_M0/PWM4_M1/LCD_D15/I2S0_SDO1_SD13/UART0_CTSN_M1/GPIO2_A7_d      | VCCIO5_IOC_GPIO2A_IOMUX_SEL_H[14:12]=3'h0 |
| gpio2_port[8]          | TEST_CLK4_OUT/PWM5_M1/LCD_D16/I2C1_SDA_M1/UART0_RX_M1/GPIO2_B0_d                           | VCCIO5_IOC_GPIO2B_IOMUX_SEL_L[2:0]=3'h0   |
| gpio2_port[9]          | TEST_CLK5_OUT/PWM6_M1/LCD_D17/I2C1_SCL_M1/UART0_TX_M1/GPIO2_B1_d                           | VCCIO5_IOC_GPIO2B_IOMUX_SEL_L[6:4]=3'h0   |
| <b>GPIO3 Interface</b> |                                                                                            |                                           |
| gpio3_port[1]          | SDMMC0_DET/GPIO3_A1_u                                                                      | VCCIO4_IOC_GPIO3A_IOMUX_SEL_L[6:4]=3'h0   |
| gpio3_port[2]          | PWM9_M0/TEST_CLK0_OUT/UART2_TX_M0/SDMMC0_D1/GPIO3_A2_u                                     | VCCIO4_IOC_GPIO3A_IOMUX_SEL_L[10:8]=3'h0  |
| gpio3_port[3]          | PWM8_M0/TEST_CLK1_OUT/UART2_RX_M0/SDMMC0_D0/GPIO3_A3_u                                     | VCCIO4_IOC_GPIO3A_IOMUX_SEL_L[14:12]=3'h0 |
| gpio3_port[4]          | PWM10_M0/LPMCU_JTAG_TCK_M1/I2C0_SCL_M2/UART5_RTSN_M0/SDMM_C0_CLK/GPIO3_A4_d                | VCCIO4_IOC_GPIO3A_IOMUX_SEL_H[2:0]=3'h0   |
| gpio3_port[5]          | PWM11_IR_M0/LPMCU_JTAG_TMS_M1/I2C0_SDA_M2/UART5_CTSN_M0/SDMMC0_CMD/GPIO3_A5_u              | VCCIO4_IOC_GPIO3A_IOMUX_SEL_H[6:4]=3'h0   |
| gpio3_port[6]          | HPMCU_JTAG_TMS_M1/A7_JTAG_TMS_M0/UART5_TX_M0/SDMMC0_D3/GPIO3_A6_u                          | VCCIO4_IOC_GPIO3A_IOMUX_SEL_H[10:8]=3'h0  |
| gpio3_port[7]          | HPMCU_JTAG_TCK_M1/A7_JTAG_TCK_M0/UART5_RX_M0/SDMMC0_D2/GPIO3_A7_u                          | VCCIO4_IOC_GPIO3A_IOMUX_SEL_H[14:12]=3'h0 |
| gpio3_port[8]          | MIPI/LVDS_D3N/VICAP_D0_M0/GPIO3_B0_d                                                       | VCCIO7_IOC_GPIO3B_IOMUX_SEL_L[2:0]=3'h0   |
| gpio3_port[9]          | MIPI/LVDS_D3P/VICAP_D1_M0/GPIO3_B1_d                                                       | VCCIO7_IOC_GPIO3B_IOMUX_SEL_L[6:4]=3'h0   |
| gpio3_port[10]         | MIPI/LVDS_CK1N/VICAP_D2_M0/GPI                                                             | VCCIO7_IOC_GPIO3B_IOMUX_                  |

| <b>Module Pin</b>      | <b>Pad Name</b>                                                       | <b>IOMUX Setting</b>                      |
|------------------------|-----------------------------------------------------------------------|-------------------------------------------|
|                        | O3_B2_d                                                               | SEL_L[10:8]=3'h0                          |
| gpio3_port[11]         | MIPI/LVDS_CK1P/VICAP_D3_M0/GPI_O3_B3_d                                | VCCIO7_IOC_GPIO3B_IOMUX_SEL_L[14:12]=3'h0 |
| gpio3_port[12]         | MIPI/LVDS_D2N/VICAP_D4_M0/GPIO3_B4_d                                  | VCCIO7_IOC_GPIO3B_IOMUX_SEL_H[2:0]=3'h0   |
| gpio3_port[13]         | MIPI/LVDS_D2P/VICAP_D5_M0/GPIO3_B5_d                                  | VCCIO7_IOC_GPIO3B_IOMUX_SEL_H[6:4]=3'h0   |
| gpio3_port[14]         | MIPI/LVDS_D1N/VICAP_D6_M0/GPIO3_B6_d                                  | VCCIO7_IOC_GPIO3B_IOMUX_SEL_H[10:8]=3'h0  |
| gpio3_port[15]         | MIPI/LVDS_D1P/VICAP_D7_M0/GPIO3_B7_d                                  | VCCIO7_IOC_GPIO3B_IOMUX_SEL_H[14:12]=3'h0 |
| gpio3_port[16]         | MIPI/LVDS_CK0N/VICAP_D8_M0/GPI_O3_C0_d                                | VCCIO7_IOC_GPIO3C_IOMUX_SEL_L[2:0]=3'h0   |
| gpio3_port[17]         | MIPI/LVDS_CK0P/VICAP_D9_M0/GPI_O3_C1_d                                | VCCIO7_IOC_GPIO3C_IOMUX_SEL_L[6:4]=3'h0   |
| gpio3_port[18]         | MIPI/LVDS_D0N/VICAP_CLKIN_M0/GPIO3_C2_d                               | VCCIO7_IOC_GPIO3C_IOMUX_SEL_L[10:8]=3'h0  |
| gpio3_port[19]         | MIPI/LVDS_D0P/VICAP_HSYNC_M0/GPIO3_C3_d                               | VCCIO7_IOC_GPIO3C_IOMUX_SEL_L[14:12]=3'h0 |
| gpio3_port[20]         | MIPI_REFCLK_OUT0/VICAP_CLKOUT_M0/GPIO3_C4_d                           | VCCIO7_IOC_GPIO3C_IOMUX_SEL_H[2:0]=3'h0   |
| gpio3_port[21]         | VICAP_VSYNC_M0/GPIO3_C5_d                                             | VCCIO7_IOC_GPIO3C_IOMUX_SEL_H[6:4]=3'h0   |
| gpio3_port[22]         | MIPI_REFCLK_OUT1/PWM7_IR_M2/VICAP_D10/GPIO3_C6_d                      | VCCIO7_IOC_GPIO3C_IOMUX_SEL_H[10:8]=3'h0  |
| gpio3_port[23]         | I2C4_SCL_M2/UART5_TX_M2/VICAP_D11/GPIO3_C7_d                          | VCCIO7_IOC_GPIO3C_IOMUX_SEL_H[14:12]=3'h0 |
| gpio3_port[24]         | I2C4_SDA_M2/UART5_RX_M2/VICAP_D12/GPIO3_D0_d                          | VCCIO7_IOC_GPIO3D_IOMUX_SEL_L[2:0]=3'h0   |
| gpio3_port[25]         | I2C3_SCL_M2/UART5_RTSN_M2/VIC_AP_D13/GPIO3_D1_d                       | VCCIO7_IOC_GPIO3D_IOMUX_SEL_L[6:4]=3'h0   |
| gpio3_port[26]         | I2C3_SDA_M2/UART5_CTSN_M2/VIC_AP_D14/GPIO3_D2_d                       | VCCIO7_IOC_GPIO3D_IOMUX_SEL_L[10:8]=3'h0  |
| gpio3_port[27]         | PWM1_M2/VICAP_D15/GPIO3_D3_d                                          | VCCIO7_IOC_GPIO3D_IOMUX_SEL_L[14:12]=3'h0 |
| <b>GPIO4 Interface</b> |                                                                       |                                           |
| gpio4_port[0]          | TEST_CLK2_OUT/I2C0_SDA_M1/UART0_RX_M2/SPI1_MISO_M0/EMMC_D7/GPIO4_A0_u | VCCIO3_IOC_GPIO4A_IOMUX_SEL_L[2:0]=3'h0   |
| gpio4_port[1]          | TEST_CLK3_OUT/I2C0_SCL_M1/UART0_TX_M2/SPI1_MOSI_M0/EMMC_D6/GPIO4_A1_u | VCCIO3_IOC_GPIO4A_IOMUX_SEL_L[6:4]=3'h0   |
| gpio4_port[2]          | FSPI_D2/EMMC_D2/GPIO4_A2_u                                            | VCCIO3_IOC_GPIO4A_IOMUX_SEL_L[10:8]=3'h0  |
| gpio4_port[3]          | FSPI_D1/EMMC_D1/GPIO4_A3_u                                            | VCCIO3_IOC_GPIO4A_IOMUX_SEL_L[14:12]=3'h0 |
| gpio4_port[4]          | FSPI_D0/EMMC_D0/GPIO4_A4_u                                            | VCCIO3_IOC_GPIO4A_IOMUX_SEL_H[2:0]=3'h0   |
| gpio4_port[5]          | I2C2_SDA_M1/UART1_TX_M2/SPI1_CS0n_M0/EMMC_D4/GPIO4_A5_u               | VCCIO3_IOC_GPIO4A_IOMUX_SEL_H[6:4]=3'h0   |
| gpio4_port[6]          | FSPI_D3/EMMC_D3/GPIO4_A6_u                                            | VCCIO3_IOC_GPIO4A_IOMUX_SEL_H[10:8]=3'h0  |
| gpio4_port[7]          | I2C2_SCL_M1/UART1_RX_M2/SPI1_CLK_M0/EMMC_D5/GPIO4_A7_u                | VCCIO3_IOC_GPIO4A_IOMUX_SEL_H[14:12]=3'h0 |
| gpio4_port[8]          | FSPI_CS0n/EMMC_CMD/GPIO4_B0_u                                         | VCCIO3_IOC_GPIO4B_IOMUX                   |

| <b>Module Pin</b> | <b>Pad Name</b>              | <b>IOMUX Setting</b>                    |
|-------------------|------------------------------|-----------------------------------------|
|                   |                              | SEL_L[2:0]=3'h0                         |
| gpio4_port[9]     | FSPI_CLK/EMMC_CLK/GPIO4_B1_d | VCCIO3_IOC_GPIO4B_IOMUX_SEL_L[6:4]=3'h0 |
| gpio4_port[16]    | ADCIN0(GPIO4_C0_z)           | VCCIO2_IOC_GPIO4C_IOMUX_SEL_L[2:0]=3'h0 |
| gpio4_port[17]    | PWM1_M1/ADCIN1/GPIO4_C1_z    | VCCIO2_IOC_GPIO4C_IOMUX_SEL_L[6:4]=3'h0 |

Notes: Unused Module Pin is tied to zero!

## 14.6 Application Notes

- 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 detection should be completed prior to enabling the interrupts to prevent spurious glitches on the interrupt output signal to the interrupt controller.

## Chapter 15 Inter-Integrated Circuit (I2C)

### 15.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 5 independent I2C: I2C0~4, with 13 pairs IOs.
- 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
- Filter out glitch on SCL and SDA

### 15.2 Block Diagram



Fig. 15-1 I2C architecture

#### 15.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 I2C\_RF component operates synchronously with the pclk.

#### 15.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 clk\_i2c.

#### 15.2.3 I2C\_TOP

I2C\_TOP module is the top module of the I2C controller.

## 15.3 Function Description

This chapter provides a description about the functions and behavior under various conditions.

The I2C controller supports only Master function. It supports 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.

### 15.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 to configure controller and uses clk\_i2c as the working clock. The correct register setting is subject to the system requirement.

### 15.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:

$$\text{SCL Divisor} = 8 * (\text{CLKDIVL} + 1 + \text{CLKDIVH} + 1); \text{clk\_i2c} = 100\text{MHz} \sim 200\text{MHz}.$$

$$\text{SCL} = \text{clk\_i2c} / \text{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. 15-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. 15-3 I2C Start and stop conditions

- ◆ Data transfer

- Acknowledge

After a byte of data transferring (clocks labeled as 1~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. 15-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.



Fig. 15-5 I2C byte transfer

## 15.4 Register Description

### 15.4.1 Registers Summary

| Name      | Offset | Size | Reset Value | Description      |
|-----------|--------|------|-------------|------------------|
| RKI2C_CON | 0x0000 | W    | 0x00050000  | Control register |

| Name            | Offset | Size | Reset Value | Description                                                                                |
|-----------------|--------|------|-------------|--------------------------------------------------------------------------------------------|
| RKI2C_CLKDIV    | 0x0004 | W    | 0x00000001  | Clock divider register I2C CLK = PCLK / (16*CLKDIV)                                        |
| RKI2C_MRADDR    | 0x0008 | W    | 0x00000000  | The slave address accessed for master rx mode                                              |
| RKI2C_MRADDR    | 0x000C | W    | 0x00000000  | The slave register address 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 received(0~32)                              |
| RKI2C_IEN       | 0x0018 | W    | 0x00000000  | Interrupt enable register                                                                  |
| RKI2C_IPD       | 0x001C | W    | 0x00000000  | Interrupt pending register                                                                 |
| RKI2C_FCNT      | 0x0020 | W    | 0x00000000  | Finished count: the count of data which has been transmitted or received for debug purpose |
| RKI2C_SCL_OE_DB | 0x0024 | W    | 0x00000020  | Slave hold debounce configure 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                                                                     |
| RKI2C_TXDATA4   | 0x0110 | W    | 0x00000000  | I2C tx data register 4                                                                     |
| RKI2C_TXDATA5   | 0x0114 | W    | 0x00000000  | I2C tx data register 5                                                                     |
| RKI2C_TXDATA6   | 0x0118 | W    | 0x00000000  | I2C tx data register 6                                                                     |
| RKI2C_TXDATA7   | 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    | 0x00000000  | Status debug register                                                                      |
| RKI2C_DBGCTRL   | 0x0224 | W    | 0x00000000  | Debug config register                                                                      |
| RKI2C_CON1      | 0x0228 | W    | 0x00000000  | Control register                                                                           |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 15.4.2 Detail Registers Description

#### RKI2C\_CON

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                          |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0005      | version<br>Rki2c version information.                                                                                                                |
| 15:14 | RW   | 0x0         | stop_setup<br>Stop setup config.<br>TSU;sto = (stop_setup + 1) * T(SCL_HIGH) + Tclk_i2c.                                                             |
| 13:12 | RW   | 0x0         | start_setup<br>Start setup config.<br>TSU;sta = (start_setup + 1) * T(SCL_HIGH) + Tclk_i2c.<br>THD;sta = (start_setup + 2) * T(SCL_HIGH) - Tclk_i2c. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x0                | data_upd_st<br>SDA update point config.<br>Used to config sda change state when scl is low, used to adjust setup/hold time.<br>4'bn: Thold = (n + 1) * Tclk_i2c.<br>Note: 0 <= n <= 5                                                                                                                                                  |
| 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          | 0x0                | ack<br>Last byte acknowledge control in master receive mode.<br>1'b0: ACK<br>1'b1: NAK                                                                                                                                                                                                                                                 |
| 4          | RW          | 0x0                | stop<br>Stop enable, when this bit is written to 1, I2C will generate stop signal.                                                                                                                                                                                                                                                     |
| 3          | RW          | 0x0                | start<br>Start enable, when this bit is written to 1, I2C will generate start signal.                                                                                                                                                                                                                                                  |
| 2:1        | RW          | 0x0                | i2c_mode<br>I2c mode select.<br>2'b00: Transmit only.<br>2'b01: Transmit address (device + register address) --> Restart --> Transmit address -> Receive only.<br>2'b10: Receive only.<br>2'b11: Transmit address (device + register address, write/read bit is 1) --> Restart --> Transmit address (device address) --> Receive data. |
| 0          | RW          | 0x0                | i2c_en<br>I2c module enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                          |

**RKI2C\_CLKDIV**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | CLKDIVH<br>SCL high level clock count.<br>$T(SCL\_HIGH) = Tclk\_i2c * (CLKDIVH + 1) * 8$ . |
| 15:0       | RW          | 0x0001             | CLKDIVL<br>SCL low level clock count.<br>$T(SCL\_LOW) = Tclk\_i2c * (CLKDIVL + 1) * 8$ .   |

**RKI2C\_MRXADDR**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                                            |
| 26         | RW          | 0x0                | addhvld<br>Address high byte valid.<br>1'b0: Invalid<br>1'b1: Valid |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 25         | RW          | 0x0                | addmvlid<br>Address middle byte valid.<br>1'b0: Invalid<br>1'b1: Valid                                   |
| 24         | RW          | 0x0                | addlvld<br>Address low byte valid.<br>1'b0: Invalid<br>1'b1: Valid                                       |
| 23:0       | RW          | 0x000000           | saddr<br>Master address register.<br>The lowest bit indicate write or read.<br>24 bits address register. |

**RKI2C\_MRXRADDR**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                                                 |
| 26         | RW          | 0x0                | sraddhvld<br>Address high byte valid.<br>1'b0: Invalid<br>1'b1: Valid    |
| 25         | RW          | 0x0                | sraddmvlid<br>Address middle byte valid.<br>1'b0: Invalid<br>1'b1: Valid |
| 24         | RW          | 0x0                | sraddlvld<br>Address low byte valid.<br>1'b0: Invalid<br>1'b1: Valid     |
| 23:0       | RW          | 0x000000           | saddr<br>Slave register address accessed.<br>24 bits register address    |

**RKI2C\_MTXCNT**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                           |
| 5:0        | RW          | 0x00               | mtxcnt<br>Master transmit count.<br>6 bits counter |

**RKI2C\_MRXCNT**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                     |
| 5:0        | RW          | 0x00               | mrxcnt<br>Master rx count.<br>6 bits counter |

**RKI2C\_IEN**

Address: Operational Base + offset (0x0018)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 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          | 0x0                | stopien<br>Stop operation finished interrupt enable.<br>1'b0: Disable<br>1'b1: Enable       |
| 4          | RW          | 0x0                | 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          | 0x0                | 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               |

**RKI2C IPD**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                           |
| 7          | RW          | 0x0                | 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          | W1<br>C     | 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          | W1<br>C     | 0x0                | 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          | W1<br>C     | 0x0                | 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. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | W1<br>C     | 0x0                | 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 clear. |
| 2          | W1<br>C     | 0x0                | 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 clear. |
| 1          | W1<br>C     | 0x0                | 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          | W1<br>C     | 0x0                | 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                            |
| 5:0        | RO          | 0x00               | fcnt<br>The count of data which has been transmitted or received for debug purpose. |

**RKI2C\_SCL\_OE\_DB**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                                                       |
| 7:0        | RW          | 0x20               | scl_oe_db<br>Slave hold scl debounce.<br>Cycles for debounce (unit: Tclk_i2c). |

**RKI2C\_TXDATA0**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata0<br>Data0 to be transmitted.<br>32 bits data |

**RKI2C\_TXDATA1**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata1<br>Data1 to be transmitted.<br>32 bits data |

**RKI2C\_TXDATA2**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata2<br>Data2 to be transmitted.<br>32 bits data |

**RKI2C TXDATA3**

Address: Operational Base + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata3<br>Data3 to be transmitted.<br>32 bits data |

**RKI2C TXDATA4**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata4<br>Data4 to be transmitted.<br>32 bits data |

**RKI2C TXDATA5**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata5<br>Data5 to be transmitted.<br>32 bits data |

**RKI2C TXDATA6**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata6<br>Data6 to be transmitted.<br>32 bits data |

**RKI2C TXDATA7**

Address: Operational Base + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdata7<br>Data7 to be transmitted.<br>32 bits data |

**RKI2C RXDATA0**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata0<br>Data0 received.<br>32 bits data |

**RKI2C RXDATA1**

Address: Operational Base + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata1<br>Data1 received.<br>32 bits data |

**RKI2C RXDATA2**

Address: Operational Base + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata2<br>Data2 received.<br>32 bits data |

**RKI2C\_RXDATA3**

Address: Operational Base + offset (0x020C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata3<br>Data3 received.<br>32 bits data |

**RKI2C\_RXDATA4**

Address: Operational Base + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata4<br>Data4 received.<br>32 bits data |

**RKI2C\_RXDATA5**

Address: Operational Base + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata5<br>Data5 received.<br>32 bits data |

**RKI2C\_RXDATA6**

Address: Operational Base + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata6<br>Data6 received.<br>32 bits data |

**RKI2C\_RXDATA7**

Address: Operational Base + offset (0x021C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000000         | rxdata7<br>Data7 received.<br>32 bits data |

**RKI2C\_ST**

Address: Operational Base + offset (0x0220)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                 |
| 1          | RO          | 0x0                | scl_st<br>SCL status.<br>1'b0: SCL status low.<br>1'b0: SCL status high. |
| 0          | RO          | 0x0                | sda_st<br>SDA status.<br>1'b0: SDA status low.<br>1'b0: SDA status high. |

**RKI2C\_DBGCTRL**

Address: Operational Base + offset (0x0224)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | h0_check_scl<br>1'b0: Check if scl been pull down by slave at the whole SCL_HIGH.<br>1'b1: Check if scl been pull down by slave only at the h0 of SCL_HIGH(SCL_HIGH including h0~h7). |
| 13         | RW          | 0x0                | nak_release_scl<br>1'b0: Hold scl as low when received nack.<br>1'b1: Release scl as high when received nack.                                                                         |
| 12         | RW          | 0x0                | flt_en<br>SCL edage glitch filter enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                            |
| 11:8       | RW          | 0x0                | slv_hold_scl_th<br>Slave hold scl threshold = slv_hold_scl_db * Tclk_i2c.                                                                                                             |
| 7:4        | RW          | 0x0                | flt_r<br>Filter scl rising edge glitches of width less than flt_r * Tclk_i2c.                                                                                                         |
| 3:0        | RW          | 0x0                | flt_f<br>Filter scl falling edge glitches of width less than flt_f * Tclk_i2c.                                                                                                        |

**RKI2C CON1**

Address: Operational Base + offset (0x0228)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                                                                          |
| 2          | RW          | 0x0                | auto_stop_nak<br>Auto stop when i2c master received nak from slave.<br>Work when CON1[0]=1'b1.<br>1'b0: Do not auto stop when received nak.<br>1'b1: Auto stop when received nak. |
| 1          | RW          | 0x0                | auto_stop_tx_end<br>Auto stop when i2c master tx end.<br>Work when CON1[0]=1'b1.<br>1'b0: Do not auto stop when tx end.<br>1'b1: Auto stop when tx end.                           |
| 0          | RW          | 0x0                | auto_stop<br>Auto stop when i2c master received nak from slave or tx end.<br>1'b0: Do not auto stop when received nak or tx end.<br>1'b1: Auto stop when received nak or tx end.  |

## 15.5 Interface Description

Table 15-1 I2C Interface Description

| Module pin  | Direction | Pin name                                                                             | IOMUX                                   |
|-------------|-----------|--------------------------------------------------------------------------------------|-----------------------------------------|
| I2C0_SCL_M0 | I/O       | I2C0_SCL_M0/UART1_TX_M0/GPIO1_A3_d                                                   | VENCIOC_GPIO1A_IOMUX_SEL_L[15:12] = 0x2 |
| I2C0_SDA_M0 | I/O       | I2C0_SDA_M0/UART1_RX_M0/GPIO1_A4_d                                                   | VENCIOC_GPIO1A_IOMUX_SEL_H[3:0] = 0x2   |
| I2C0_SCL_M1 | I/O       | TEST_CLK3_OUT/I2C0_SCL_M1/UART0_TX_M2/SPI1_MOSI_M0/EMMC_D6(GPIO4_A1_u)               | PERIIOC_GPIO4A_IOMUX_SEL_L[7:4] = 0x4   |
| I2C0_SDA_M1 | I/O       | TEST_CLK2_OUT/I2C0_SDA_M1/UART0_RX_M2/SPI1_MISO_M0/EMMC_D7(GPIO4_A0_u)               | PERIIOC_GPIO4A_IOMUX_SEL_L[3:0] = 0x4   |
| I2C0_SCL_M2 | I/O       | PWM10_M0/LPMCU_JTAG_TCK_M1/I2C0_SCL_M2/UART5_RTSN_M0/SDMMC0_CL_K(GPIO3_A4_d)         | VIIOC_GPIO3A_IOMUX_SEL_H[3:0] = 0x3     |
| I2C0_SDA_M2 | I/O       | PWM11_IR_M0/LPMCU_JTAG_TMS_M1/I2C0_SDA_M2/UART5_CTSN_M0/SDMMC0_CMD(GPIO3_A5_u)       | VIIOC_GPIO3A_IOMUX_SEL_H[7:4] = 0x3     |
| I2C1_SCL_M0 | I/O       | PWM5_M0/UART1_RTSN_M0/I2C1_SCL_M0/GPIO0_A5_d                                         | PMUIOC_GPIO0A_IOMUX_SEL_H[7:4] = 0x1    |
| I2C1_SDA_M0 | I/O       | PWM6_M0/UART1_CTSN_M0/I2C1_SDA_M0/GPIO0_A6_d                                         | PMUIOC_GPIO0A_IOMUX_SEL_H[11:8] = 0x1   |
| I2C1_SCL_M1 | I/O       | TEST_CLK5_OUT/PWM6_M1/LCD_D17/I2C1_SCL_M1/UART0_TX_M1(GPIO2_B1_d)                    | VOIOC_GPIO2B_IOMUX_SEL_L[3:0] = 0x2     |
| I2C1_SDA_M1 | I/O       | TEST_CLK4_OUT/PWM5_M1/LCD_D16/I2C1_SDA_M1/UART0_RX_M1(GPIO2_B0_d)                    | VOIOC_GPIO2B_IOMUX_SEL_L[7:4] = 0x2     |
| I2C2_SCL_M0 | I/O       | PWM7_IR_M0/I2C2_SCL_M0/UART3_TX_M0/GPIO1_A0_d                                        | VENCIOC_GPIO1A_IOMUX_SEL_L[3:0] = 0x2   |
| I2C2_SDA_M0 | I/O       | PWM4_M0/PMU_DEBUG/I2C2_SDA_M0/UART3_RX_M0/GPIO1_A1_d                                 | VENCIOC_GPIO1A_IOMUX_SEL_L[7:4] = 0x2   |
| I2C2_SCL_M1 | I/O       | I2C2_SCL_M1/UART1_RX_M2/SPI1_CLK_M0/EMMC_D5(GPIO4_A7_u)                              | PERIIOC_GPIO4A_IOMUX_SEL_H[15:12] = 0x4 |
| I2C2_SDA_M1 | I/O       | I2C2_SDA_M1/UART1_TX_M2/SPI1_CS0n_M0/EMMC_D4(GPIO4_A5_u)                             | PERIIOC_GPIO4A_IOMUX_SEL_H[7:4] = 0x4   |
| I2C3_SCL_M0 | I/O       | FLASH_TRIG_OUT/I2C3_SCL_M0/PWM2_M1/LCD_D14/I2S0_SDO2_SDID2/UART0_RTSN_M1(GPIO2_A6_d) | VOIOC_GPIO2A_IOMUX_SEL_H[11:8] = 0x5    |

| Module pin  | Direction | Pin name                                                                                    | IOMUX                                     |
|-------------|-----------|---------------------------------------------------------------------------------------------|-------------------------------------------|
| I2C3_SDA_M0 | I/O       | PRELIGHT_TRIG_OUT/I2C3_SDA_M0/PWM4_M1/LCD_D15/I2S0_SDO1_SD13/UART0_CTSN_M1/GPIO2_A7_d       | VOIOC_GPIO2A_IOMUX_SEL_H[15:12] = 0x5     |
| I2C3_SCL_M1 | I/O       | DSMAUDIO_N//PWM11_IR_M2/UART5_TX_M1/I2C3_SCL_M1/VICAP_CLKOUT_M1/LCD_CLK/GPIO1_D3_d          | VENCIOC_GPIO1D_IOMUX_SEL_L_L[15:12] = 0x3 |
| I2C3_SDA_M1 | I/O       | DSMAUDIO_P/PWM0_M1/SPI0_CS1n_M0/UART5_RX_M1/I2C3_SDA_M1/VICAP_VSYNC_M1/LCD_VSYNC/GPIO1_D2_d | VENCIOC_GPIO1D_IOMUX_SEL_L_L[11:8] = 0x3  |
| I2C3_SCL_M2 | I/O       | I2C3_SCL_M2/UART5_RTSN_M2/VICAP_D13/GPIO3_D1_d                                              | VIIOC_GPIO3D_IOMUX_SEL_L[7:4] = 0x3       |
| I2C3_SDA_M2 | I/O       | I2C3_SDA_M2/UART5_CTSN_M2/VICAP_D14/GPIO3_D2_d                                              | VIIOC_GPIO3D_IOMUX_SEL_L[11:8] = 0x3      |
| I2C4_SCL_M0 | I/O       | I2C4_SCL_M0/UART1_RTSN_M1/LCD_D9/I2S0_LRCK/SDMMC1_D0_M0/GPIO2_A1_d                          | VOIOC_GPIO2A_IOMUX_SEL_L[7:4] = 0x5       |
| I2C4_SDA_M0 | I/O       | I2C4_SDA_M0/UART1_CTSN_M1/LCD_D8/I2S0_SCLK/SDMMC1_D1_M0/GPIO2_A0_d                          | VOIOC_GPIO2A_IOMUX_SEL_L[3:0] = 0x5       |
| I2C4_SCL_M1 | I/O       | SPI0_MOSI_M0/SDMMC1_CLK_M1/I2C4_SCL_M1/PWM5_M2/VICAP_D4_M1/LCD_D5/GPIO1_C2_d                | VENCIOC_GPIO1C_IOMUX_SEL_L[11:8] = 0x4    |
| I2C4_SDA_M1 | I/O       | SPI0_MISO_M0/SDMMC1_CMD_M1/I2C4_SDA_M1/PWM6_M2/VICAP_D5_M1/LCD_D4/GPIO1_C3_d                | VENCIOC_GPIO1C_IOMUX_SEL_L[15:12] = 0x4   |
| I2C4_SCL_M2 | I/O       | I2C4_SCL_M2/UART5_TX_M2/VICAP_D11/GPIO3_C7_d                                                | VIIOC_GPIO3C_IOMUX_SEL_H[15:12] = 0x3     |
| I2C4_SDA_M2 | I/O       | I2C4_SDA_M2/UART5_RX_M2/VICAP_D12/GPIO3_D0_d                                                | VIIOC_GPIO3D_IOMUX_SEL_L[3:0] = 0x3       |

## 15.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)



Fig. 15-6 I2C Flow chat for transmit only mode

- Receive only mode (I2C\_CON[1:0]=2'b10)



Fig. 15-7 I2C Flow chat for receive only mode

- Mix mode ( $\text{I2C\_CON}[1:0]=2'b01$  or  $\text{I2C\_CON}[1:0]=2'b11$ )



Fig. 15-8 I2C Flow chat for mix mode

## Chapter 16 I2S

### 16.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. 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.

#### 16.1.1 Features

- Support eight internal 32-bit wide and 32-location deep FIFOs
- 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 and receiving in PCM mode
- Support 8-channel audio transmitting and receiving in I2S 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 configurable SCLK and LRCK polarity
- Support loopback function and rx channel data select

Support SDI, SDO IOMUX.

### 16.2 Block Diagram



Fig. 16-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. By the divider of the module, the clock generator generates SCLK and LRCK to transmitter and receiver.

**TX\_CTRL**

For I2S/PCM/TDM Controller, TX\_CTRL includes TDM transmitter and I2S/PCM transmitter. 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.

**RX\_CTRL**

For I2S/PCM/TDM Controller, RX\_CTRL includes TDM receiver and I2S/PCM 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.

**TX FIFO**

The transmit FIFO is the buffer to store transmitted audio data. The size of one FIFO is 32bits x 32.

**RX FIFO**

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

## 16.3 Function Description

In the I2S/PCM/TDM, 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.



Fig. 16-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. 16-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.

### 16.3.1 I2S Normal Mode

There is an APB slave interface in RTC. It is responsible for accessing registers.

This is the waveform of I2S normal mode. For LRCK (i2s\_lrck) 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. 16-4 I2S Normal Mode Timing Format

### 16.3.2 I2S Left Justified Mode

This is the waveform of I2S left justified mode. For LRCK (i2s\_lrck) 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. 16-5 I2S Left Justified Mode Timing Format

### 16.3.3 I2S Right Justified Mode

This is the waveform of I2S right justified mode. For LRCK (i2s\_lrck) 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. 16-6 I2S Right Justified Mode Timing Format

### 16.3.4 PCM Early Mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck) 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. 16-7 PCM Early Mode Timing Format

### 16.3.5 PCM Late1 Mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck) 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. 16-8 PCM Late1 Mode Timing Format

### 16.3.6 PCM Late2 Mode

This is the waveform of PCM early mode. For LRCK (*i2s\_lrck*) 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. 16-9 PCM Late2 Mode Timing Format

### 16.3.7 PCM Late3 Mode

This is the waveform of PCM early mode. For LRCK (*i2s\_lrck*) 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. 16-10 PCM Late3 Mode Timing Format

### 16.3.8 TDM Normal Mode (PCM Format)

This is the waveform of TDM normal mode. For LRCK (*i2s\_lrck*) 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) on the second falling edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 16-11 TDM Normal Mode Timing Format (PCM Format)

### 16.3.9 TDM Left Shift Mode0 (PCM Format)

This is the waveform of PCM early mode. For LRCK (i2s\_lrck) 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) on the second rising edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 16-12 TDM Left Shift Mode 0 Timing Format (PCM Format)

### 16.3.10 TDM Left Shift Mode1 (PCM Format)

This is the waveform of PCM early mode. For LRCK (i2s\_lrck) 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) on the first falling edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 16-13 TDM Left Shift Mode 1 Timing Format (PCM Format)

### 16.3.11 TDM Left Shift Mode2 (PCM Format)

This is the waveform of PCM early mode. For LRCK (i2s\_lrck) 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) on the first rising edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig. 16-14 TDM Left Shift Mode 2 Timing Format (PCM Format)

### 16.3.12 TDM Left Shift Mode3 (PCM Format)

This is the waveform of PCM early mode. For LRCK (i2s1\_lrck) 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. 16-15 TDM Left Shift Mode 3 Timing Format (PCM Format)

### 16.3.13 TDM Normal Mode (I2S Format)

This is the waveform of I2S normal mode. For SD (i2s\_sdo, i2s\_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.

`tdm_txctrl[17]/tdm_rxctrl[17]=1:`



`tdm_txctrl[17]/tdm_rxctrl[17]=0:`



Fig. 16-16 TDM Normal Mode Timing Format (I2S Format)

### 16.3.14 TDM Left Justified Mode (I2S Format)

This is the waveform of I2S left justified mode. 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.



`tdm_txctrl[17]/tdm_rxctrl[17]=1:`



Fig. 16-17 TDM Left Justified Mode Timing Format (I2S Format)

### 16.3.15 TDM Right Justified Mode (I2S Format)

This is the waveform of I2S right justified mode. 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 range of SD signal width is from 16 to 32bits.



tdm\_txctrl[17]/tdm\_rxctrl[17]=1:



Fig. 16-18 TDM Right Justified Mode Timing Format (I2S Format)

## 16.4 Register Description

### 16.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

### 16.4.2 Registers Summary

| Name                       | Offset | Size | Reset Value | Description                                  |
|----------------------------|--------|------|-------------|----------------------------------------------|
| I2S TDM 8CH TXCR           | 0x0000 | W    | 0x7200000F  | Transmit Operation Control Register          |
| I2S TDM 8CH RXCR           | 0x0004 | W    | 0x01C8000F  | Receive Operation Control Register           |
| I2S TDM 8CH CKR            | 0x0008 | W    | 0x00001F1F  | Clock Generation Register                    |
| I2S TDM 8CH TXFIFOLR       | 0x000C | W    | 0x00000000  | TX FIFO Level Register                       |
| I2S TDM 8CH DMACR          | 0x0010 | W    | 0x001F0000  | DMA Control Register                         |
| I2S TDM 8CH INTCR          | 0x0014 | W    | 0x01F00000  | Interrupt Control Register                   |
| I2S TDM 8CH INTSR          | 0x0018 | W    | 0x00000000  | Interrupt Status Register                    |
| I2S TDM 8CH XFER           | 0x001C | W    | 0x00000000  | Transfer Start Register                      |
| I2S TDM 8CH CLR            | 0x0020 | W    | 0x00000000  | Sclk Domain Logic Clear Register             |
| I2S TDM 8CH TXDR           | 0x0024 | W    | 0x00000000  | Transmit FIFO Data Register                  |
| I2S TDM 8CH RXDR           | 0x0028 | W    | 0x00000000  | Receive FIFO Data Register                   |
| I2S TDM 8CH RXFIFOLR       | 0x002C | W    | 0x00000000  | RX FIFO Level Register                       |
| I2S TDM 8CH TDM TXC<br>TRL | 0x0030 | W    | 0x00003EFF  | TDM Mode Transmit Operation Control Register |

| Name                    | Offset | Size | Reset Value | Description                                 |
|-------------------------|--------|------|-------------|---------------------------------------------|
| I2S TDM 8CH TDM RXC TRL | 0x0034 | W    | 0x00003EFF  | TDM Mode Receive Operation Control Register |
| I2S TDM 8CH CLKDIV      | 0x0038 | W    | 0x00000707  | Clock Divider Register                      |
| I2S TDM 8CH VERSION     | 0x003C | W    | 0x20050001  | Version Register                            |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**-Double WORD (64 bits) access

### 16.4.3 Detail Registers Description

#### I2S TDM 8CH TXCR

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                   |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RO   | 0x0         | reserved                                                                                                                                                                                                                                      |
| 30:29 | RW   | 0x3         | tx_path_select3<br>Tx path select<br>2'b00: Sd03 output data from path0<br>2'b01: Sd03 output data from path1<br>2'b10: Sd03 output data from path2<br>2'b11: Sd03 output data from path3<br>Note: When TDM mode, only path0 enable.          |
| 28:27 | RW   | 0x2         | tx_path_select2<br>Tx path select<br>2'b00: Sd02 output data from path0<br>2'b01: Sd02 output data from path1<br>2'b10: Sd02 output data from path2<br>2'b11: Sd02 output data from path3<br>Note: When TDM mode, only path0 enable.          |
| 26:25 | RW   | 0x1         | tx_path_select1<br>Tx path select<br>2'b00: Sd01 output data from path0<br>2'b01: Sd01 output data from path1<br>2'b10: Sd01 output data from path2<br>2'b11: Sd01 output data from path3<br>Note: When TDM mode, only path0 enable.          |
| 24:23 | RW   | 0x0         | tx_path_select0<br>Tx path select<br>2'b00: Sd00 output data from path0<br>2'b01: Sd00 output data from path1<br>2'b10: Sd00 output data from path2<br>2'b11: Sd00 output data from path3<br>Note: When TDM mode, only path0 enable.          |
| 22:17 | RW   | 0x00        | rcnt<br>(Can be written only when XFER[0] bit is 0.)<br>Only valid in I2S Right justified format and slave TX mode is selected.<br>Start to transmit data RCNT sclk cycles after left channel valid.<br>Note: Only function when TX TFS[1]=0. |
| 16:15 | RW   | 0x0         | tcsr<br>Transmit channel select register<br>2'b00: Two channel<br>2'b01: Four channel<br>2'b10: Six channel<br>2'b11: Eight channel                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | <p>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 channel and high 16 bit for right channel.<br/>1'b1: Low 16bit data valid from AHB/APB bus, high 16 bit data invalid.</p>                                                                           |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                             |
| 12         | RW          | 0x0                | <p>sjm<br/>Store justified mode<br/>(Can be written only when XFER[0] bit is 0.)<br/>1'b0: Right justified<br/>1'b1: Left justified<br/>16bit~31bit DATA stored in 32 bits width FIFO.<br/>If VDW select 16bit data, this bit is valid only when HWT select 0. Because if HWT is 1, every FIFO unit contains two 16bit data and 32 bit space is full, it is impossible to choose justified mode.</p> |
| 11         | RW          | 0x0                | <p>fbm<br/>First Bit Mode<br/>(Can be written only when XFER[0] bit is 0.)<br/>1'b0: MSB<br/>1'b1: LSB</p>                                                                                                                                                                                                                                                                                           |
| 10:9       | RW          | 0x0                | <p>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</p>                                                                                                                                                                                                                  |
| 8:7        | RW          | 0x0                | <p>pbm<br/>(Can be written only when XFER[0] bit is 0.)<br/>2'b00: PCM no delay mode<br/>2'b01: PCM delay 1 mode<br/>2'b10: PCM delay 2 mode<br/>2'b11: PCM delay 3 mode<br/>Note: Function when TX TFS[1:0] is 1.</p>                                                                                                                                                                               |
| 6:5        | RW          | 0x0                | <p>tfs<br/>(Can be written only when XFER[0] 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)</p>                                                                                                                                                                                                                        |
| 4:0        | RW          | 0x0f               | <p>vdw<br/>Valid data width<br/>(Can be written only when XFER[0] bit is 0.)<br/>5'h00~5'b0e: Reserved<br/>5'h0f: 16bit<br/>5'h10: 17bit<br/>5'h11: 18bit<br/>5'h12: 19bit<br/>.....<br/>5'h1c: 29bit<br/>5'h1d: 30bit<br/>5'h1e: 31bit<br/>5'h1f: 32bit</p>                                                                                                                                         |

**I2S TDM 8CH RXCR**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 24:23      | RW          | 0x3                | rx_path_select3<br>Rx path select<br>2'b00: Path3 data from sdi0<br>2'b01: Path3 data from sdi1<br>2'b10: Path3 data from sdi2<br>2'b11: Path3 data from sdi3<br>Note: Inoperative at TDM mode.                                                                                                                                                                                         |
| 22:21      | RW          | 0x2                | rx_path_select2<br>Rx path select<br>2'b00: Path2 data from sdi0<br>2'b01: Path2 data from sdi1<br>2'b10: Path2 data from sdi2<br>2'b11: Path2 data from sdi3<br>Note: Inoperative at TDM mode.                                                                                                                                                                                         |
| 20:19      | RW          | 0x1                | rx_path_select1<br>Rx path select<br>2'b00: Path1 data from sdi0<br>2'b01: Path1 data from sdi1<br>2'b10: Path1 data from sdi2<br>2'b11: Path1 data from sdi3<br>Note: Inoperative at TDM mode.                                                                                                                                                                                         |
| 18:17      | RW          | 0x0                | rx_path_select0<br>Rx path select<br>2'b00: Path0 data from sdi0<br>2'b01: Path0 data from sdi1<br>2'b10: Path0 data from sdi2<br>2'b11: Path0 data from sdi3                                                                                                                                                                                                                           |
| 16:15      | RW          | 0x0                | rCSR<br>Receive channel select register<br>2'b00: Two channel<br>2'b01: Four channel<br>2'b10: Six channel<br>2'b11: Eight channel                                                                                                                                                                                                                                                      |
| 14         | RW          | 0x0                | 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 channel and high 16 bit for right channel.<br>1'b1: Low 16bit data valid to AHB/APB bus, high 16 bit data invalid.                                                                              |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 12         | RW          | 0x0                | sjm<br>Store justified mode<br>(Can be written only when XFER[1] bit is 0.)<br>1'b0: Right justified<br>1'b1: Left justified<br>16bit~31bit DATA stored in 32 bits width FIFO.<br>If VDW select 16bit data, this bit is valid only when HWT select 0. Because if HWT is 1, every FIFO unit contains two 16bit data and 32 bit space is full, it is impossible to choose justified mode. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | fbm<br>First bit mode<br>(Can be written only when XFER[1] bit is 0.)<br>1'b0: MSB<br>1'b1: LSB                                                                                                                                           |
| 10:9       | RW          | 0x0                | ibm<br>I2S bus mode<br>(Can be written only when XFER[1] bit is 0.)<br>2'b00: I2S normal<br>2'b01: I2S left justified<br>2'b10: I2S right justified<br>2'b11: Reserved                                                                    |
| 8:7        | RW          | 0x0                | pbm<br>PCM bus mode<br>(Can be written only when XFER[1] bit is 0.)<br>2'b00: PCM no delay mode<br>2'b01: PCM delay 1 mode<br>2'b10: PCM delay 2 mode<br>2'b11: PCM delay 3 mode                                                          |
| 6:5        | RW          | 0x0                | 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          | 0x0f               | vdw<br>Valid data width<br>(Can be written only when XFER[1] bit is 0.)<br>5'h00~5'b0e: Reserved<br>5'h0f: 16bit<br>5'h10: 17bit<br>5'h11: 18bit<br>5'h12: 19bit<br>.....<br>5'h1c: 29bit<br>5'h1d: 30bit<br>5'h1e: 31bit<br>5'h1f: 32bit |

**I2S TDM 8CH CKR**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |
| 29:28      | RW          | 0x0                | lrck_common<br>TX and RX common use<br>2'b00/2'b11: Tx_lrck/rx_lrck are used as synchronous signal for 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. |
| 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)                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26         | RW          | 0x0                | <p>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</p>                                                                                                                                                                                                                                                                 |
| 25         | RW          | 0x0                | <p>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: Low valid)</p>  |
| 24         | RW          | 0x0                | <p>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: Low valid)</p> |
| 23:16      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15:8       | RW          | 0x1f               | <p>rsd<br/>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 = (receive sclk<br/>divider/2)*2*frequency of rx_lrck<br/>Note: Function when RX TFS[1:0] is 2'b00 or 2'b01.</p>                                                                                                                                                                                                                          |
| 7:0        | RW          | 0x1f               | <p>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 = (Transmit sclk<br/>divider/2)*2*frequency of tx_lrck<br/>Note: Function when TX TFS[1:0] is 2'b00 or 2'b01.</p>                                                                                                                                                                                                                        |

**I2S TDM 8CH TXFIFOLR**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                         |
| 23:18      | RW          | 0x00               | tfl3<br>Transmit fifo3 level<br>Contains the number of valid data entries in the transmit fifo3. |
| 17:12      | RW          | 0x00               | tfl2<br>Transmit fifo2 level<br>Contains the number of valid data entries in the transmit FIFO2. |
| 11:6       | RW          | 0x00               | tfl1<br>Transmit fifo1 level<br>Contains the number of valid data entries in the transmit fifo1. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 5:0        | RO          | 0x00               | tfl0<br>Transmit fifo0 level<br>Contains the number of valid data entries in the transmit fifo0. |

**I2S TDM 8CH DMACR**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 24         | RW          | 0x0                | 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 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          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 8          | RW          | 0x0                | 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 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 TX FIFO(TX FIFO0 if CSR=00;TX FIFO1 if CSR=01,TX FIFO2 if CSR=10,TX FIFO3 if CSR=11)is equal to or below this field value. |

**I2S TDM 8CH INTCR**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                                                                                               |
| 24:20      | RW          | 0x1f               | rft<br>Receive fifo threshold<br>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                                                                                                                                                               |
| 18         | WO          | 0x0                | rxoic<br>RX overrun interrupt clear<br>Write 1 to clear RX overrun interrupt.                                                                                          |
| 17         | RW          | 0x0                | rxoie<br>RX overrun interrupt enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                  |
| 16         | RW          | 0x0                | rxifie<br>RX full interrupt enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                    |
| 15:9       | RO          | 0x00               | reserved                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:4        | RW          | 0x00               | tft<br>Transmit fifo threshold<br>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                                                                                                                                                            |
| 2          | RW          | 0x0                | txuic<br>TX underrun interrupt clear<br>Write 1 to clear TX underrun interrupt.                                                                                     |
| 1          | RW          | 0x0                | txuie<br>TX underrun interrupt enable<br>1'b0: Disable<br>1'b1: Enable                                                                                              |
| 0          | RW          | 0x0                | txeie<br>TX empty interrupt enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                 |

**I2S TDM 8CH INSTR**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                        |
| 17         | RO          | 0x0                | rxoi<br>RX overrun interrupt<br>1'b0: Inactive<br>1'b1: Active  |
| 16         | RO          | 0x0                | rfi<br>RX full interrupt<br>1'b0: Inactive<br>1'b1: Active      |
| 15:2       | RO          | 0x0000             | reserved                                                        |
| 1          | RO          | 0x0                | txui<br>TX underrun interrupt<br>1'b0: Inactive<br>1'b1: Active |
| 0          | RO          | 0x0                | txei<br>TX empty interrupt<br>1'b0: Inactive<br>1'b1: Active    |

**I2S TDM 8CH XFER**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                     |
| 4          | RW          | 0x0                | rxch_sel<br>0: I2S normal mode<br>1: I2S left justified and right justified  |
| 3          | RW          | 0x0                | loopback_mode2<br>loopback_en<br>1'b0: Stop loopback<br>1'b1: Start loopback |
| 2          | RW          | 0x0                | loopback_mode1<br>loopback_en<br>1'b0: Stop loopback<br>1'b1: Start loopback |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | rxs<br>RX start bit<br>1'b0: Stop RX transfer<br>1'b1: Start RX transfer          |
| 0          | RW          | 0x0                | txs<br>TX transfer start bit<br>1'b0: Stop TX transfer<br>1'b1: Start TX transfer |

**I2S TDM 8CH CLR**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                  |
| 1          | RW          | 0x0                | rxc<br>RX logic clear<br>This is a self-cleared bit. Write 1 to clear all receive logic.  |
| 0          | RW          | 0x0                | txc<br>TX logic clear<br>This is a self-cleared bit. Write 1 to clear all transmit logic. |

**I2S TDM 8CH TXDR**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | txdr<br>Transmit fifo data register<br>When it is written, data are moved into the transmit fifo. |

**I2S TDM 8CH RXDR**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | rxdr<br>Receive fifo data register<br>When the register is read, data in the receive fifo is accessed. |

**I2S TDM 8CH RXFIFOLR**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                       |
| 23:18      | RW          | 0x00               | rfl3<br>Receive fifo3 level<br>Contains the number of valid data entries in the receive fifo3. |
| 17:12      | RW          | 0x00               | rfl2<br>Receive fifo2 level<br>Contains the number of valid data entries in the receive fifo2. |
| 11:6       | RW          | 0x00               | rfl1<br>Receive fifo1 level<br>Contains the number of valid data entries in the receive fifo1. |
| 5:0        | RW          | 0x00               | rfl0<br>Receive fifo0 level<br>Contains the number of valid data entries in the receive fifo0. |

**I2S TDM 8CH TDM TXCTRL**

Address: Operational Base + offset (0x0030)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20:18      | RW          | 0x0                | <p>tx_tdm_fsync_width_sel1<br/>           TDM transfer fsync width sel1<br/>           (Can be written only when XFER[0] is 0.)<br/>           3'b000: Single period of the sclk_tx.<br/>           3'b001: 2 period of the sclk_tx.<br/>           n: n+1 period of the sclk_tx.<br/>           3'b110: 7 period of the sclk_tx.<br/>           3'b111: The width is equivalent to a channel block.<br/>           Note: Function when TX TFS[1:0] is 2 or 3.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 17         | RW          | 0x0                | <p>tx_tdm_fsync_width_sel0<br/>           TDM transfer fsync width sel0<br/>           (Can be written only when XFER[0] is 0.)<br/>           1'b0: 1/2 frame width. It should be set to an even number.<br/>           1'b1: Frame width.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 16:14      | RW          | 0x0                | <p>tdm_tx_shift_ctrl<br/>           TDM transfer shift ctrl<br/>           (Can be written only when XFER[0] is 0.)<br/>           3'b000:<br/>           PCM format 0: Normal mode, drive data on the second negedge of sclk_tx after rising edge of TX LRCK.<br/>           I2S format 0: Normal mode<br/>           3'b001:<br/>           PCM format 1: 1/2 cycle shift left, drive data on second posedge of sclk_tx after rising edge of TX LRCK.<br/>           I2S format 1: Left justified mode<br/>           3'b010:<br/>           PCM format 2: 1 cycle shift left, drive data on first negedge of sclk_tx after rising edge of TX LRCK.<br/>           I2S format 2: Right justified mode<br/>           3'b011:<br/>           PCM format 3: 3/2 cycle shift left, drive data on first posedge of sclk_tx after rising edge of TX LRCK.<br/>           I2S format: Not support<br/>           3'b100:<br/>           PCM format 4: 2 cycle shift left, drive data aligned to the posedge of TX LRCK.<br/>           I2S format: Not support<br/>           3'b101~3'b111: Not support<br/>           Note: Function when TX TFS[1:0] is 2 or 3.</p> |
| 13:9       | RW          | 0x1f               | <p>tdm_tx_slot_bit_width<br/>           TDM transfer slot bits<br/>           (Can be written only when XFER[0] is 0.)<br/>           5'h00~5'h0e: Reserved<br/>           5'h0f: 16bit<br/>           5'h10: 17bit<br/>           5'h11: 18bit<br/>           5'h12: 19bit<br/>           .....<br/>           5'h1f: 32bit<br/>           Note: Function when TX TFS[1:0] is 2 or 3.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0        | RW          | 0x0ff              | <p>tdm_tx_frame_width<br/>TDM transfer frame width<br/>(Can be written only when XFER[0] is 0.)<br/>9'h000~9'h01e: Reserved<br/>9'h01f: 32bit<br/>9'h020: 33bit<br/>9'h021: 34bit<br/>9'h022: 35bit<br/>.....<br/>9'h1ff: 512bit</p> <p>Note: Functional when TX TFS[1:0] is 2 or 3.</p> |

**I2S TDM 8CH TDM RXCTRL**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 20:18      | RW          | 0x0                | <p>tx_tdm_fsync_width_sel1<br/>TDM receive fsync width sel1<br/>(Can be written only when XFER[1] is 0.)<br/>3'b000: Single period of the sclk_rx.<br/>3'b001: 2 period of the sclk_rx.<br/>n: n+1 period of the sclk_rx.<br/>3'b110: 7 period of the sclk_rx.<br/>3'b111: The width is equivalent to a channel block</p> <p>Note: Function when RX TFS[1:0] is 2 or 3.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 17         | RW          | 0x0                | <p>rx_tdm_fsync_width_sel0<br/>TDM receive fsync width sel0<br/>(Can be written only when XFER[1] is 0.)<br/>1'b0: 1/2 frame width. It should be set to an even number.<br/>1'b1: Frame width</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 16:14      | RW          | 0x0                | <p>tdm_rx_shift_ctrl<br/>TDM receive shift ctrl<br/>(Can be written only when XFER[1] is 0.)<br/>3'b000:<br/>PCM format 0: Normal mode, sample data on the third posedge of sclk_rx after rising edge of RX LRCK.<br/>I2S format 0: Normal mode<br/>3'b001:<br/>PCM format 1: 1/2 cycle shift left, sample data on second negedge of sclk_rx after rising edge of RX LRCK.<br/>I2S format 1: left justified mode<br/>3'b010:<br/>PCM format 2: 1 cycle shift left, sample data on second posedge of sclk_rx after rising edge of RX LRCK.<br/>I2S format 2: Right justified mode<br/>3'b011:<br/>PCM format 3: 3/2 cycle shift left, sample data on first negedge of sclk_rx after rising edge of RX LRCK.<br/>I2S format: Not support<br/>3'b100:<br/>PCM format 4: 2 cycle shift left, sample data on the first posedge of sclk_rx after rising edge of RX LRCK.<br/>I2S format: Not support<br/>3'b101~3'b111: Not support</p> <p>Note: Function when RX TFS[1:0] is 2 or 3.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:9       | RW          | 0x1f               | <p>tdm_rx_slot_bit_width<br/>TDM receive slot bits<br/>(Can be written only when XFER[1] is 0.)<br/>5'h00~5'h0e: Reserved<br/>5'h0f: 16bit<br/>5'h10: 17bit<br/>5'h11: 18bit<br/>5'h12: 19bit<br/>.....<br/>5'h1f: 32bit<br/>Note: Function when RX TFS[1:0] is 2 or 3.</p>          |
| 8:0        | RW          | 0x0ff              | <p>tdm_rx_frame_width<br/>TDM receive frame width<br/>(Can be written only when XFER[1] is 0.)<br/>9'h000~9'h01e: Reserved<br/>9'h01f: 32bit<br/>9'h020: 33bit<br/>9'h021: 34bit<br/>9'h022: 35bit<br/>.....<br/>9'h1ff: 512bit<br/>Note: Functional when RX TFS[1:0] is 2 or 3.</p> |

**I2S TDM 8CH CLKDIV**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                             |
| 15:8       | RW          | 0x07               | <p>rx_mdiv<br/>RX mclk divider<br/>(Can be written only when XFER[1] bit is 0.)<br/>mclk_rx divider = (mclk_rx/sclk_rx)-1.<br/>For example, if mclk_rx divider is 5, then the frequency of sclk_rx is mclk_rx/6.</p> |
| 7:0        | RW          | 0x07               | <p>tx_mdiv<br/>TX mclk fivider<br/>(Can be written only when XFER[0] bit is 0.)<br/>mclk_tx divider = (mclk_tx/sclk_tx)-1.<br/>For example, if mclk_tx divider is 5, then the frequency of sclk_tx is mclk_tx/6.</p> |

**I2S TDM 8CH VERSION**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:0       | RO          | 0x20050001         | i2s_version        |

**16.5 Interface Description**

The following table shows the I2S0 interface description.

Table 16-1 I2S0 Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>                                                            | <b>IO_MUX Setting</b>                    |
|-------------------|------------------|----------------------------------------------------------------------------|------------------------------------------|
| i2s0_mclk         | I/O              | LCD_D10/I2S0_MCLK/SDMMC1_CLK_M0/<br>GPIO2_A2_d                             | VO_IOC_GPIO2A_IOMUX_<br>SEL_L[10:8]=3'h2 |
| i2s0_sclk         | I/O              | I2C4_SDA_M0/UART1_CTSN_M1/LCD_D8<br>/I2S0_SCLK/SDMMC1_D1_M0/GPIO2_A0<br>_d | VO_IOC_GPIO2A_IOMUX_<br>SEL_L[2:0]=3'h2  |

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>                                                                        | <b>IOMUX Setting</b>                  |
|-------------------|------------------|----------------------------------------------------------------------------------------|---------------------------------------|
| i2s0_lrck         | I/O              | SDMMC1_D0_M0/I2S0_LRCK_M0/LCD_D9/UART1_RTSN_M1/I2C4_SCL_M0/VCCI_O5/GPIO2_a1            | VO_IOC_GPIO2A_IOMUX_SEL_L[6:4]=3'h2   |
| i2s0_sdo0         | O                | UART1_TX_M1/LCD_D12/I2S0_SDO0/SDMMC1_D3_M0/GPIO2_A4_d                                  | VO_IOC_GPIO2A_IOMUX_SEL_H[2:0]=3'h2   |
| i2s0_sdo1         | O                | PRELIGHT_TRIG_OUT/I2C3_SDA_M0/PWM4_M1/LCD_D15/I2S0_SDO1_SDID3/UART0_CTSN_M1/GPIO2_A7_d | VO_IOC_GPIO2A_IOMUX_SEL_H[14:12]=3'h2 |
| i2s0_sdo2         | O                | FLASH_TRIG_OUT/I2C3_SCL_M0/PWM2_M1/LCD_D14/I2S0_SDO2_SDID2/UART0_RTSN_M1/GPIO2_A6_d    | VO_IOC_GPIO2A_IOMUX_SEL_H[10:8]=3'h2  |
| i2s0_sdo3         | O                | LCD_D11/I2S0_SDO3_SDID1/SDMMC1_CMD_M0/GPIO2_A3_d                                       | VO_IOC_GPIO2A_IOMUX_SEL_L[14:12]=3'h2 |
| i2s0_sdi0         | I                | UART1_RX_M1/LCD_D13/I2S0_SDID0/SDMMC1_D2_M0/GPIO2_A5_d                                 | VO_IOC_GPIO2A_IOMUX_SEL_H[6:4]=3'h2   |
| i2s0_sdi1         | I                | LCD_D11/I2S0_SDO3_SDID1/SDMMC1_CMD_M0/GPIO2_A3_d                                       | VO_IOC_GPIO2A_IOMUX_SEL_L[14:12]=3'h2 |
| i2s0_sdi2         | I                | FLASH_TRIG_OUT/I2C3_SCL_M0/PWM2_M1/LCD_D14/I2S0_SDO2_SDID2/UART0_RTSN_M1/GPIO2_A6_d    | VO_IOC_GPIO2A_IOMUX_SEL_H[10:8]=3'h2  |
| i2s0_sdi3         | I                | PRELIGHT_TRIG_OUT/I2C3_SDA_M0/PWM4_M1/LCD_D15/I2S0_SDO1_SDID3/UART0_CTSN_M1/GPIO2_A7_d | VO_IOC_GPIO2A_IOMUX_SEL_H[14:12]=3'h2 |

## 16.6 Application Notes

### **16.6.1 Software Application Notes**



Fig. 16-19 I2S/PCM/TDM Controller Transmit 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.*

I2S/PCM/TDM controllers can support up to 16 channels when operate in TDM mode.

Following configurations must be observed when in 16-channel TDM mode before starting sending or receiving audio data.

- Set I2S TDM 8CH TXCR.TFS to 2'b11 or I2S TDM 8CH RXCR.TFS to 2'b11.
  - Set I2S TDM 8CH TDM TXCTRL.TX\_TDM\_FSYNC\_WIDTH\_SEL0 to 1'b1 or I2S TDM 8CH TDM RXCTRL.RX\_TDM\_FSYNC\_WIDTH\_SEL0 to 1'b1.
  - Set other registers properly.

## Chapter 17 Digital Audio Codec

### 17.1 Overview

Digital Audio Codec is a 16-bit digital audio encoder which supports multiple sample rates. It is mainly composed of digital DAC. The aim of digital DAC is to process the data received from I2S/PCM interface through filters, volume control and modulation.

The Digital Audio Codec supports the following features.

- Support 8-bit APB bus slave interface
  - Support 2-channel digital DAC
  - Support 1-channel audio DSM format output
  - Support I2S/PCM interface
  - Support I2S/PCM master and slave mode
  - Support 2-channel audio receiving in I2S mode
  - Support 2-channel audio receiving in PCM mode
  - 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 configurable SCLK and LRCK polarity
  - Support 16 bit sample resolution
  - Support programmable left and right channel exchangeable in I2S mode and PCM mode
  - Support three modes of mixing for every digital DAC channel
  - Support volume control
- Support programmable negative and positive volume gain

### 17.2 Block Diagram



Fig. 17-1 Digital Audio Codec Block Diagram

#### **ACDC\_RF**

The **ACDC\_RF** implements the 8-bit APB slave operation through APB bus. It is responsible for configuring the operation registers of other modules.

#### **ACDC\_CRU**

The **ACDC\_CRU** implements clock and reset generation function. It is responsible for generating sample clock, digital DAC operation clock and I2S operation clock.

#### **Digital DAC**

There are 2 digital DAC channels. The digital DAC receives audio data from **ACDC\_I2S**

module. It includes one CIC filter, one high-pass filter, several low-pass decimation filters and other audio signal processing related modules. The output of digital DAC is sent to DSM modular before transmitting outside.

### **ACDC\_I2S**

The I2S/PCM audio interface can be configured to master mode or slave mode. In Master Mode, SCLK and LRCK are configured as output. In slave mode, SCLK and LRCK are configured as input. The ACDC\_I2S module can only operate in RX mode. When in RX mode, it receives audio data from I2S RX interface and sends it to digital DAC.

### **DSM Modulator**

It is a modulator that converts 16 bits audio sample data to 1 bit audio data.

## **17.3 Function description**

The I2S/PCM interface of Digital Audio Codec is connected to the I2S0 controller. Please refer to the I2S chapter for detailed information about I2S and PCM format that Digital Audio Codec supports.

### **17.3.1 Filters of Digital DAC**

I2S module receives two-channel audio data from I2S RX interface and drives it to the digital DAC which supports mixing function or directly to the DSM modulator. How to pour 2-channel audio data into 2-channel digital DAC can be achieved by programming mixing mode.

The 2-channel digital DAC includes a high-pass filter and a maximum of 5 half-band filters. The high-pass filter is used to filter DC components in audio data stream. Result of high-pass filter is sent to the digital DAC volume control module. The input of 5 half-band filters comes from output of volume control module with each perform 2-times interpolation. But not all of them are working all the time. How many of them are needed to work depends on the sample rate of digital DAC. The result of half-band filters is sent to a modulator.

### **17.3.2 Volume Control**

For digital DAC, output of high-pass filters is fed into volume control module. The volume control module inside digital DAC contains several sub-modules such as peak detect, frequency cross zero detect, LIMITER and digital gain control. It can be digitally attenuated over a range of -96dB~0dB in 0.375dB/step for negative gain and amplified over a range of 0dB~96dB in 0.375dB/step for positive gain. Whether is attenuated or amplified can be software programmed.

## **17.4 Register Description**

### **17.4.1 Internal Address Mapping**

Slave address can be divided into different length for different usage, which is shown as follows.

### **17.4.2 Registers Summary**

| Name                    | Offset | Size | Reset Value | Description                            |
|-------------------------|--------|------|-------------|----------------------------------------|
| ACDCDIG_DACVUCTL        | 0x0140 | W    | 0x00000001  | DAC Volume Control Register            |
| ACDCDIG_DACVUCTIME      | 0x0144 | W    | 0x00000000  | DAC Volume Control Time Limit Register |
| ACDCDIG_DACDIGIN        | 0x0148 | W    | 0x00000000  | DAC Digital Enable Register            |
| ACDCDIG_DACCLKCTRL      | 0x014C | W    | 0x00000000  | DAC Clock Control Register             |
| ACDCDIG_DACINT_DIV      | 0x0154 | W    | 0x00000007  | DAC Integer Clock Divider Register     |
| ACDCDIG_DACSCLKRXINTDIV | 0x0160 | W    | 0x0000001F  | I2S SCLK RX Integer Divider Register   |
| ACDCDIG_DACDSM_DIV      | 0x0164 | W    | 0x00000003  | DSM Mode Integer Divider Register      |

| Name                | Offset | Size | Reset Value | Description                                     |
|---------------------|--------|------|-------------|-------------------------------------------------|
| ACDCDIG_DACDSM_CTRL | 0x0168 | W    | 0x00000000  | DSM Mode Control Register                       |
| ACDCDIG_DACCFG1     | 0x0184 | W    | 0x00000004  | DAC Configure Register 1                        |
| ACDCDIG_DACMUTE     | 0x0188 | W    | 0x00000000  | DAC Mute Control Register                       |
| ACDCDIG_DACMUTEST   | 0x018C | W    | 0x00000000  | DAC Mute Status Register                        |
| ACDCDIG_DACVOLLO    | 0x0190 | W    | 0x00000000  | Volume of DAC Left Channel 0 Register           |
| ACDCDIG_DACVOLR0    | 0x01A0 | W    | 0x00000000  | Volume of DAC right Channel 1 Register          |
| ACDCDIG_DACVOGP     | 0x01B0 | W    | 0x00000000  | DAC Volume Gain Polarity Register               |
| ACDCDIG_DACRVOLLO   | 0x01B4 | W    | 0x000000FF  | Internal Volume of DAC Left Channel 0 Register  |
| ACDCDIG_DACRVOLR0   | 0x01C4 | W    | 0x000000FF  | Internal Volume of DAC right Channel 1 Register |
| ACDCDIG_DACLMT0     | 0x01D4 | W    | 0x00000000  | DAC Limiter Register 0                          |
| ACDCDIG_DACLMT1     | 0x01D8 | W    | 0x00000000  | DAC Limiter Register 1                          |
| ACDCDIG_DACLMT2     | 0x01DC | W    | 0x00000000  | DAC Limiter Register 2                          |
| ACDCDIG_DACMIXCTRLL | 0x01E0 | W    | 0x00000000  | DAC Mixing Control Register Of Left Channels    |
| ACDCDIG_DACMIXCTRLR | 0x01E4 | W    | 0x00000000  | DAC Mixing Control Register Of right Channels   |
| ACDCDIG_DACHPF      | 0x01E8 | W    | 0x00000000  | DAC High-pass Filter Control Register           |
| ACDCDIG_I2S_RXCR0   | 0x030C | W    | 0x0000000F  | Receive Operation Control Register 0            |
| ACDCDIG_I2S_RXCR1   | 0x0310 | W    | 0x00000000  | Receive Operation Control Register 1            |
| ACDCDIG_I2S_CKR0    | 0x0314 | W    | 0x00000000  | Clock Generation Register 0                     |
| ACDCDIG_I2S_CKR1    | 0x0318 | W    | 0x00000000  | Clock Generation Register 1                     |
| ACDCDIG_I2S_XFER    | 0x031C | W    | 0x00000000  | Transfer Start Register                         |
| ACDCDIG_I2S_CLR     | 0x0320 | W    | 0x00000000  | SCLK Domain Logic Clear Register                |
| ACDCDIG_VERSION     | 0x0380 | W    | 0x00000002  | Version Register                                |

Notes:  
**Size:** **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 17.4.3 Detail Registers Description

#### ACDCDIG\_DACVUCTL

Address: Operational Base + offset (0x0140)

| Bit  | Attr | Reset Value | Description                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | RO   | 0x00000000  | reserved                                                                                                                             |
| 2    | RW   | 0x0         | dac_byps<br>Digital DAC volume control bypass.<br>1'b0: Digital DAC volume control enable<br>1'b1: Digital DAC volume control bypass |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | dacfade<br>Digital DAC volume adjust mode.<br>1'b0: Update to new volume immediately.<br>1'b1: Update volume as daczdt field describes.                                                                                                                      |
| 0          | RW          | 0x1                | daczdt<br>Digital DAC volume cross zero detect enable. It works when dac_byps is 1'b0 and dacfade is 1'b1.<br>1'b0: Volume adjusts every sample.<br>1'b1: Volume adjusts only when audio waveform crosses zero or volume control time limit condition meets. |

**ACDCDIG\_DACVUCTIME**

Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                               |
| 7:0        | RW          | 0x00               | dacvuct<br>Volume control time limit, valid only in fade cross zero mode.<br>Time limit = dacvuct*(1/sample rate)<br>Unit: Sample rate |

**ACDCDIG\_DACDIGEN**

Address: Operational Base + offset (0x0148)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0000000          | reserved                                                                                                                                                                                                  |
| 4          | RW          | 0x0                | dacglben<br>Global enable of all Digital DAC channels. Only when dacglben and the enable signal corresponding to each Digital DAC channel is valid before starting work.<br>1'b0: Disable<br>1'b1: Enable |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                  |
| 0          | RW          | 0x0                | dacen_l0r1<br>Digital DAC left channel 0 and right channel 1 enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                     |

**ACDCDIG\_DACCLKCTRL**

Address: Operational Base + offset (0x014C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0000000          | reserved                                                                        |
| 5          | RW          | 0x0                | dac_cke<br>Digital DAC operation clock enable.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | i2srx_cke<br>Clock enable of internal I2S RX channel.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                                                                                          |
| 3          | RW          | 0x0                | cke_bclk_rx<br>Clock enable of sclk_out_rx.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                                                                                                    |
| 2          | RW          | 0x0                | dac_sync_ena<br>Enable of the synchronization signal used internally generated by Digital DAC.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                                                 |
| 1          | RO          | 0x0                | dac_sync_status<br>There is a counter to generate synchronization signal of Digital DAC. In order to ensure the integrity of synchronization signal, it is necessary to read back dac_sync_status to judge whether the counter stops working when dac_sync_ena is set from 1'b1 to 1'b0. If the signal is read back to 1'b0, it means that the counter stops working and the synchronization signal of Digital DAC is complete. |
| 0          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |

**ACDCDIG\_DACINT\_DIV**

Address: Operational Base + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                   |
| 7:0        | RW          | 0x07               | int_div_con<br>Integer clock divider to provide 6.144/5.644/4.096MHz sample clock for internal filters. Make sure that int_div_con is an odd number between 7(8 times division) and 15(16 times division). |

**ACDCDIG\_DACSCLKRXINT\_DIV**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                      |
| 7:0        | RW          | 0x1f               | sckrxdiv<br>Integer clock divider to generate sclk_out_rx when I2S RX works in master mode. It is ignored when in slave mode. |

**ACDCDIG\_DACDSM\_DIV**

Address: Operational Base + offset (0x0164)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 7:0        | RW          | 0x03               | audio_dsm_div<br>DSM mode division of Digital DAC's operation clock. |

**ACDCDIG DACDSM CTRL**

Address: Operational Base + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                       |
| 6          | RW          | 0x0                | dsm_mode_cke<br>Clock enable of 1-bit DSM modulator<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                           |
| 5:4        | RW          | 0x0                | dsm_mode<br>Audio DSM mode selection<br>2'b01: Audio DSM mode 0. The input of 1-bit DSM modulator is from the last filter of Audio DAC.<br>2'b10: Audio DSM mode 1. The input of 1-bit DSM modulator is directly from output of I2S RX inside the ACDCDIG.<br>Others: Reserved |
| 3          | RW          | 0x0                | dsm_en<br>1-bit DSM modulator enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                          |
| 2:0        | RW          | 0x0                | dith_sel<br>Dith mode selection of 1-bit DSM modulator.                                                                                                                                                                                                                        |

**ACDCDIG DACCFG1**

Address: Operational Base + offset (0x0184)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                   |
| 4:2        | RW          | 0x1                | dacsrt<br>Sample rates of Digital DAC when in audio DSM mode 0. This field is ignored when in audio DSM mode 1.<br>3'b000: 12kHz/11.024kHz/8kHz<br>3'b001: 24kHz/22.05kHz/16kHz<br>3'b010: 32kHz/48kHz/44.1kHz<br>3'b011: 96kHz/88.2kHz/64kHz<br>3'b100: 192kHz/176.4kHz/128kHz<br>3'b101~3'b111: Reserved |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                   |

**ACDCDIG DACMUTE**

Address: Operational Base + offset (0x0188)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | dacunmt<br>1'b0: DAC normal mode<br>1'b1: DAC unmute mode. In this mode, DAC volume control block will adjust volume to match the value in DACVOLL* and DACVOLR*. |
| 0          | RW          | 0x0                | dacmt<br>1'b0: DAC normal mode<br>1'b1: DAC mute mode                                                                                                             |

**ACDCDIG DACMUTEST**

Address: Operational Base + offset (0x018C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                           |
| 4          | RO          | 0x0                | unmutest_l0r1<br>Unmute status for Digital DAC left channel 0 and right channel 1. When unmute is done, it indicates that internal volume is equal to the value programmed in DACVOLL* and DACVOLR*.<br>1'b0: Unmute not done<br>1'b1: Unmute done |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                           |
| 0          | RO          | 0x0                | mutest_l0r1<br>Mute status for Digital DAC left channel 0 and right channel 1.<br>1'b0: Not mute<br>1'b1: Mute                                                                                                                                     |

**ACDCDIG DACVOLLO**

Address: Operational Base + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                        |
| 7:0        | RW          | 0x00               | daclv0<br>Volume of Digital DAC left channel 0.<br>0db~ -95.625db, 0.375db/step.<br>8'h0: 0db<br>8'h1: -0.375db<br>8'h2: -0.75db<br>8'h3: -1.125db<br>.....<br>8'hff: -95.625db |

**ACDCDIG DACVOLR0**

Address: Operational Base + offset (0x01A0)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | RW          | 0x00               | dacrv0<br>Volume of Digital DAC right channel 1.<br>0db~ -95.625db, 0.375db/step.<br>8'h0: 0db<br>8'h1: -0.375db<br>8'h2: -0.75db<br>8'h3: -1.125db<br>.....<br>8'hff: -95.625db |

**ACDCDIG DACVOGP**

Address: Operational Base + offset (0x01B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                              |
| 1          | RW          | 0x0                | volgpr1<br>Gain polarity for the volume of Digital DAC right channel 1.<br>1'b0: Negative gain<br>1'b1: Positive gain |
| 0          | RW          | 0x0                | volgpl0<br>Gain polarity for the volume of Digital DAC left channel 0.<br>1'b0: Negative gain<br>1'b1: Positive gain  |

**ACDCDIG DACRVOLLO**

Address: Operational Base + offset (0x01B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                           |
| 7:0        | RO          | 0xff               | rvollo<br>Internal real-time volume of Digital DAC left channel 0. |

**ACDCDIG DACRVOLRO**

Address: Operational Base + offset (0x01C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                            |
| 7:0        | RO          | 0xff               | rvolr0<br>Internal real-time volume of Digital DAC right channel 1. |

**ACDCDIG DACLMTO**

Address: Operational Base + offset (0x01D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                  |
| 1          | RW          | 0x0                | limen<br>LIMITER enable.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | limdct<br>Limiter detect mode.<br>1'b0: (Left channel + right channel)/2<br>1'b0: Left channel or right channel independently |

**ACDCDIG DACLMT1**

Address: Operational Base + offset (0x01D8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                     |
| 7:4        | RW          | 0x0                | atk_rate<br>LIMITER attack rate=(power(2, atk_rate)*(8*clk)), clk is such as 4.096Mhz, 5.6448Mhz, 6.144Mhz.  |
| 3:0        | RW          | 0x0                | rls_rate<br>LIMITER release rate=(power(2, rls_rate)*(8*clk)), clk is such as 4.096MHz, 5.6448MHz, 6.144MHz. |

**ACDCDIG DACLMT2**

Address: Operational Base + offset (0x01DC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                     |
| 6:4        | RW          | 0x0                | max_lilmt<br>The highest threshold of LIMITER.<br>3'b000~3'b100: 0db~-12db, 3db/step<br>3'b101~3'b111: -18db~-30db, 6db/step |
| 3          | RO          | 0x0                | reserved                                                                                                                     |
| 2:0        | RW          | 0x0                | min_lilmt<br>The lowest threshold of LIMITER.<br>3'b000~3'b100: 0db~-12db, 3db/step<br>3'b101~3'b111: -18db~-30db, 6db/step  |

**ACDCDIG DACMIXCTRLL**

Address: Operational Base + offset (0x01E0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                              |
| 1:0        | RW          | 0x0                | mixmode_l0<br>Digital DAC left channel 0 mixing mode.<br>2'b00: Left channel<br>2'b01: Right channel<br>2'b10~2'b11: (Left channel + right channel)/2 |

**ACDCDIG DACMIXCTRLR**

Address: Operational Base + offset (0x01E4)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | mixmode_r0<br>Digital DAC right channel 1 mixing mode.<br>2'b00: Left channel<br>2'b01: Right channel<br>2'b10~2'b11: (Left channel + right channel)/2 |

**ACDCDIG\_DACHPF**

Address: Operational Base + offset (0x01E8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                   |
| 5:4        | RW          | 0x0                | hpcf<br>High-pass filter control.<br>2'b00: 80Hz<br>2'b01: 100Hz<br>2'b10: 120Hz<br>2'b11: 140Hz                                                           |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                   |
| 0          | RW          | 0x0                | hpfen_l0r1<br>High-pass filter enable for left channel 0 and right channel 1.<br>1'b0: High-pass filter is disabled.<br>1'b1: High-pass filter is enabled. |

**ACDCDIG\_I2S\_RXCRO**

Address: Operational Base + offset (0x030C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                         |
| 7:6        | RW          | 0x0                | pbm<br>PCM bus mode<br>2'b00: PCM no delay mode<br>2'b01: PCM delay 1 mode<br>2'b10: PCM delay 2 mode<br>2'b11: PCM delay 3 mode |
| 5          | RW          | 0x0                | tfs<br>Transfer format select<br>1'b0: I2S format<br>1'b1: PCM format                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x0f               | <p>vdw<br/>Valid data width<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'b11110: 31bit<br/>5'b11111: 32bit</p> |

**ACDCDIG I2S RXCR1**

Address: Operational Base + offset (0x0310)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                           |
| 7:6        | RW          | 0x0                | <p>rCSR<br/>Channel select<br/>2'b00: Two channel<br/>Others: Reserved</p>                                                         |
| 5          | RO          | 0x0                | reserved                                                                                                                           |
| 4          | RW          | 0x0                | <p>cex<br/>Exchange left channel and right channel in the every receive line.<br/>1'b0: Not exchange<br/>1'b1: Exchange</p>        |
| 3          | RO          | 0x0                | reserved                                                                                                                           |
| 2          | RW          | 0x0                | <p>fbm<br/>First bit mode<br/>1'b0: MSB<br/>1'b1: LSB</p>                                                                          |
| 1:0        | RW          | 0x0                | <p>ibm<br/>I2S bus mode<br/>2'b00: I2S normal<br/>2'b01: I2S Left justified<br/>2'b10: I2S Right justified<br/>2'b11: Reserved</p> |

**ACDCDIG I2S CKR0**

Address: Operational Base + offset (0x0314)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x0                | rsd<br>I2S rx sclk divider for rx_lrck generator.<br>2'b00: 64<br>2'b01: 128<br>2'b10~2'b11: 256 |
| 1:0        | RO          | 0x0                | reserved                                                                                         |

**ACDCDIG I2S CKR1**

Address: Operational Base + offset (0x0318)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                     |
| 3          | RW          | 0x0                | mss<br>Master/slave mode select<br>1'b0: Master mode(sclk output)<br>1'b1: Slave mode(sclk input)                                                                                                                                                                                                                                                                                            |
| 2          | RW          | 0x0                | ckp<br>Sclk polarity<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.                                                                                                                                                                                                                               |
| 1          | RW          | 0x0                | rlp<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: low valid) |
| 0          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                     |

**ACDCDIG I2S XFER**

Address: Operational Base + offset (0x031C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                 |
| 1          | RW          | 0x0                | rxs<br>1'b0: Stop RX transfer<br>1'b1: Start RX transfer |
| 0          | RO          | 0x0                | reserved                                                 |

**ACDCDIG I2S CLR**

Address: Operational Base + offset (0x0320)

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

| Bit | Attr | Reset Value | Description                                                               |
|-----|------|-------------|---------------------------------------------------------------------------|
| 1   | RW   | 0x0         | rxc<br>This is a self-cleared bit. Write 1'b1 to clear all receive logic. |
| 0   | RO   | 0x0         | reserved                                                                  |

### **ACDCDIG VERSION**

Address: Operational Base + offset (0x0380)

| Bit  | Attr | Reset Value | Description                |
|------|------|-------------|----------------------------|
| 31:8 | RO   | 0x000000    | reserved                   |
| 7:0  | RO   | 0x02        | ver<br>Version of ACDCDIG. |

## **17.5 Interface Description**

Table 17-1 Digital Audio Codec Interface Description

| Module Pin  | Direction | Pad Name                                                                                            | IOMUX Setting                              |
|-------------|-----------|-----------------------------------------------------------------------------------------------------|--------------------------------------------|
| AUDIO_DSM_P | O         | DSMAUDIO_P/PWM0_M1/SPI0_CS1n_M0/<br>UART5_RX_M1/I2C3_SDA_M1/VICAP_VSY<br>NC_M1/LCD_VSYNC/GPIO1_D2_d | VENC_IOC_GPIO1D_IOMU<br>XSEL_L[10:8]=3'h7  |
| AUDIO_DSM_N | O         | DSMAUDIO_N//PWM11_IR_M2/UART5_TX<br>_M1/I2C3_SCL_M1/VICAP_CLKOUT_M1/L<br>CD_CLK/GPIO1_D3_d          | VENC_IOC_GPIO1D_IOMU<br>XSEL_L[14:12]=3'h7 |

Notes: I=input, O=output, I/O=input/output, bidirectional

The I2S RX interface of Digital Audio Codec can only operate in slave mode if combined with I2S0 and ACODEC PHY for loopback application. In this situation, I2S0 acts as a master, Digital Audio Codec and ACODEC PHY act as slave. To enable connections between Digital Audio Codec and I2S0, GRF\_PERI\_CON1[8] should be set to 1'b1.

## **17.6 Application Notes**

### **17.6.1 Software Application Notes**

Steps to configure Digital DAC to work in audio DSM mode 0 are as follows.

1. Program CRU in the SOC system to achieve the operation frequency of Digital DAC.
2. Program ACDCDIG\_DACINT\_DIV to 0x07.
3. Program ACDCDIG\_DACCLKCTRL to 0x3d.
4. Program ACDCDIG\_DACSCLKRXINT\_DIV if Digital DAC I2S RX acts as master.
5. Program ACDCDIG\_DACDSM\_CTRL to 0x58.
6. Program ACDCDIG\_I2S\_CKR0 and ACDCDIG\_I2S\_CKR1 to set I2S RX related registers.
7. Program ACDCDIG\_I2S\_CLR to clear RX logic.
8. Program ACDCDIG\_I2S\_RXCR0 and ACDCDIG\_I2S\_RXCR1.
9. Program GRF\_PERI\_CON1[8] to 1'b1 and program registers of I2S0 that is connected to Digital Audio Codec. Don't start transfer at this time.
10. Program DAC related registers such as ACDCDIG\_DACHPF, ACDCDIG\_DACVUCTL and ACDCDIG\_DACCFG1 to achieve basic configuration.
11. Program ACDCDIG\_I2S\_XFER to start I2S RX.
12. Program registers of I2S0 outside Digital Audio Codec to start TX.
13. Program ACDCDIG\_DACDIGIN to enable digital DAC channels. From now on, the Digital Audio Codec begins to work.

Steps to configure Digital Audio Codec to end audio DSM mode 0 transfer are as follows.

1. Program registers of I2S0 to stop TX and ACDCDIG\_I2S\_XFER to stop RX.
2. Program ACDCDIG\_DACDSM\_CTRL to 0x0.
3. Program ACDCDIG\_DACDIGIN to disable digital DAC channels.
4. Program ACDCDIG\_DACCLKCTRL to 0x0. Wait ACDCDIG\_DACCLKCTRL.dac\_sync\_status until read back to be 1'b0.

Steps to configure Digital DAC to work in audio DSM mode 1 are as follows.

1. Program CRU in the SOC system to achieve the operation frequency of Digital DAC.
2. Program ACDCDIG\_DACCLKCTRL to 0x3d.
3. Program ACDCDIG\_DACSCLKRXINT\_DIV if Digital DAC I2S RX acts as master.
4. Program ACDCDIG\_DACDSM\_CTRL to 0x68.
5. Program ACDCDIG\_I2S\_CKR0 and ACDCDIG\_I2S\_CKR1 to set I2S RX related registers.
6. Program ACDCDIG\_I2S\_CLR to clear RX logic.
7. Program ACDCDIG\_I2S\_RXCR0 and ACDCDIG\_I2S\_RXCR1.
8. Program GRF\_PERI\_CON1[8] to 1'b1 and program registers of I2S0 to start TX.
9. Program ACDCDIG\_I2S\_XFER to start I2S RX. From now on, the Digital Audio Codec begins to work.

Steps to configure Digital Audio Codec to end audio DSM mode 1 transfer are as follows.

1. Program registers of I2S0 to stop TX and ACDCDIG\_I2S\_XFER to stop RX.
2. Program ACDCDIG\_DACDSM\_CTRL to 0x0.
3. Program ACDCDIG\_DACCLKCTRL to 0x0. Wait ACDCDIG\_DACCLKCTRL.dac\_sync\_status until read back to be 1'b0

## Chapter 18 Flexible Serial Peripheral Interface (FSPI)

### 18.1 Overview

The FSPI is a flexible serial peripheral interface host controller to interface with external device.

The FSPI supports the following features:

- Support various vendor devices with flexible command sequencer engine
  - Serial NOR Flash
  - Serial NAND Flash
  - Serial pSRAM
  - Serial SRAM
- Support SDR mode
- Support Single/Dual/Quad IO mode
- Support a 32-bit AHB slave to read and write controller register bank and initiate command sequence, including transfer data from/to external device indirectly
- Support a 32-bit AHB master with embedded DMA engine to transfer data from/to external device indirectly
- Support independent clock for system bus HCLK and controller core SCLK
- Support maskable interrupts generation
- Support sampling clock with optionally configurable delay line
- Support 1 CS# operation

### 18.2 Block Diagram



Fig. 18-1 FSPI Architecture

Memory-Mapped AHB slave is available when XIP feature is present. In current chip, this feature is not provided.

## 18.3 Function Description

### 18.3.1 AHB Slave

The AHB slave block is used to configure the register of controller to generate flexible command sequence, process the interrupt exception, target various device feature and AC timing specification. It is also used to write CMD/ADDR/DATA to TX FIFO and read DATA from RX FIFO which buffer the DATA from external device.

### 18.3.2 AHB Master

When the embedded DMA CTRL is used to transfer DATA, the AHB master is used to transfer data to other system region, such as internal SRAM, peripheral, external DRAM.

### 18.3.3 REG File

The REG File is configurable register bank to control the store the static configuration and dynamic status of controller.

### 18.3.4 DMA CTRL

A block takes responsible for splitting a long length transfer trans into AHB bus transaction and interfacing with ASYNC TX or RX FIFO.

### 18.3.5 FIFO

There are four FIFO in the FSPI controller. ASYNC TX FIFO and ASYNC RX FIFO is for normal transaction that initiated by command sequence driver. The ASYNC MM (Memory-Mapped) TX FIFO and ASYNC MM (Memory-Mapped) RX FIFO is only used to buffer DATA from or to external device initiated by system bus master directly.

### 18.3.6 NSPI CTRL

Sequence decode engine which generates specialized timing sequence for various device. The NSPI decode the transaction from TX FIFO and Memory-Mapped Controller and convert it to relative CMD/ADDR/DATA frame based on the configuration.

## 18.4 Register Description

### 18.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

Table 18-1 FSPI Address Mapping

| Base Address  | Device   | Address Length | Offset Address Range |
|---------------|----------|----------------|----------------------|
| 32'hFFAC_0000 | FSPI CFG | 64K BYTE       | 0x0000 ~ 0x0268      |

### 18.4.2 Registers Summary

| Name       | Offset | Size | Reset Value | Description                                   |
|------------|--------|------|-------------|-----------------------------------------------|
| FSPI_CTRL0 | 0x0000 | W    | 0x00000000  | Control Register for CS0 Device               |
| FSPI_IMR   | 0x0004 | W    | 0x000001FF  | Interrupt Mask Register                       |
| FSPI_ICLR  | 0x0008 | W    | 0x00000000  | Interrupt Clear Register                      |
| FSPI_FTLR  | 0x000C | W    | 0x00001010  | FIFO Threshold Level Register                 |
| FSPI_RCVR  | 0x0010 | W    | 0x00000000  | FSPI Recover Register                         |
| FSPI_AX0   | 0x0014 | W    | 0x00000000  | FSPI Auxiliary Data Value for CS0 Device      |
| FSPI_ABITO | 0x0018 | W    | 0x00000000  | Extend Address Bits for CS0 Device            |
| FSPI_ISR   | 0x001C | W    | 0x00000000  | Interrupt Status                              |
| FSPI_FSR   | 0x0020 | W    | 0x00000001  | FIFO Status Register                          |
| FSPI_SR    | 0x0024 | W    | 0x00000000  | FSPI Status Register                          |
| FSPI_RISR  | 0x0028 | W    | 0x00000000  | Raw Interrupt Status Register                 |
| FSPI_VER   | 0x002C | W    | 0x00000006  | Version Register                              |
| FSPI_QOP   | 0x0030 | W    | 0x00000000  | Quad Line Operation IO Level Pre-set Register |

| Name                | Offset | Size | Reset Value | Description                                                 |
|---------------------|--------|------|-------------|-------------------------------------------------------------|
| FSPI EXT CTRL       | 0x0034 | W    | 0x00004023  | Extend Control Register                                     |
| FSPI DLL CTRL0      | 0x003C | W    | 0x00000001  | Delay Line Control Register for CS0 Device                  |
| FSPI EXT AX         | 0x0044 | W    | 0x0000F0FF  | Extend Auxiliary Data Control Register                      |
| FSPI SCLK INATM CNT | 0x0048 | W    | 0xFFFFFFFF  | SCLK Inactive Timeout Counter                               |
| FSPI XMMC WCMD0     | 0x0050 | W    | 0x00000000  | Memory Mapped Control Write Command Register for CS0 Device |
| FSPI XMMC RCMD0     | 0x0054 | W    | 0x00000000  | Memory Mapped Control Read Command Register for CS0 Device  |
| FSPI XMMC CTRL      | 0x0058 | W    | 0x000072E0  | Memory Mapped Control Register                              |
| FSPI MODE           | 0x005C | W    | 0x00000000  | Controller Working Mode Register                            |
| FSPI DEVGRN         | 0x0060 | W    | 0x00000017  | Device Region Size Register                                 |
| FSPI DEVSIZE0       | 0x0064 | W    | 0x00000012  | Device Size Register for CS0 Device                         |
| FSPI TME0           | 0x0068 | W    | 0x00000000  | Timeout Enable Control Register for CS0 Device              |
| FSPI XMMC RX WTMRK  | 0x0070 | W    | 0x00000002  | Memory Mapped Mode Receiver FIFO Water Mark Register        |
| FSPI DMATR          | 0x0080 | W    | 0x00000000  | DMA Trigger Register                                        |
| FSPI DMAADDR        | 0x0084 | W    | 0x00000000  | DMA Address Register                                        |
| FSPI LEN CTRL       | 0x0088 | W    | 0x00000000  | Length Control Register                                     |
| FSPI LEN EXT        | 0x008C | W    | 0x00000000  | Length Extended Register                                    |
| FSPI XMMCSR         | 0x0094 | W    | 0x00000000  | Memory Mapped Status Register                               |
| FSPI CMD            | 0x0100 | W    | 0x00000000  | Indirect Command Register                                   |
| FSPI ADDR           | 0x0104 | W    | 0x00000000  | Address Register                                            |
| FSPI DATA           | 0x0108 | W    | 0x00000000  | Data Register                                               |
| FSPI CTRL1          | 0x0200 | W    | 0x00000000  | Control Register for CS1 Device                             |
| FSPI AX1            | 0x0214 | W    | 0x00000000  | FSPI Auxiliary Data Value for CS1 Device                    |
| FSPI ABIT1          | 0x0218 | W    | 0x00000000  | Extend Address Bits for CS1 Device                          |
| FSPI DLL CTRL1      | 0x023C | W    | 0x00000001  | Delay Line Control Register for CS1 Device                  |
| FSPI XMMC WCMD1     | 0x0250 | W    | 0x00000000  | Memory Mapped Control Write Command Register for CS1 Device |
| FSPI XMMC RCMD1     | 0x0254 | W    | 0x00000000  | Memory-Mapped Command Control Register for CS1 Device       |
| FSPI DEVSIZE1       | 0x0264 | W    | 0x00000012  | Device Size Register for CS1 Device                         |
| FSPI TME1           | 0x0268 | W    | 0x00000000  | Timeout Enable Control Register for CS1 Device              |

Notes:Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 18.4.3 Detail Registers Description

#### FSPI CTRL0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:14 | RO   | 0x00000     | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12      | RW          | 0x0                | DATB<br>Data Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this DATB to match the CMD sequence before doing indirect access mode and memory mapped access mode.                                                                                                                                            |
| 11:10      | RW          | 0x0                | ADRB<br>Address Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this ADRB to match the CMD sequence before doing indirect access mode and memory mapped access mode.                                                                                                                                         |
| 9:8        | RW          | 0x0                | CMDB<br>Command Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this CMDB to match the CMD sequence before doing indirect access mode and memory mapped access mode.                                                                                                                                         |
| 7:4        | RW          | 0x0                | IDLE_CYCLE<br>Idle Cycles When Switching IO from Output to Input<br>4'h0: Idle hold is disable<br>4'h1: Hold the SCLK in idle for 2 cycles when switch to shift in<br>...<br>4'hf: Hold the SCLK in idle for 16 cycles when switch to shift in<br>To improve the transform IO timing, the application can set this register to hold the SCLK in low state or high state.       |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                       |
| 1          | RW          | 0x0                | SHIFTPHASE<br>Shift Phase of Data Input in Controller<br>1'b0: Shift input data at posedge SCLK<br>1'b1: Shift input data at negedge SCLK<br>The application can select the input data captured by posedge of SCLK when "0" or negedge of SCLK when "1".                                                                                                                       |
| 0          | RW          | 0x0                | SPIM<br>Serial Peripheral Interface Mode<br>1'b0: Mode 0<br>1'b1: Mode 3<br>SPIM is used to control the serial mode (CPOL and CPHA). CPOL indicates clock polarity of Serial master, CPOL=1 for SCLK high while idle, CPOL=0 for SCLK low while not transmitting. CPHA indicates clock phase. The combination of CPOL bit and CPHA bit decides which Serial mode is supported. |

**FSPI\_IMR**

Address: Operational Base + offset (0x0004)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x1                | DMAM<br>DMA Finish Interrupt Mask<br>1'b0: DMA finish interrupt is not masked<br>1'b1: DMA finish interrupt is masked<br>Only valid in indirect access mode.                                     |
| 6          | RW          | 0x1                | NSPIM<br>NSPI Interrupt Mask<br>1'b0: NSPI interrupt is not masked<br>1'b1: NSPI interrupt is masked<br>Valid in indirect access mode and memory mapped mode.                                    |
| 5          | RW          | 0x1                | AHBM<br>AMBA AHB Error Interrupt Mask<br>1'b0: AMBA AHB Error interrupt is not masked<br>1'b1: AMBA AHB Error interrupt is masked<br>Only valid in indirect access mode.                         |
| 4          | RW          | 0x1                | TRANSM<br>Transfer Finish Interrupt Mask<br>1'b0: Transfer finish interrupt is not masked<br>1'b1: Transfer finish interrupt is masked<br>Only valid in indirect access mode.                    |
| 3          | RW          | 0x1                | TXEM<br>Transmit FIFO Empty Interrupt Mask<br>1'b0: Transmit FIFO empty interrupt is not masked<br>1'b1: Transmit FIFO empty interrupt is masked<br>Only valid in indirect access mode.          |
| 2          | RW          | 0x1                | TXOM<br>Transmit FIFO Overflow Interrupt Mask<br>1'b0: Transmit FIFO overflow interrupt is not masked<br>1'b1: Transmit FIFO overflow interrupt is masked<br>Only valid in indirect access mode. |
| 1          | RW          | 0x1                | RXUM<br>Receive FIFO Underflow Interrupt Mask<br>1'b0: Receive FIFO underflow interrupt is not masked<br>1'b1: Receive FIFO underflow interrupt is masked<br>Only valid in indirect access mode. |
| 0          | RW          | 0x1                | RXFM<br>Receive FIFO Full Interrupt Mask<br>1'b0: Receive FIFO full interrupt is not masked<br>1'b1: Receive FIFO full interrupt is masked<br>Only valid in indirect access mode.                |

**FSPI ICLR**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                         |
| 7          | W1C         | 0x0                | DMAC<br>DMA Finish Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the DMAS    |
| 6          | W1C         | 0x0                | NSPIC<br>NSPI Error Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the NSPIS. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 5          | W1C         | 0x0                | AHBC<br>AMBA AHB Error Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the AHBS.         |
| 4          | W1C         | 0x0                | TRANSC<br>Transfer Finish Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the TRANSS.    |
| 3          | W1C         | 0x0                | TXEC<br>Transmit FIFO Empty Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the TXES.    |
| 2          | W1C         | 0x0                | TXOC<br>Transmit FIFO Overflow Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the TXOS. |
| 1          | W1C         | 0x0                | RXUC<br>Receive FIFO Underflow Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the RXUS. |
| 0          | W1C         | 0x0                | RXFC<br>Receive FIFO Full Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the RXFS.      |

**FSPI\_FTLR**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                               |
| 15:8       | RW          | 0x10               | RXFTLR<br>Receive FIFO Threshold Level<br>8'h0: 0 entry level<br>8'h1: 1 entry level<br>...<br>8'h10: 16 entry level(default)<br>...<br>When the number of receive FIFO entries is bigger than or equal to this value, the receive FIFO full interrupt is triggered.   |
| 7:0        | RW          | 0x10               | TXFTLR<br>Transmit FIFO Threshold Level<br>8'h0: 0 entry level<br>8'h1: 1 entry level<br>...<br>8'h10: 16 entry level(default)<br>...<br>When the number of transmit FIFO entries is less than or equal to this value, the transmit FIFO empty interrupt is triggered. |

**FSPI\_RCVR**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                      |
| 0          | R/W<br>SC   | 0x0                | RCVR<br>FSPI Recover<br>Write any values to trigger the recovery of SMC NSPI state machine, FIFO state and other logic state. |

**FSPI\_AX0**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                 |
| 7:0        | RW          | 0x00               | AX<br>Auxiliary Data<br>The AX value when doing the continuous read (enhance mode or XIP mode). That is M7-M0 in "Continuous Read Mode". |

**FSPI\_ABITO**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                       |
| 4:0        | RW          | 0x00               | ABIT<br>Address Bits Extend<br>5'h0: 1 bit<br>5'h1: 2 bits<br>...<br>5'h1f: 32 bits<br>Only valid when ADDR_B is set to 2'b11. |

**FSPI\_ISR**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                          |
| 7          | RO          | 0x0                | DMAS<br>DMA Finish Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated                     |
| 6          | RO          | 0x0                | NSPIS<br>NSPI Transaction Decode Error Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated |
| 5          | RO          | 0x0                | AHBS<br>AMBA AHB Error Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated                 |
| 4          | RO          | 0x0                | TRANSS<br>Transfer Finish Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated              |
| 3          | RO          | 0x0                | TXES<br>Transmit FIFO Empty Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated            |
| 2          | RO          | 0x0                | TXOS<br>Transmit FIFO Overflow Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | RXUS<br>Receive FIFO Underflow Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated |
| 0          | RW          | 0x0                | RXFS<br>Receive FIFO Full Interrupt Status<br>1'b0: No interrupt<br>1'b1: Active interrupt generated      |

**FSPI FSR**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:21      | RO          | 0x000              | reserved                                                                                                                        |
| 20:16      | RW          | 0x00               | RXWLVL<br>RX FIFO Water Level<br>5'h0: FIFO is empty<br>5'h1: 1 entry is taken<br>...<br>5'h10: 16 entry is taken, FIFO is full |
| 15:13      | RO          | 0x0                | reserved                                                                                                                        |
| 12:8       | RO          | 0x00               | TXWLVL<br>TX FIFO Water Level<br>5'h0: FIFO is full<br>5'h1: 1 entry is left<br>...<br>5'h10: 16 entry is left, FIFO is empty   |
| 7:4        | RO          | 0x0                | reserved                                                                                                                        |
| 3          | RO          | 0x0                | RXFS<br>Receive FIFO Full Status<br>1'b0: RX FIFO is not full<br>1'b1: RX FIFO is full                                          |
| 2          | RO          | 0x0                | RXES<br>Receive FIFO Empty Status<br>1'b0: RX FIFO is not empty<br>1'b1: RX FIFO is empty                                       |
| 1          | RO          | 0x0                | TXES<br>Transmit FIFO Empty Status<br>1'b0: TX FIFO is not empty<br>1'b1: TX FIFO is empty                                      |
| 0          | RO          | 0x1                | TXFS<br>Transmit FIFO Full Status<br>1'b0: TX FIFO is not full<br>1'b1: TX FIFO is full                                         |

**FSPI SR**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                           |
| 0          | RO          | 0x0                | SR<br>Status Register<br>1'b0: NSPI Controller is idle<br>1'b1: NSPI Controller is busy<br>When controller is busy, don't change the setting of control register. When NSPI is idle, the software can initiate new transaction to external device. |

**FSPI\_RISR**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                |
| 7          | RO          | 0x0                | DMAS<br>DMA Finish Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status.             |
| 6          | RO          | 0x0                | NSPIS<br>NSPI Error Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status.            |
| 5          | RO          | 0x0                | AHBS<br>AMBA AHB Error Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status.         |
| 4          | RO          | 0x0                | TRANSS<br>Transfer Finish Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status.      |
| 3          | RO          | 0x0                | TXES<br>Transmit FIFO Empty Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status.    |
| 2          | RO          | 0x0                | TXOS<br>Transmit FIFO Overflow Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status. |
| 1          | RO          | 0x0                | RXUS<br>Receive FIFO Underflow Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status. |
| 0          | RO          | 0x0                | RXFS<br>Receive FIFO Full Interrupt Status<br>1'b0: No active raw interrupt<br>1'b1: Active raw interrupt is generated<br>Cleared by writing corresponding ICLR bit to clear raw interrupt status.      |

**FSPI\_VER**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:16      | RO          | 0x0000             | reserved                      |
| 15:0       | RO          | 0x0006             | VER<br>The Version ID of FSPI |

**FSPI\_QOP**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                                                       |
| 1          | RW          | 0x0                | SO123BP<br>SO123 Bypass Mode<br>1'b0: Disable bypass<br>1'b1: Enable bypass<br>Default is enabled.                                                                             |
| 0          | RW          | 0x0                | SO123<br>D1/D2/D3 Data Value During Inactive When CS is Active<br>1'b0: Set to "0"<br>1'b1: Set to "1"<br>The value of SO1, SO2 and SO3 during command and address bits input. |

**FSPI\_EXT\_CTRL**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x00000            | reserved                                                                                                                                                                                                                                                               |
| 14         | RW          | 0x1                | SR_GEN_MODE<br>Status Register Generation Mode<br>1'b0: Compatible mode with old controller<br>1'b1: Robust generation to indicates the status of controller<br>If set to "1", the controller will only clear the SR bit after operation sequence done and CS is high. |
| 13         | RW          | 0x0                | TRANS_INT_MODE<br>Transmit Done Interrupt Generation Mode<br>1'b0: Trigger NSPI end in data done<br>1'b1: Trigger NSPI end in CS inactive<br>Default Generation is compatible with old controller.                                                                     |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                               |
| 11:8       | RW          | 0x0                | SWITCH_IO_O2I_CNT<br>Switch IO Attribute Cycles in O2I Idle Phase<br>4'h0: 1st cycle<br>4'h1: 2nd cycle<br>4'h2: 3rd cycle<br>4'h3: 4th cycle<br>...<br>4'hf: 16th cycle<br>The target cycle when switching from output to input in O2I idle phase.                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x2                | <p>SWITCH_IO_DUMM_CNT<br/>Switch IO Attribute Cycles in Dummy Phase<br/>4'h0: 1st cycle<br/>4'h1: 2nd cycle<br/>4'h2: 3rd cycle<br/>4'h3: 4th cycle<br/>...<br/>4'hf: 16th cycle<br/>The target cycle when switching from output to input in Dummy data phase.</p>                          |
| 3:0        | RW          | 0x3                | <p>CS_DESEL_CTRL<br/>CS Inactive Control<br/>4'h0: 1 cycle<br/>4'h1: 2 cycles<br/>4'h2: 3 cycles<br/>4'h3: 4 cycles<br/>...<br/>4'hf: 16 cycles<br/>The target cycles to hold CS inactive after de-assert the CS.<br/>Default value are 4 SCLK cycles that is enough for normal device.</p> |

**FSPI DLL CTRL0**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                      |
| 15         | RW          | 0x0                | <p>SCLK_SMP_SEL<br/>SCLK Sampling Selection<br/>1'b0: Bypass DLL<br/>1'b1: From DLL<br/>The sampling SCLK source selection.</p>                                                                                                                                                                               |
| 14:9       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                      |
| 8:0        | RW          | 0x001              | <p>SMP_DLL_CFG<br/>Sample Delay Line Configuration<br/>9'h0: 1 DLL element cell<br/>9'h1: 1 DLL element cell<br/>9'h2: 2 DLL element cells<br/>...<br/>9'h1ff: 511 DLL element cells<br/>This register to control the sampling delay line cell used. The maximum DLL element cells is decided by process.</p> |

**FSPI EXT AX**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                         |
| 15:8       | RW          | 0xf0               | <p>AX_SETUP_PAT<br/>Auxiliary Setup Data Pattern<br/>The AX data pattern that setup the continuous/enhance/XIP read mode</p>     |
| 7:0        | RW          | 0xff               | <p>AX_CANCEL_PAT<br/>Auxiliary Cancel Data Pattern<br/>The AX data pattern that cancel the continuous/enhance/XIP read mode.</p> |

**FSPI SCLK INATM CNT**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0xffffffff         | SCLK_INATM_CNT<br>SCLK Inactive Timeout Counter<br>When CS is active and SCLK is hold in high or low due to TX FIFO is empty or RX FIFO is full, if SCLK_INATM_EN is enabled, and timeout occurs, the controller will go back to idle and RX FIFO is flushed. |

**FSPI XMMC WCMDO**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                              |
| 15:14      | WO          | 0x0                | ADDRB<br>Address Bits<br>2'b00: 0 bit<br>2'b01: 24 bits<br>2'b10: 32 bits<br>2'b11: From the ABIT register<br>Address bits number select in memory mapped mode, if there is not address command to send, set to zero. |
| 13         | WO          | 0x0                | CONT<br>Continuous<br>1'b0: Disable continuous mode<br>1'b1: Enable continuous mode<br>AX mode or Continuous mode or XIP mode for device which begins with address.                                                   |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                              |
| 11:8       | WO          | 0x0                | DUMM<br>Dummy Cycles<br>4'h0: No dummy cycle<br>...<br>4'h8: 8 cycles<br>...<br>Dummy bit cycles in memory mapped mode.                                                                                               |
| 7:0        | WO          | 0x00               | CMD<br>Command<br>Command data in memory mapped access mode.                                                                                                                                                          |

**FSPI XMMC RCMDO**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                              |
| 15:14      | WO          | 0x0                | ADDRB<br>Address Bits<br>2'b00: 0 bit<br>2'b01: 24 bits<br>2'b10: 32 bits<br>2'b11: From the ABIT register<br>Address bits number select in memory mapped mode, if there is not address command to send, set to zero. |
| 13         | WO          | 0x0                | CONT<br>Continuous<br>1'b0: Disable continuous mode<br>1'b1: Enable continuous mode<br>AX mode or Continuous mode or XIP mode for device which begins with address.                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 12         | RO          | 0x0                | reserved                                                                                                                |
| 11:8       | WO          | 0x0                | DUMM<br>Dummy Cycles<br>4'h0: No dummy cycle<br>...<br>4'h8: 8 cycles<br>...<br>Dummy bit cycles in memory mapped mode. |
| 7:0        | WO          | 0x00               | CMD<br>Command<br>Command data in memory mapped access mode.                                                            |

**FSPI\_XMMC\_CTRL**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                       |
| 6          | RW          | 0x1                | PFT_EN<br>Prefetch Enable<br>1'b0: Disable<br>1'b1: Enable<br>Should disable prefetch if controller communicate with pSRAM which need refresh. |
| 5          | RW          | 0x1                | DEV_HWEN<br>Device AMBA AHB HWRITE Enable<br>1'b0: Disable<br>1'b1: Enable                                                                     |
| 4:0        | RO          | 0x00               | reserved                                                                                                                                       |

**FSPI\_MODE**

Address: Operational Base + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                               |
| 0          | RW          | 0x0                | XMMC_MODE_EN<br>Memory Mapped Mode Enable<br>1'b0: Disable, indirect access mode<br>1'b1: Enable, Memory-Mapped mode<br>Before switching from indirect access mode to Memory-Mapped mode, the application should make sure the controller is in idle state and no pending transaction. If switch from Memory-Mapped to indirect access mode, software should initiate a dummy read by CPU before that. |

**FSPI\_DEVVRGN**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                  |
| 9:8        | RW          | 0x0                | DEC_CTRL<br>Decode Control<br>2'b00: 1 CS#<br>2'b01: 2 CS#<br>2'b10: 4 CS#<br>2'b11: Reserved<br>Only valid in XMMC mode. |
| 7:5        | RO          | 0x0                | reserved                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x17               | <p>RSIZE<br/>Region Size<br/>5'd0: 1 byte<br/>5'd1: 2 bytes<br/>5'd2: 4 bytes<br/>.....<br/>5'd10: 1K bytes<br/>.....<br/>5'd20: 1M bytes<br/>.....<br/>5'd31: 4G bytes</p> <p>In Memory-Mapped mode, the CS is controlled by AHB address bus, region size is used to generate CS.</p> |

**FSPI DEVSIZE0**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                            |
| 4:0        | RW          | 0x12               | <p>DSIZE<br/>Device Size<br/>5'd0: 1 byte<br/>5'd1: 2 bytes<br/>5'd2: 4 bytes<br/>.....<br/>5'd10: 1K bytes<br/>.....<br/>5'd20: 1M bytes<br/>.....<br/>5'd31: 4G byte</p> <p>Device size is used to generate slop over status.</p> |

**FSPI TME0**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                 |
| 1          | RW          | 0x0                | <p>SCLK_INATM_EN<br/>SCLK Inactive Timeout Enable<br/>1'b0: Disable<br/>1'b1: Enable</p> |
| 0          | RO          | 0x0                | reserved                                                                                 |

**FSPI XMMC RX WTMRK**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                                                                     |
| 7:0        | RW          | 0x02               | <p>RX_FULL_WTMRK<br/>Memory Mapped Mode Receiver FIFO Water Mark.<br/>Default is enough.</p> |

**FSPI DMATR**

Address: Operational Base + offset (0x0080)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 0          | W1<br>C     | 0x0                | DMATR<br>DMA Trigger<br>Write "1" to start the DMA transfer. |

**FSPI DMAADDR**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | DMAADDR<br>DMA Address<br>The destination or source data address in current system. |

**FSPI LEN CTRL**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                         |
| 0          | RW          | 0x0                | TRB_SEL<br>Total Transfer Bytes Selection<br>1'b0: TRB controlled by CMD[TRB]<br>1'b1: TRB controlled by LEN_EXT |

**FSPI LEN EXT**

Address: Operational Base + offset (0x008C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | TRB_EXT<br>Total Transfer Bytes Extended<br>32'd0: No data<br>32'd1: 1 Byte<br>32'd2: 2 Bytes<br>...<br>Total data bytes number that will write to /read from the device. |

**FSPI XMMCSR**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                                                                                          |
| 1          | R/W<br>SC   | 0x0                | SLOPOVER1<br>Slop Over Register for CS1<br>1'b0: Normal state<br>1'b1: Address slop over<br>When the access address in memory map mode is bigger than DEVSIZE, this bit will be set. Write "1" to clear this bit. |
| 0          | R/W<br>SC   | 0x0                | SLOPOVER0<br>Slop Over Register for CS0<br>1'b0: Normal state<br>1'b1: Address slop over<br>When the access address in memory map mode is bigger than DEVSIZE, this bit will be set. Write "1" to clear this bit. |

**FSPI CMD**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | WO          | 0x0                | CS<br>Device Chip Select.<br>2'b00: Chip select 0<br>2'b01: Chip select 1<br>2'b10: Reserved<br>2'b11: Reserved                                                                                                         |
| 29:16      | WO          | 0x0000             | TRB<br>Total Transfer Bytes<br>14'd0: No data<br>14'd1: 1 Byte<br>14'd2: 2 Bytes<br>...<br>Total data bytes number that will write to or read from the device.                                                          |
| 15:14      | WO          | 0x0                | ADDRB<br>Address Bits<br>2'b00: 0 bit<br>2'b01: 24 bits<br>2'b10: 32 bits<br>2'b11: From the ABIT register<br>Address bits number select in indirect access mode. If there is not address command to send, set to zero. |
| 13         | WO          | 0x0                | CONT<br>Continuous<br>1'b0: Disable continuous mode<br>1'b1: Enable continuous mode<br>AX mode or Continuous mode or XIP mode for device which begins with address.                                                     |
| 12         | WO          | 0x0                | WR<br>Write or Read<br>1'b0: Read<br>1'b1: Write                                                                                                                                                                        |
| 11:8       | WO          | 0x0                | DUMM<br>Dummy Cycles<br>4'h0: No dummy cycle<br>...<br>4'h8: 8 cycles<br>...<br>Dummy bit cycles in indirect access mode.                                                                                               |
| 7:0        | WO          | 0x00               | CMD<br>Command<br>Command data in indirect access mode.                                                                                                                                                                 |

**FSPI ADDR**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | ADDR<br>Address Register<br>Indirect access start address data for current command sequence. |

**FSPI DATA**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | DATA<br>Data Register<br>Device data read or write from/to device. |

**FSPI\_CTRL1**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14      | RO          | 0x00000            | reserved                                                                                                                                                                                                                                                                                                                                                                       |
| 13:12      | RW          | 0x0                | DATB<br>Data Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this DATB to match the CMD sequence before doing indirect access mode and memory mapped access mode.                                                                                                                                            |
| 11:10      | RW          | 0x0                | ADRB<br>Address Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this ADRB to match the CMD sequence before doing indirect access mode and memory mapped access mode.                                                                                                                                         |
| 9:8        | RW          | 0x0                | CMDB<br>Command Line Width<br>2'b00: 1 bit, x1 mode<br>2'b01: 2 bits, x2 mode<br>2'b10: 4 bits, x4 mode<br>2'b11: Reserved<br>Set this CMDB to match the CMD sequence before doing indirect access mode and memory mapped access mode.                                                                                                                                         |
| 7:4        | RW          | 0x0                | IDLE_CYCLE<br>Idle Cycles When Switching IO from Output to Input<br>4'h0: Idle hold is disable<br>4'h1: Hold the SCLK in idle for 2 cycles when switch to shift in<br>...<br>4'hf: Hold the SCLK in idle for 16 cycles when switch to shift in<br>To improve the transform IO timing, the application can set this register to hold the SCLK in low state or high state.       |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                       |
| 1          | RW          | 0x0                | SHIFTPHASE<br>Shift Phase of Data Input in Controller<br>1'b0: Shift input data at posedge SCLK<br>1'b1: Shift input data at negedge SCLK<br>The application can select the input data captured by posedge of SCLK when "0" or negedge of SCLK when "1".                                                                                                                       |
| 0          | RW          | 0x0                | SPIM<br>Serial Peripheral Interface Mode<br>1'b0: Mode 0<br>1'b1: Mode 3<br>SPIM is used to control the serial mode (CPOL and CPHA). CPOL indicates clock polarity of Serial master, CPOL=1 for SCLK high while idle, CPOL=0 for SCLK low while not transmitting. CPHA indicates clock phase. The combination of CPOL bit and CPHA bit decides which Serial mode is supported. |

**FSPI\_AX1**

Address: Operational Base + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                 |
| 7:0        | RW          | 0x00               | AX<br>Auxiliary Data<br>The AX value when doing the continuous read (enhance mode or XIP mode). That is M7-M0 in "Continuous Read Mode". |

**FSPI\_ABIT1**

Address: Operational Base + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0000000          | reserved                                                                                                                      |
| 4:0        | RW          | 0x00               | ABIT<br>Address Bits Extend<br>5'h0: 1 bit<br>5'h1: 2 bits<br>...<br>5'h1f: 32 bits<br>Only valid when ADDRB is set to 2'b11. |

**FSPI\_DLL\_CTRL1**

Address: Operational Base + offset (0x023C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                        |
| 15         | RW          | 0x0                | SCLK_SMP_SEL<br>SCLK sampling selection<br>1'b0: Bypass DLL<br>1'b1: From DLL<br>The sampling SCLK source selection.                                                                                                                                                                            |
| 14:9       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                        |
| 8:0        | RW          | 0x001              | SMP_DLL_CFG<br>Sample Delay Line Configuration<br>9'h0: 1 DLL element cell<br>9'h1: 1 DLL element cell<br>9'h2: 2 DLL element cells<br>...<br>9'h1ff: 511 DLL element cells<br>This register to control the sampling delay line cell used. The maximum DLL element cells is decided by process. |

**FSPI\_XMMC\_WCMD1**

Address: Operational Base + offset (0x0250)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                              |
| 15:14      | WO          | 0x0                | ADDRB<br>Address Bits<br>2'b00: 0 bit<br>2'b01: 24 bits<br>2'b10: 32 bits<br>2'b11: From the ABIT register<br>Address bits number select in memory mapped mode, if there is not address command to send, set to zero. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | WO          | 0x0                | CONT<br>Continuous<br>1'b0: Disable continuous mode<br>1'b1: Enable continuous mode<br>AX mode or Continuous mode or XIP mode for device which begins with address. |
| 12         | RO          | 0x0                | reserved                                                                                                                                                            |
| 11:8       | WO          | 0x0                | DUMM<br>Dummy Cycles<br>4'h0: No dummy cycle<br>...<br>4'h8: 8 cycles<br>...<br>Dummy bit cycles in memory mapped mode.                                             |
| 7:0        | WO          | 0x00               | CMD<br>Command<br>Command data in memory mapped access mode.                                                                                                        |

**FSPI\_XMMC\_RCMD1**

Address: Operational Base + offset (0x0254)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                              |
| 15:14      | WO          | 0x0                | ADDRB<br>Address Bits<br>2'b00: 0 bit<br>2'b01: 24 bits<br>2'b10: 32 bits<br>2'b11: From the ABIT register<br>Address bits number select in memory mapped mode, if there is not address command to send, set to zero. |
| 13         | WO          | 0x0                | CONT<br>Continuous<br>1'b0: Disable continuous mode<br>1'b1: Enable continuous mode<br>AX mode or Continuous mode or XIP mode for device which begins with address.                                                   |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                              |
| 11:8       | WO          | 0x0                | DUMM<br>Dummy Cycles<br>4'h0: No dummy cycle<br>...<br>4'h8: 8 cycles<br>...<br>Dummy bit cycles in memory mapped mode.                                                                                               |
| 7:0        | WO          | 0x00               | CMD<br>Command<br>Command data in memory mapped access mode.                                                                                                                                                          |

**FSPI\_DEVSIZE1**

Address: Operational Base + offset (0x0264)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x12               | <p>DSIZE<br/>Device Size<br/>5'd0: 1 byte<br/>5'd1: 2 bytes<br/>5'd2: 4 bytes<br/>.....<br/>5'd10: 1K bytes<br/>.....<br/>5'd20: 1M bytes<br/>.....<br/>5'd31: 4G bytes<br/>Device size is used to generate slop over status.</p> |

**FSPI\_TME1**

Address: Operational Base + offset (0x0268)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                       |
| 1          | RW          | 0x0                | SCLK_INATM_EN<br>SCLK Inactive Timeout Enable<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RO          | 0x0                | reserved                                                                       |

**18.5 Interface Description**

Table 18-2 FSPI Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>               | <b>IOMUX Setting</b>                      |
|-------------------|------------------|-------------------------------|-------------------------------------------|
| sfc_sclk          | O                | FSPI_CLK/EMMC_CLK/GPIO4_B1_d  | VCCIO3_IOC_GPIO4B_IOMUX_SEL_L[6:4]=3'h2   |
| sfc_csn           | O                | FSPI_CS0n/EMMC_CMD/GPIO4_B0_u | VCCIO3_IOC_GPIO4B_IOMUX_SEL_L[2:0]=3'h2   |
| sfc_sio0          | I/O              | FSPI_D0/EMMC_D0/GPIO4_A4_u    | VCCIO3_IOC_GPIO4A_IOMUX_SEL_H[2:0]=3'h2   |
| sfc_sio1          | I/O              | FSPI_D1/EMMC_D1/GPIO4_A3_u    | VCCIO3_IOC_GPIO4A_IOMUX_SEL_L[14:12]=3'h2 |
| sfc_sio2          | I/O              | FSPI_D2/EMMC_D2/GPIO4_A2_u    | VCCIO3_IOC_GPIO4A_IOMUX_SEL_L[10:8]=3'h2  |
| sfc_sio3          | I/O              | FSPI_D3/EMMC_D3/GPIO4_A6_u    | VCCIO3_IOC_GPIO4A_IOMUX_SEL_H[10:8]=3'h2  |

Notes: I=Input, O=Output, I/O=Input/Output, bidirectional

## 18.6 Application Notes

### 18.6.1 Typical Program Flow Without DMA



Fig. 18-2 Program Flow

All the AHB bus write data to FSPI\_CMD, FSPI\_ADDR and FSPI\_DATA will be marked with different header and then pushed into transmit FIFO by writing order.

### 18.6.2 Typical READ Flow Without DMA



Fig. 18-3 Read Flow

### 18.6.3 Command Flow with DMA



Fig. 18-4 Command with DMA Flow

The total transfer bytes is decided by TRB register in FSPI\_CMD and must be aligned to 2 bytes.

### 18.6.4 SPI Mode and Sampling Phase Control

The register SPIM in FSPI\_CTRL will decide the default value of SCLK when CS# is inactive. When SPIM=0, the default value is 0, means Mode 0. When SPIM=1, the default value is 1,

means SPI Mode 3.

The register SHIFTPAHSE in FSPI\_CTRL will decide when to sample the SIO data. If SHIFTPAHSE=0, it will sample the data at the posedge of SCLK sampling clock. If SHIFTPHASE=1, it will sample the data at the negedge of SCLK sampling. The phase delay of sampling clock SCLK is configurable by SMP\_DLL\_CFG. It is strongly recommended that the SMP\_DLL\_CFG is set to 1 when SCLK\_SMP\_SEL is in bypass mode.

Individual FSPI\_DLL\_CTRL[n] allows flexibly control the DLL for each CSn channel, and the DLL is switched dynamically when the CSn is in operation.



Fig. 18-5 SPI mode

### 18.6.5 Idle Cycles

The FSPI\_CTRL register is a global control register, when the controller is in busy state (FSPI\_SR), FSPI\_CTRL cannot be set. The field IDLE\_CYCLE (FSPI\_CTRL[7:4]) of this register are used to configure the idle level cycles of FSPI core clock (SCLK) before reading the first bit of the read command.

Like the following picture shows, the highlighted line of the SCLK is the idle cycles, during these cycles, the chip pad is switched to output. When IDLE\_CYCLE =0, it means there will be no idle level cycles.



Fig. 18-6 Idle cycles

## Chapter 19 Gigabit Media Access Controller (GMAC)

### 19.1 Overview

The Ethernet Quality-of-Service controller(EQOS is commonly referred to as GMAC in this document) provides a complete Ethernet interface from processor to a Reduced Media Independent Interface (RMII) and Reduced Gigabit Media Independent Interface (RGMII) compliant Ethernet PHY. The GMAC 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.

The following features may or may not be present in the actual product. Please contact Rockchip for the actual feature configurations and the third-party licensing requirements.

#### 19.1.1 MAC Features

##### 19.1.1.1 MAC Tx and Rx Common Features

- Supports 10/100-Mbps data transfer rates with the RMII interfaces
- Half-duplex operation:
  - CSMA/CD Protocol support
  - Flow control using back-pressure support (based on implementation-specific white papers and UNH Ethernet Clause 4 MAC Test Suite - Annex D)
  - Packet bursting and packet extension in 1000 Mbps half-duplex operation
- 64-bit data transfer interface on the application side
- Full-duplex flow control operations (IEEE 802.3x Pause packets and Priority flow control)
- network statistics with RMON or MIB Counters (RFC2819/RFC2665)
- Media clock generation and recovery
- MDIO (Clause 22 and Clause 45) master interface for PHY device configuration and management

##### 19.1.1.2 MAC Tx Features

- Preamble and start of packet data (SFD) insertion
- Separate 32-bit status for each packet transmitted from the application
- Automatic CRC and pad generation controllable on a per-packet basis
- Programmable packet length to support Standard or Jumbo Ethernet packets with up to 16 KB of size
- Programmable Inter Packet Gap (40–96 bit times in steps of 8)
- IEEE 802.3x Flow Control automatic transmission of zero-quanta Pause packet when flow control input transitions from assertion to de-assertion (in full-duplex mode)
- Source Address field insertion or replacement, and VLAN insertion, replacement, and deletion in transmitted packets with per-packet or static-global control
- Insertion, replacement, or deletion of up to two VLAN tags
- Frame Preemption for MAC Tx

##### 19.1.1.3 MAC Rx Features

- Automatic Pad and CRC Stripping options
- Option to disable Automatic CRC checking
- Preamble and SFD deletion
- Separate 112-bit or 128-bit status
- Programmable watchdog timeout limit
- Flexible address filtering modes:
  - Up to 31 additional 48-bit perfect (DA) address filters with masks for each byte
  - Up to 96 additional 48-bit perfect (DA) address filters that can be selected in blocks of 32 and 64 registers
  - Up to 31 48-bit SA address comparison check with masks for each byte
  - 32 bit, 64 bit, 128 bit, or 256 bit Hash filter (optional) for multicast and unicast (DA) addresses

- Option to pass all multi-cast addressed packets
- Promiscuous mode to pass all packets without any filtering for network monitoring
- Pass all incoming packets (as per filter) with a status report
- Additional packet filtering:
  - VLAN tag-based: Perfect match and Hash-based (optional) filtering. Filtering based on either outer or inner VLAN tag is possible
  - Layer 3 and Layer 4-based: TCP or UDP over IPv4 or IPv6
  - Extended VLAN tag based filtering 4, 8, 16, or 32 filter selection
- IEEE 802.1Q VLAN tag detection and option to delete the VLAN tags in received packets
- Optional module to detect remote wake-up packets and AMD magic packets
- Optional forwarding of received Pause packets to the application (in full-duplex mode)
- Frame Preemption for MAC Rx

## 19.1.2 MTL Features

### 19.1.2.1 MTL Tx and Rx Common Features

- 32-bit, 64-bit, or 128-bit Transaction Layer block (bridges the application and the MAC)
- Data transfers executed using simple FIFO protocol
- Synchronization for all clocks in the design (Transmit, Receive, and Application clocks)
- Optimization for packet-oriented transfers with packets delimiters
- Option to have dual-port RAM based asynchronous FIFO controllers or Single-port RAM based synchronous FIFO controllers
- RAM memory instantiation outside the top-level module to facilitate memory testing or instantiation
- Programmable burst length, up to half the size of the MTL Rx queue or Tx queue size, to support burst data transfer in the EQOS-MTL configuration
- Programmable threshold capability for each queue (default of 64 bytes)
- Optional Debug and slave mode operation on Queue 0 (default queue)

### 19.1.2.2 MTL Tx Features

- TX FIFO sizes on transmission is 16 KB
- Store-and-Forward mechanism or threshold mode (cut-through) for transmission to the MAC
- Programmable queue size in configurations with multiple queues. Each queue size can be programmed in terms of 256 bytes
- Automatic retransmission of collision packets in half-duplex mode
- Discard packets on late collision, excessive collisions, excessive deferral, and under-run conditions with appropriate status
- Disabling of Data Memory RAM chip-select when inactive to reduce power consumption
- Optional module to calculate and insert IPv4 header checksum and TCP, UDP, or ICMP checksum
- Programmable interrupt options for different operational conditions
- Statistics by generating pulses for packets dropped (because of underflow) in the Tx FIFO
- Optional packet-level control for
  - VLAN tag insertion or replacement
  - Ethernet source address insertion
  - Layer3/Layer4 Checksum insertion control
  - One-step timestamp
  - Timestamp control
  - CRC and pad control
- Following scheduling algorithms in configurations with multiple queues:
  - Weighted Round Robin (WRR)
  - (When Data Center Bridging is enabled) Deficit Weighted Round Robin (DWRR)
  - (When Data Center Bridging is enabled) Weighted Fair Queuing (WFQ)
  - Strict Priority (SP)
  - (When Audio-Video Bridging is enabled) Credit-based Shaper (CBS)
  - (When TSN is enabled), Enhancement to Scheduled Traffic (EST)

- (When TSN is enabled), Time Based Scheduling (TBS)
- Option to support dropping of Tx Status to improve the Transmit throughput

### **19.1.2.3 MTL Rx Features**

- Rx queue sizes in the Receive path is 32 KB
- Insertion of Rx Status vectors into the Rx queue after the EOP transfer (in Threshold mode) and before SOP (in Store-and-Forward mode) in EQOS-MTL configuration
- Programmable Rx queue threshold (default fixed at 64 bytes) in Threshold (or cut-through) mode
- Option to filter all error packets on reception and not forward them to the application in the store-and-forward mode
- Option to forward the undersized good packets
- Statistics by generating pulses for packets dropped (because of overflow) in the Rx FIFO
- Automatic generation of Pause packet control or backpressure signal to the MAC based on the Rx Queue fill level
- Arbitration among queues when multiple queues are present. The following arbitration schemes are supported:
  - Weighted Round Robin (WRR)
  - Weighted Strict priority (WSP)
  - Strict Priority (SP)
- Option to replicate received multicast packets for transfer by multiple Rx DMA channels
- Option to have a programmable lookup table based flexible Parser for filtering and steering the Rx packets

### **19.1.3 DMA Block Features**

- 64-bit data transfers
- Separate DMA channel in the Transmit path for each queue in MTL
- Single or multiple DMA channels for any number of queues in MTL Receive path
- Fully synchronous design operating on a single application clock (except for CSR module, when a separate CSR clock is configured)
- Optimization for packet-oriented DMA transfers with packet delimiters
- Byte-aligned addressing for data buffer support
- Dual-buffer (ring) descriptor support
- Descriptor architecture to allow large blocks of data transfer with minimum CPU intervention (each descriptor can transfer up to 32 KB of data)
- Comprehensive status reporting for normal operation and transfers with errors
- Individual programmable burst length for Tx DMA and Rx DMA engines for optimal host bus utilization
- Programmable interrupt options for different operational conditions
- Per-packet Transmit or Receive Complete Interrupt control
- Round-robin or fixed-priority arbitration between the Receive and Transmit engines
- Start and Stop modes
- Separate ports for host CSR access and host data interface
- support for TCP Segmentation Offload (TSO) and UDP Segmentation Offload (USO)
- Selectable number of Tx DMA channels with TSO/USO feature enabled
- Routing of received packets to the DMA channels based on the DA or VLAN Priority in multi-channel DMA configurations
- Option to split the packet header (Layer 3 and Layer 4) and payload in a different buffers
- Time-sensitive conditional packet fetching from system memory by comparing the Slot Time or IEEE 1588 time information provided in the descriptor (useful for AV applications)
- Programmable control for Transmit Descriptor posted writes to improve the throughput
- Sideband signals to control starting and stopping of DMA channels

## 19.2 Block Diagram



Fig. 19-1 GMAC Block Diagram

The GMAC 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 GMAC transfers data to system memory through the AXI master interface. The host CPU uses the APB Slave interface to access the GMAC subsystem's control and status registers (CSRs).

The GMAC only 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 GMAC 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 GMAC line clocks.



Fig. 19-2 GMAC in SOC

GMAC Supports 10/100-Mbps data transfer rates with the RMII interfaces.

## 19.3 Function Description

### 19.3.1 Frame Structure

Data frames transmitted shall have the frame format shown in Fig.1-3.



Fig. 19-3 Frame Format

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.

#### 19.3.1.1 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 GMAC 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.

#### 19.3.1.2 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. 19-4 RMII Transmission Bit Ordering

#### 19.3.1.3 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. 19-5 Start of MII and RMII Transmission in 100-Mbps Mode



Fig. 19-6 End of MII and RMII Transmission in 100-Mbps Mode



Fig. 19-7 Start of MII and RMII Transmission in 10-Mbps Mode



Fig. 19-8 End of MII and RMII Transmission in 10-Mbps Mode

#### 19.3.1.4 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. 19-9 RMII Receive Bit Ordering

### 19.3.2 Station Management Agent

The application can access the PHY registers through the Station Management Agent (SMA) module. SMA is a two-wire Station Management interface (MIM).

For MIM accesses, the maximum operating frequency of the MDC (gmii\_mdc\_o) is 2.5 MHz, as specified in the IEEE 802.3. In the GMAC core, the gmii\_mdc\_o clock is derived from the application clock or clk\_csr\_i, using a divider-counter. The divide factor depends on the clock range setting (CR field) in the MAC\_MDIO\_Address register Select the clock divide factor as mentioned in the description of CR field of MAC\_MDIO\_Address register, to meet IEEE specifications. However, if your system supports higher clock frequencies on the MIM interface, there is a provision to select a different divider.

The MDIO frame structure is as follows:

Table 19-1 MDIO Clause 45 Frame Structure

| Field        | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IDLE         | The mdio line is in tri-state; there is no clock on gmii_mdc_o signal.                                                                                                                                                                                                                                                                                      |
| PREAMBLE     | 32 continuous bits of value 1                                                                                                                                                                                                                                                                                                                               |
| START        | Start of packet is 2'b00                                                                                                                                                                                                                                                                                                                                    |
| OPCODE       | <ul style="list-style-type: none"> <li>■ 2'b00</li> <li>■ 2'b01</li> <li>■ 2'b10</li> <li>■ 2'b11</li> </ul>                                                                                                                                                                                                                                                |
| PHY ADDR     | 5-bit address select for one of 32 PHYs                                                                                                                                                                                                                                                                                                                     |
| DEV ADDR     | 5-bit address select for one of 32 devices                                                                                                                                                                                                                                                                                                                  |
| TA           | Turnaround <ul style="list-style-type: none"> <li>■ 2'bZ0: Read and post-read increment address</li> <li>■ 2'b10: Write and address MDIO accesses Where Z is the tri-state level</li> </ul>                                                                                                                                                                 |
| DATA/ADDRESS | 16-bit value: For an address cycle (OPCODE = 2'b00), this frame contains the address of the register to be accessed on the next cycle. For the data cycle of a write frame, this field contains the data to be written to the register. For read or post-read increment address frames, this field contains the contents of the register read from the PHY. |

| Field | Description                                                                                                                                                                                                                                                                             |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <ul style="list-style-type: none"> <li>■ In address and data write cycles, the GMAC drives the MDIO line during the transfer of these 16 bits.</li> <li>■ In read and post-read increment address cycles, the PHY drives the MDIO line during the transfer of these 16 bits.</li> </ul> |

The frame structure for Clause 22 frames is also supported. The C45E bit in the MAC\_MDIO\_Address register can be programmed to enable Clause 22 or Clause 45 mode of operation. Table.1-2 shows the Clause 22 frame format.

Table 19-2 MDIO Clause 22 Frame Structure

| Field        | Description                                                                                                                                                                                              |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IDLE         | The mdio line is in tri-state; there is no clock on gmii_mdc_o signal.                                                                                                                                   |
| PREAMBLE     | 32 continuous bits of value 1                                                                                                                                                                            |
| START        | Start of packet is 2'b01                                                                                                                                                                                 |
| OPCODE       | <ul style="list-style-type: none"> <li>■ 2'b01 : Write</li> <li>■ 2'b10 : Read</li> </ul>                                                                                                                |
| PHY ADDR     | 5-bit address select for one of 32 PHYs                                                                                                                                                                  |
| DEV ADDR     | 5-bit address to select the register within each MMD                                                                                                                                                     |
| TA           | <ul style="list-style-type: none"> <li>Turnaround</li> <li>■ 2'bZ0: Read and post-read increment address</li> <li>■ 2'b10: Write and address MDIO accesses<br/>Where Z is the tri-state level</li> </ul> |
| DATA/ADDRESS | <ul style="list-style-type: none"> <li>Any 16-bit value:</li> <li>■ In a write operation, the GMAC drives MDIO</li> <li>■ In read operation, the PHY drives MDIO</li> </ul>                              |

In addition to normal read and write operations, the SMA also supports post-read increment address while operating in Clause 45 mode.

### 19.3.3 TCP/IP Segmentation Offload (TSO) Engine

The TCP Segmentation Offload (TSO) engine is useful in offloading the TCP segmentation functions to the hardware.

It also supports UDP Segmentation Offload (USO) in which the UDP payload is segmented in the hardware. There are no sequencing/ordering controls available or updated in the segments, so it can be used in point to point applications in which out of order packets are not expected by the receiver. The description and flow of TSO mentioned in this section is same as USO, any deviation is provided as notes.

In the TCP segmentation offload (TSO) feature, the DMA splits a large TCP packet into multiple small packets and passes these packets to the MTL Tx Queue.

### 19.3.4 MAC Management Counters

The GMAC supports storing the statistics about the received and transmitted packets in registers that are accessible through the application.

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 packets. The register set includes a control register for controlling the behavior of the registers, two status registers containing interrupts generated (receive and transmit), and Interrupt Enable registers (receive and transmit). These registers are accessible from the Application through the MAC Control Interface (MCI). Each register is 32-bits wide. The write data is qualified with the corresponding mci\_be\_i signals. Therefore, non-32-bit accesses are allowed as long as the address is word-aligned. The MMCs are accessed using transactions, in the same way the CSR address space is accessed.

The MMC counters are free running. There is no separate enable for the counters to start. If a particular MMC counter is present in the RTL, it starts counting when corresponding packet is received or transmitted. The Receive MMC counters are updated for packets that are passed by the Address Filter (AFM) block. The statistics of packets, dropped by the AFM module, are not updated unless they are runt packets of less than 6 bytes (DA bytes are not received fully). To get statistics of all packets, set Bit 0 in the “MAC\_Packet\_Filter” register.

The MMC module gathers statistics on encapsulated IPv4, IPv6, TCP, UDP, or ICMP payloads in received Ethernet packets.

## 19.4 Register Description

### 19.4.1 Registers Summary

| Name                       | Offset | Size | Reset Value | Description                                                                                                                                      |
|----------------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| GMAC_MAC_Configuration     | 0x0000 | W    | 0x00008000  | The MAC Configuration Register establishes the operating mode of the MAC                                                                         |
| GMAC_MAC_Ext_Configuration | 0x0004 | W    | 0x00000000  | The MAC Extended Configuration Register establishes the operating mode of the MAC                                                                |
| GMAC_MAC_Packet_Filter     | 0x0008 | W    | 0x00000000  | The MAC Packet Filter register contains the filter controls for receiving packets                                                                |
| GMAC_MAC_Watchdog_Timeout  | 0x000C | W    | 0x00000000  | The Watchdog Timeout register controls the watchdog timeout for received packets                                                                 |
| GMAC_MAC_Hash_Table_Reg0   | 0x0010 | W    | 0x00000000  | The Hash Table Register 0 contains the first 32 bits of the hash table                                                                           |
| GMAC_MAC_Hash_Table_Reg1   | 0x0014 | W    | 0x00000000  | The Hash Table Register 1 contains the second 32 bits of the hash table                                                                          |
| GMAC_MAC_VLAN_Tag          | 0x0050 | W    | 0x00000000  | The VLAN Tag register identifies the IEEE 802.1Q VLAN type packets                                                                               |
| GMAC_MAC_VLAN_Hash_Table   | 0x0058 | W    | 0x00000000  | When VTHM bit of the MAC_VLAN_Tag register is set, the 16-bit VLAN Hash Table register is used for group address filtering based on the VLAN tag |
| GMAC_MAC_Q0_Tx_Flow_Ctrl   | 0x0070 | W    | 0x00000000  | The Flow Control register controls the generation and reception of the Control (Pause Command) packets by the Flow control module of the MAC     |
| GMAC_MAC_Rx_Flow_Ctrl      | 0x0090 | W    | 0x00000000  | The Receive Flow Control register controls the pausing of MAC Transmit based on the received Pause packet                                        |
| GMAC_MAC_Interrupt_Status  | 0x00B0 | W    | 0x00000000  | The Interrupt Status register contains the status of interrupts                                                                                  |
| GMAC_MAC_Interrupt_Enable  | 0x00B4 | W    | 0x00000000  | The Interrupt Enable register contains the masks for generating the interrupts                                                                   |

| Name                               | Offset | Size | Reset Value | Description                                                                                                                                                                                                                                                                |
|------------------------------------|--------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC_MAC_Rx_Tx_Status</u>       | 0x00B8 | W    | 0x00000000  | The Receive Transmit Status register contains the Receive and Transmit Error status                                                                                                                                                                                        |
| <u>GMAC_MAC_PMT_Control_Status</u> | 0x00C0 | W    | 0x00000000  | The PMT Control and Status Register                                                                                                                                                                                                                                        |
| <u>GMAC_MAC_RWK_Packet_Filter</u>  | 0x00C4 | W    | 0x00000000  | The Remote Wakeup Filter registers are implemented as 8, 16, or 32 indirect access registers (wkuppktfilter_reg#i) based on whether 4, 8, or 16 Remote Wakeup Filters are selected in the configuration and accessed by application through MAC_RWK_Packet_Filter register |
| <u>GMAC_RWK_Filter0[Byte]_Mask</u> | 0x10C0 | W    | 0x00000000  | RWK Filter0 Byte Mask                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_Filter1[Byte]_Mask</u> | 0x10C4 | W    | 0x00000000  | RWK Filter1 Byte Mask                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_Filter2[Byte]_Mask</u> | 0x10C8 | W    | 0x00000000  | RWK Filter2 Byte Mask                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_Filter3[Byte]_Mask</u> | 0x10CC | W    | 0x00000000  | RWK Filter3 Byte Mask                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_Filter01_CRC</u>       | 0x10D0 | W    | 0x00000000  | RWK Filter 0/1 CRC-16                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_Filter23_CRC</u>       | 0x10D4 | W    | 0x00000000  | RWK Filter 2/3 CRC-16                                                                                                                                                                                                                                                      |
| <u>GMAC_RWK_Filter_Offset</u>      | 0x10D8 | W    | 0x00000000  | RWK Filter Offset                                                                                                                                                                                                                                                          |
| <u>GMAC_RWK_Filter_Command</u>     | 0x10DC | W    | 0x00000000  | RWK Filter Command                                                                                                                                                                                                                                                         |
| <u>GMAC_MAC_Version</u>            | 0x0110 | W    | 0x00001E51  | The version register identifies the version of the GMAC                                                                                                                                                                                                                    |
| <u>GMAC_MAC_Debug</u>              | 0x0114 | W    | 0x00000000  | The Debug register provides the debug status of various MAC blocks                                                                                                                                                                                                         |
| <u>GMAC_MAC_HW_Feature0</u>        | 0x011C | W    | 0x400103E1  | This register indicates the presence of first set of the optional features or functions                                                                                                                                                                                    |
| <u>GMAC_MAC_HW_Feature1</u>        | 0x0120 | W    | 0x010E4166  | This register indicates the presence of second set of the optional features or functions                                                                                                                                                                                   |
| <u>GMAC_MAC_HW_Feature2</u>        | 0x0124 | W    | 0x10000000  | This register indicates the presence of third set of the optional features or functions                                                                                                                                                                                    |
| <u>GMAC_MAC_HW_Feature3</u>        | 0x0128 | W    | 0x00000000  | This register indicates the presence of fourth set the optional features or functions                                                                                                                                                                                      |
| <u>GMAC_MAC_MDIO_Address</u>       | 0x0200 | W    | 0x00000000  | The MDIO Address register controls the management cycles to external PHY through a management interface                                                                                                                                                                    |
| <u>GMAC_MAC_MDIO_Data</u>          | 0x0204 | W    | 0x00000000  | The MDIO Data register stores the Write data to be written to the PHY register located at the address specified in MAC_MDIO_Address                                                                                                                                        |

| Name                            | Offset | Size | Reset Value | Description                                                                                                                          |
|---------------------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| GMAC MAC ARP Address            | 0x0210 | W    | 0x00000000  | The ARP Address register contains the IPv4 Destination Address of the MAC                                                            |
| GMAC MAC CSR SW Ctrl            | 0x0230 | W    | 0x00000000  | This register contains SW programmable controls for changing the CSR access response and status bits clearing                        |
| GMAC MAC Ext Cfg1               | 0x0238 | W    | 0x00000002  | This register contains Split mode control field and offset field for Split Header feature                                            |
| GMAC MAC Address0 High          | 0x0300 | W    | 0x0000FFFF  | The MAC Address0 High register holds the upper 16 bits of the first 6-byte MAC address of the station                                |
| GMAC MAC Address0 Low           | 0x0304 | W    | 0xFFFFFFFF  | The MAC Address0 Low register holds the lower 32 bits of the 6-byte first MAC address of the station                                 |
| GMAC MMC Control                | 0x0700 | W    | 0x00000000  | This register establishes the operating mode of MMC                                                                                  |
| GMAC MMC Rx Interrupt           | 0x0704 | W    | 0x00000000  | Maintains the interrupts generated from all Receive statistics counters                                                              |
| GMAC MMC Tx Interrupt           | 0x0708 | W    | 0x00000000  | Maintains the interrupts generated from all Transmit statistics counters                                                             |
| GMAC MMC Rx Interrupt Mask      | 0x070C | W    | 0x00000000  | This register maintains the masks for interrupts generated from all Receive statistics counters                                      |
| GMAC MMC Tx Interrupt Mask      | 0x0710 | W    | 0x00000000  | This register maintains the masks for interrupts generated from all Transmit statistics counters                                     |
| GMAC Tx Octet Count Good Bad    | 0x0714 | W    | 0x00000000  | This register provides the number of bytes transmitted by the GMAC, exclusive of preamble and retried bytes, in good and bad packets |
| GMAC Tx Packet Count Good Bad   | 0x0718 | W    | 0x00000000  | This register provides the number of good and bad packets, exclusive of retried packets                                              |
| GMAC Tx Underflow Error Packets | 0x0748 | W    | 0x00000000  | This register provides the number of packets aborted because of packets underflow error                                              |
| GMAC Tx Carrier Error Packets   | 0x0760 | W    | 0x00000000  | This register provides the number of packets aborted because of carrier sense error (no carrier or loss of carrier)                  |
| GMAC Tx Octet Count Good        | 0x0764 | W    | 0x00000000  | This register provides the number of bytes exclusive of preamble, only in good packets                                               |
| GMAC Tx Packet Count Good       | 0x0768 | W    | 0x00000000  | This register provides the number of good packets transmitted by GMAC                                                                |
| GMAC Tx Pause Packets           | 0x0770 | W    | 0x00000000  | This register provides the number of good Pause packets by GMAC                                                                      |

| Name                                    | Offset | Size | Reset Value | Description                                                                                                                                                           |
|-----------------------------------------|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC Rx Packets Count Good Bad</u>   | 0x0780 | W    | 0x00000000  | This register provides the number of good and bad packets received by GMAC                                                                                            |
| <u>GMAC Rx Octet Count Good Bad</u>     | 0x0784 | W    | 0x00000000  | This register provides the number of bytes received by GMAC, exclusive of preamble, in good and bad packets                                                           |
| <u>GMAC Rx Octet Count Good</u>         | 0x0788 | W    | 0x00000000  | This register provides the number of bytes received by GMAC, exclusive of preamble, only in good packets                                                              |
| <u>GMAC Rx Multicast Packets Good</u>   | 0x0790 | W    | 0x00000000  | This register provides the number of good multicast packets received by                                                                                               |
| <u>GMAC Rx CRC Error Packets</u>        | 0x0794 | W    | 0x00000000  | This register provides the number of packets received by GMAC with CRC error                                                                                          |
| <u>GMAC Rx Length Error Packets</u>     | 0x07C8 | W    | 0x00000000  | This register provides the number of packets received by GMAC with length error (Length Type field not equal to packet size), for all packets with valid length field |
| <u>GMAC Rx Pause Packets</u>            | 0x07D0 | W    | 0x00000000  | This register provides the number of good and valid Pause packets received by GMAC                                                                                    |
| <u>GMAC Rx FIFO Overflow Packets</u>    | 0x07D4 | W    | 0x00000000  | This register provides the number of missed received packets because of FIFO overflow                                                                                 |
| <u>GMAC MMC IPC Rx Interrupt Mask</u>   | 0x0800 | W    | 0x00000000  | This register maintains the mask for the interrupt generated from the receive IPC statistic counters                                                                  |
| <u>GMAC MMC IPC Rx Interrupt</u>        | 0x0808 | W    | 0x00000000  | This register maintains the interrupt that the receive IPC statistic counters generate                                                                                |
| <u>GMAC RxIPv4 Good Packets</u>         | 0x0810 | W    | 0x00000000  | This register provides the number of good IPv4 datagrams received by GMAC with the TCP, UDP, or ICMP payload                                                          |
| <u>GMAC RxIPv4 Header Error Packets</u> | 0x0814 | W    | 0x00000000  | This register provides the number of IPv4 datagrams received by GMAC with header (checksum, length, or version mismatch) errors                                       |
| <u>GMAC RxIPv6 Good Packets</u>         | 0x0824 | W    | 0x00000000  | This register provides the number of good IPv6 datagrams received by GMAC                                                                                             |
| <u>GMAC RxIPv6 Header Error Packets</u> | 0x0828 | W    | 0x00000000  | This register provides the number of IPv6 datagrams received by GMAC with header (length or version mismatch) errors                                                  |
| <u>GMAC RxUDP Error Packets</u>         | 0x0834 | W    | 0x00000000  | This register provides the number of good IP datagrams received by GMAC whose UDP payload has a checksum error                                                        |

| Name                                   | Offset | Size | Reset Value | Description                                                                                                                                                   |
|----------------------------------------|--------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC RxTCP Error Packets</u>        | 0x083C | W    | 0x00000000  | This register provides the number of good IP datagrams received by GMAC whose TCP payload has a checksum error                                                |
| <u>GMAC RxICMP Error Packets</u>       | 0x0844 | W    | 0x00000000  | This register provides the number of good IP datagrams received by GMAC whose ICMP payload has a checksum error                                               |
| <u>GMAC RxIPv4 Header Error Octets</u> | 0x0854 | W    | 0x00000000  | This register provides the number of bytes received by GMAC in IPv4 datagrams with header errors (checksum, length, version mismatch)                         |
| <u>GMAC RxIPv6 Header Error Octets</u> | 0x0868 | W    | 0x00000000  | This register provides the number of bytes received by GMAC in IPv6 datagrams with header errors (length, version mismatch)                                   |
| <u>GMAC RxUDP Error Octets</u>         | 0x0874 | W    | 0x00000000  | This register provides the number of bytes received by GMAC in a UDP segment that had checksum errors                                                         |
| <u>GMAC RxTCP Error Octets</u>         | 0x087C | W    | 0x00000000  | This register provides the number of bytes received by GMAC in a TCP segment that had checksum errors                                                         |
| <u>GMAC RxICMP Error Octets</u>        | 0x0884 | W    | 0x00000000  | This register provides the number of bytes received by GMAC in a good ICMP segment                                                                            |
| <u>GMAC MTL Operation Mode</u>         | 0x0C00 | W    | 0x00000000  | The Operation Mode register establishes the Transmit and Receive operating modes and commands                                                                 |
| <u>GMAC MTL DBG CTL</u>                | 0x0C08 | W    | 0x00000000  | The FIFO Debug Access Control and Status register controls the operation mode of FIFO debug access                                                            |
| <u>GMAC MTL DBG STS</u>                | 0x0C0C | W    | 0x01900000  | The FIFO Debug Status register contains the status of FIFO debug access                                                                                       |
| <u>GMAC MTL FIFO Debug Data</u>        | 0x0C10 | W    | 0x00000000  | The FIFO Debug Data register contains the data to be written to or read from the FIFOs                                                                        |
| <u>GMAC MTL Interrupt Status</u>       | 0x0C20 | W    | 0x00000000  | The software driver (application) reads this register during interrupt service routine or polling to determine the interrupt status of MTL queues and the MAC |
| <u>GMAC MTL TxQ0 Operation Mode</u>    | 0x0D00 | W    | 0x00000000  | The Queue 0 Transmit Operation Mode register establishes the Transmit queue operating modes and commands                                                      |

| Name                                     | Offset | Size | Reset Value | Description                                                                                                                                                                                   |
|------------------------------------------|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC MTL TxQ0 Underflow</u>           | 0x0D04 | W    | 0x00000000  | The Queue 0 Underflow Counter register contains the counter for packets aborted because of Transmit queue underflow and packets missed because of Receive queue packet flush                  |
| <u>GMAC MTL TxQ0 Debug</u>               | 0x0D08 | W    | 0x00000000  | The Queue 0 Transmit Debug register gives the debug status of various blocks related to the Transmit queue                                                                                    |
| <u>GMAC MTL Q0 Interrupt Ctrl Status</u> | 0x0D2C | W    | 0x00000000  | This register contains the interrupt enable and status bits for the queue 0 interrupts                                                                                                        |
| <u>GMAC MTL RxQ0 Operation Mode</u>      | 0x0D30 | W    | 0x00000000  | The Queue 0 Receive Operation Mode register establishes the Receive queue operating modes and command                                                                                         |
| <u>GMAC MTL RxQ0 Miss Pkt Ovf Cnt</u>    | 0x0D34 | W    | 0x00000000  | The Queue 0 Missed Packet and Overflow Counter register contains the counter for packets missed because of Receive queue packet flush and packets discarded because of Receive queue overflow |
| <u>GMAC MTL RxQ0 Debug</u>               | 0x0D38 | W    | 0x00000000  | The Queue 0 Receive Debug register gives the debug status of various blocks related to the Receive queue                                                                                      |
| <u>GMAC DMA Mode</u>                     | 0x1000 | W    | 0x00000000  | The Bus Mode register establishes the bus operating modes for the DMA                                                                                                                         |
| <u>GMAC DMA SysBus Mode</u>              | 0x1004 | W    | 0x00010000  | The System Bus mode register controls the behavior of the AHB or AXI master                                                                                                                   |
| <u>GMAC DMA Interrupt Status</u>         | 0x1008 | W    | 0x00000000  | The application reads this Interrupt Status register during interrupt service routine or polling to determine the interrupt status of DMA channels, MTL queues, and the MAC                   |
| <u>GMAC DMA Debug Status0</u>            | 0x100C | W    | 0x00000000  | The Debug Status 0 register gives the Receive and Transmit process status for DMA Channel 0-Channel 2 for debugging purpose                                                                   |
| <u>GMAC AXI LPI Entry Interval</u>       | 0x1040 | W    | 0x00000000  | This register is used to control the AXI LPI entry interval                                                                                                                                   |
| <u>GMAC DMA CH0 Control</u>              | 0x1100 | W    | 0x00000000  | The register specifies the MSS value for segmentation, length to skip between two descriptors, and 8xPBL mode                                                                                 |
| <u>GMAC DMA CH0 Tx Control</u>           | 0x1104 | W    | 0x00000000  | The register controls the Tx features such as PBL, TCP segmentation, and Tx Channel weights                                                                                                   |

| Name                                            | Offset | Size | Reset Value | Description                                                                                                                                |
|-------------------------------------------------|--------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC DMA CH0 Rx Control</u>                  | 0x1108 | W    | 0x00000000  | The DMA Channel0 Receive Control register controls the Rx features such as PBL, buffer size, and extended status                           |
| <u>GMAC DMA CH0 TxDesc List HAddress</u>        | 0x1110 | W    | 0x00000000  | The Channel0 Tx Descriptor List HAddress register has the higher 8 or 16 bits of the start address of the Transmit descriptor list         |
| <u>GMAC DMA CH0 TxDesc List Address</u>         | 0x1114 | W    | 0x00000000  | The Channel0 Tx Descriptor List Address register points the DMA to the start of Transmit descriptor list                                   |
| <u>GMAC DMA CH0 RxDesc List HAaddress</u>       | 0x1118 | W    | 0x00000000  | The Channel0 Rx Descriptor List HAddress register has the higher 8 or 16 bits of the start address of the Receive descriptor list          |
| <u>GMAC DMA CH0 RxDesc List Address</u>         | 0x111C | W    | 0x00000000  | The Channel0 Rx Descriptor List Address register points the DMA to the start of Receive descriptor list                                    |
| <u>GMAC DMA CH0 TxDesc Tail Pointer</u>         | 0x1120 | W    | 0x00000000  | The Channel0 Tx Descriptor Tail Pointer register points to an offset from the base and indicates the location of the last valid descriptor |
| <u>GMAC DMA CH0 RxDesc Tail Pointer</u>         | 0x1128 | W    | 0x00000000  | The Channel0 Rx Descriptor Tail Pointer Points to an offset from the base and indicates the location of the last valid descriptor          |
| <u>GMAC DMA CH0 TxDesc Ring Length</u>          | 0x112C | W    | 0x00000000  | The Tx Descriptor Ring Length register contains the length of the Transmit descriptor ring                                                 |
| <u>GMAC DMA CH0 RxDesc Ring Length</u>          | 0x1130 | W    | 0x00000000  | The Channel0 Rx Descriptor Ring Length register contains the length of the Receive descriptor circular ring                                |
| <u>GMAC DMA CH0 Interrupt Enable</u>            | 0x1134 | W    | 0x00000000  | The Channel0 Interrupt Enable register enables the interrupts reported by the Status register                                              |
| <u>GMAC DMA CH0 Rx Interrupt Watchdog Timer</u> | 0x1138 | W    | 0x00000000  | The Receive Interrupt Watchdog Timer register indicates the watchdog timeout for Receive Interrupt (RI) from the DMA                       |
| <u>GMAC DMA CH0 Current App TxDesc</u>          | 0x1144 | W    | 0x00000000  | The Channel0 Current Application Transmit Descriptor register points to the current Transmit descriptor read by the DMA                    |
| <u>GMAC DMA CH0 Current App RxDesc</u>          | 0x114C | W    | 0x00000000  | The Channel0 Current Application Receive Descriptor register points to the current Receive descriptor read by the DMA                      |

| Name                                | Offset | Size | Reset Value | Description                                                                                                                                                                |
|-------------------------------------|--------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GMAC DMA CH0 Current App TxBuffer_H | 0x1150 | W    | 0x00000000  | The Channeli Current Application Transmit Buffer Address High register has the higher 8 or 16 bits of the current address of the Transmit buffer address read by the DMA   |
| GMAC DMA CH0 Current App TxBuffer   | 0x1154 | W    | 0x00000000  | The Channel0 Current Application Transmit Buffer Address register points to the current Tx buffer address read by the DMA                                                  |
| GMAC DMA CH0 Current App RxBuffer_H | 0x1158 | W    | 0x00000000  | The Channeli Current Application Receive Buffer Address High register has the higher 8 or 16 bits of the current address of the Receive buffer address read by the DMA     |
| GMAC DMA CH0 Current App RxBuffer   | 0x115C | W    | 0x00000000  | The Channel0 Current Application Receive Buffer Address register points to the current Rx buffer address read by the DMA                                                   |
| GMAC DMA CH0 Status                 | 0x1160 | W    | 0x00000000  | The software driver (application) reads the Status register during interrupt service routine or polling to determine the status of the DMA                                 |
| GMAC DMA CH0 Miss Frame Cnt         | 0x1164 | W    | 0x00000000  | This register has the number of packet counter that got dropped by the DMA either due to Bus Error or due to programming RPF field in DMA_CH <i>i</i> _Rx_Control register |
| GMAC DMA CH0 RX ERI Cnt             | 0x1168 | W    | 0x00000000  | The DMA_CH0_RX_ERI_Cnt registers provides the count of the number of times ERI was asserted                                                                                |

Notes: **S**-Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

#### 19.4.2 Detail Registers Description

##### GMAC MAC Configuration

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | ARPEN<br>ARP Offload Enable<br>When this bit is set, the MAC can recognize an incoming ARP request packet and schedules the ARP packet for transmission. It forwards the ARP packet to the application and also indicate the events in the RxStatus. When this bit is reset, the MAC receiver does not recognize any ARP packet and indicates them as Type frame in the RxStatus.<br>This bit is available only when the Enable IPv4 ARP Offload is selected.<br>Values:<br>1'b0: ARP Offload is disabled<br>1'b1: ARP Offload is enabled |
| 30:28 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27         | RW          | 0x0                | <p>IPC<br/>Checksum Offload<br/>When set, this bit enables the IPv4 header checksum checking and IPv4 or IPv6 TCP, UDP, or ICMP payload checksum checking. When this bit is reset, the COE function in the receiver is disabled. The Layer 3 and Layer 4 Packet Filter and Enable Split Header features automatically selects the IPC Full Checksum Offload Engine on the Receive side. When any of these features are enabled, you must set the IPC bit.</p> <p>Values:<br/>1'b0: IP header/payload checksum checking is disabled<br/>1'b1: IP header/payload checksum checking is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 26:24      | RW          | 0x0                | <p>IPG<br/>Inter-Packet Gap<br/>These bits control the minimum IPG between packets during transmission. This range of minimum IPG is valid in full-duplex mode. In the half-duplex mode, the minimum IPG can be configured only for 64-bit times (IPG = 100). Lower values are not considered. When a JAM pattern is being transmitted because of backpressure activation, the MAC does not consider the minimum IPG. The above function (IPG less than 96 bit times) is valid only when EIPGEN bit in MAC_Ext_Configuration register is reset. When EIPGEN is set, then the minimum IPG (greater than 96 bit times) is controlled as per the description given in EIPG field in MAC_Ext_Configuration register.</p> <p>Values:<br/>3'b000: 96 bit times IPG<br/>3'b001: 88 bit times IPG<br/>3'b010: 80 bit times IPG<br/>3'b011: 72 bit times IPG<br/>3'b100: 64 bit times IPG<br/>3'b101: 56 bit times IPG<br/>3'b110: 48 bit times IPG<br/>3'b111: 40 bit times IPG</p>                                                                                                                                                                                               |
| 23         | RW          | 0x0                | <p>GPSLCE<br/>Giant Packet Size Limit Control Enable<br/>When this bit is set, the MAC considers the value in GPSL field in MAC_Ext_Configuration register to declare a received packet as Giant packet. This field must be programmed to more than 1,518 bytes. Otherwise, the MAC considers 1,518 bytes as giant packet limit. When this bit is reset, the MAC considers a received packet as Giant packet when its size is greater than 1,518 bytes (1522 bytes for tagged packet). The watchdog timeout limit, Jumbo Packet Enable and 2K Packet Enable have higher precedence over this bit, that is the MAC considers a received packet as Giant packet when its size is greater than 9,018 bytes (9,022 bytes for tagged packet) with Jumbo Packet Enabled and greater than 2,000 bytes with 2K Packet Enabled. The watchdog timeout, if enabled, terminates the received packet when watchdog limit is reached. Therefore, the programmed giant packet limit should be less than the watchdog limit to get the giant packet status.</p> <p>Values:<br/>1'b0: Giant Packet Size Limit Control is disabled<br/>1'b1: Giant Packet Size Limit Control is enabled</p> |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22    | RW   | 0x0         | <p>S2KP<br/>IEEE 802.3as Support for 2K Packets<br/>When this bit is set, the MAC considers all packets with up to 2,000 bytes length as normal packets. When the JE bit is not set, the MAC considers all received packets of size more than 2K bytes as Giant packets. When this bit is reset and the JE bit is not set, the MAC considers all received packets of size more than 1,518 bytes (1,522 bytes for tagged) as giant packets.<br/>Note: When the JE bit is set, setting this bit has no effect on the giant packet status.</p> <p>Values:<br/>1'b0: Support upto 2K packet is disabled<br/>1'b1: Support upto 2K packet is Enabled</p>                                                                                                    |
| 21    | RW   | 0x0         | <p>CST<br/>CRC stripping for Type packets<br/>When this bit is set, the last four bytes (FCS) of all packets of Ether type (type field greater than 1,536) are stripped and dropped before forwarding the packet to the application.<br/>Note: For information about how the settings of the ACS bit and this bit impact the packet length, see the Table, Packet Length based on the CST and ACS Bits.</p> <p>Values:<br/>1'b0: CRC stripping for Type packets is disabled<br/>1'b1: CRC stripping for Type packets is enabled</p>                                                                                                                                                                                                                    |
| 20    | RW   | 0x0         | <p>ACS<br/>Automatic Pad or CRC Stripping<br/>When this bit is set, the MAC strips the Pad or FCS field on the incoming packets only if the value of the length field is less than 1,536 bytes. All received packets with length field greater than or equal to 1,536 bytes are passed to the application without stripping the Pad or FCS field. When this bit is reset, the MAC passes all incoming packets to the application, without any modification.<br/>Note: For information about how the settings of CST bit and this bit impact the packet length, see the Table, Packet Length based on the CST and ACS Bit .</p> <p>Values:<br/>1'b0: Automatic Pad or CRC Stripping is disabled<br/>1'b1: Automatic Pad or CRC Stripping is enabled</p> |
| 19    | RW   | 0x0         | <p>WD<br/>Watchdog Disable<br/>When this bit is set, the MAC disables the watchdog timer on the receiver. The MAC can receive packets of up to 16,383 bytes. When this bit is reset, the MAC does not allow more than 2,048 bytes (10,240 if JE is set high) of the packet being received. The MAC cuts off any bytes received after 2,048 bytes.</p> <p>Values:<br/>1'b0: Watchdog is enabled<br/>1'b1: Watchdog is disabled</p>                                                                                                                                                                                                                                                                                                                      |
| 18:17 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | <p><b>JE</b><br/>Jumbo Packet Enable<br/>When this bit is set, the MAC allows jumbo packets of 9,018 bytes (9,022 bytes for VLAN tagged packets) without reporting a giant packet error in the Rx packet status.<br/>Values:<br/>1'b0: Jumbo packet is disabled<br/>1'b1: Jumbo packet is enabled</p>                                                                                                                                                                                                                                                      |
| 15         | RW          | 0x1                | <p><b>PS</b><br/>Port Select<br/>This bit selects the Ethernet line speed. This bit, along with Bit 14, selects the exact line speed. In the 10/100 Mbps-only (always 1) or 1000 Mbps-only (always 0) configurations, this bit is read-only (RO) with appropriate value. In default 10/100/1000 Mbps configurations, this bit is read-write (R/W). The mac_speed_o[1] signal reflects the value of this bit.<br/>Values:<br/>1'b0: For 1000 or 2500 Mbps operations<br/>1'b1: For 10 or 100 Mbps operations</p>                                            |
| 14         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13         | RW          | 0x0                | <p><b>DM</b><br/>Duplex Mode<br/>When this bit is set, the MAC operates in the full-duplex mode in which it can transmit and receive simultaneously. This bit is RO with default value of 1'b1 in the full-duplex-only configurations.<br/>Values:<br/>1'b0: Half-duplex mode<br/>1'b1: Full-duplex mode</p>                                                                                                                                                                                                                                               |
| 12         | RW          | 0x0                | <p><b>LM</b><br/>Loopback Mode<br/>When this bit is set, the MAC operates in the loopback mode at GMII or MII. The (G)MII Rx clock input (clk_rx_i) is required for the loopback to work properly. This is because the Tx clock is not internally looped back.<br/>Values:<br/>1'b0: Loopback is disabled<br/>1'b1: Loopback is enabled</p>                                                                                                                                                                                                                |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 9          | RW          | 0x0                | <p><b>DCRS</b><br/>Disable Carrier Sense During Transmission<br/>When this bit is set, the MAC transmitter ignores the (G)MII CRS signal during packet transmission in the half-duplex mode. As a result, no errors are generated because of Loss of Carrier or No Carrier during transmission.<br/>When this bit is reset, the MAC transmitter generates errors because of Carrier Sense. The MAC can even abort the transmission.<br/>Values:<br/>1'b0: Enable Carrier Sense During Transmission<br/>1'b1: Disable Carrier Sense During Transmission</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | RW   | 0x0         | <p>DR<br/>Disable Retry</p> <p>When this bit is set, the MAC attempts only one transmission. When a collision occurs on the GMII or MII interface, the MAC ignores the current packet transmission and reports a Packet Abort with excessive collision error in the Tx packet status. When this bit is reset, the MAC retries based on the settings of the BL field. This bit is applicable only in the half-duplex mode.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Enable Retry</li> <li>1'b1: Disable Retry</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6:5 | RW   | 0x0         | <p>BL<br/>Back-Off Limit</p> <p>The back-off limit determines the random integer number (r) of slot time delays (4,096 bit times for 1000/2500 Mbps; 512 bit times for 10/100 Mbps) for which the MAC waits before rescheduling a transmission attempt during retries after a collision. n = retransmission attempt.</p> <p>The random integer r takes the value in the range <math>0 \leq r &lt; 2^k</math></p> <p>This bit is applicable only in the half-duplex mode.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>2'b00: k = min(n,10)</li> <li>2'b01: k = min(n,8)</li> <li>2'b10: k = min(n,4)</li> <li>2'b11: k = min(n,1)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4   | RW   | 0x0         | <p>DC<br/>Deferral Check</p> <p>When this bit is set, the deferral check function is enabled in the MAC. The MAC issues a Packet Abort status, along with the excessive deferral error bit set in the Tx packet status, when the Tx state machine is deferred for more than 24,288 bit times in 10 or 100 Mbps mode. If the MAC is configured for 1000/2500 Mbps operation, the threshold for deferral is 155,680 bits times.</p> <p>Deferral begins when the transmitter is ready to transmit, but it is prevented because of an active carrier sense signal (CRS) on GMII or MII. The defer time is not cumulative. For example, if the transmitter defers for 10,000 bit times because the CRS signal is active and the CRS signal becomes inactive, the transmitter transmits and collision happens. Because of collision, the transmitter needs to back off and then defer again after back off completion. In such a scenario, the deferral timer is reset to 0, and it is restarted. When this bit is reset, the deferral check function is disabled and the MAC defers until the CRS signal goes inactive. This bit is applicable only in the half-duplex mode.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Deferral check function is disabled</li> <li>1'b1: Deferral check function is enabled</li> </ul> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2 | RW   | 0x0         | <p>PRELEN<br/>Preamble Length for Transmit packets<br/>These bits control the number of preamble bytes that are added to the beginning of every Tx packet. The preamble reduction occurs only when the MAC is operating in the full-duplex mode.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>2'b00: 7 bytes of preamble</li> <li>2'b01: 5 bytes of preamble</li> <li>2'b10: 3 bytes of preamble</li> <li>2'b11: Reserved</li> </ul>                                                   |
| 1   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0   | RW   | 0x0         | <p>RE<br/>Receiver Enable<br/>When this bit is set, the Rx state machine of the MAC is enabled for receiving packets from the GMII or MII interface. When this bit is reset, the MAC Rx state machine is disabled after it completes the reception of the current packet. The Rx state machine does not receive any more packets from the GMII or MII interface.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Receiver is disabled</li> <li>1'b1: Receiver is enabled</li> </ul> |

**GMAC MAC Ext Configuration**

Address: Operational Base + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 29:25 | RW   | 0x00        | <p>EIPG<br/>Extended Inter-Packet Gap<br/>The value in this field is applicable when the EIPGEN bit is set. This field (as Most Significant bits), along with IPG field in MAC_Configuration register, gives the minimum IPG greater than 96 bit times in steps of 8 bit times: {EIPG, IPG}</p> <ul style="list-style-type: none"> <li>8'h00 - 104 bit times</li> <li>8'h01 - 112 bit times</li> <li>8'h02 - 120 bit times</li> <li>-----</li> <li>8'hFF - 2144 bit times</li> </ul>                                                                                                                                                                                                                                                                                                                                        |
| 24    | RW   | 0x0         | <p>EIPGEN<br/>Extended Inter-Packet Gap Enable<br/>When this bit is set, the MAC interprets EIPG field and IPG field in MAC_Configuration register together as minimum IPG greater than 96 bit times in steps of 8 bit times. When this bit is reset, the MAC ignores EIPG field and interprets IPG field in MAC_Configuration register as minimum IPG less than or equal to 96 bit times in steps of 8 bit times.</p> <p>Note: The extended Inter-Packet Gap feature must be enabled when operating in Full-Duplex mode only. There may be undesirable effects on back-pressure function and frame transmission if it is enabled in Half-Duplex mode.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Extended Inter-Packet Gap is disabled</li> <li>1'b1: Extended Inter-Packet Gap is enabled</li> </ul> |
| 23    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22:20      | RW          | 0x0                | <p>HDSMS<br/>Maximum Size for Splitting the Header Data<br/>These bits indicate the maximum header size allowed for splitting the header data in the received packet.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>0x0 (64BYTES): Maximum Size for Splitting the Header Data is 64 bytes</li> <li>0x1 (128BYTES): Maximum Size for Splitting the Header Data is 128 bytes</li> <li>0x2 (256BYTES): Maximum Size for Splitting the Header Data is 256 bytes</li> <li>0x3 (512BYTES): Maximum Size for Splitting the Header Data is 512 bytes</li> <li>0x4 (1024BYTES): Maximum Size for Splitting the Header Data is 1024 bytes</li> <li>0x5 (RSVD): Reserved</li> </ul>            |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 18         | RW          | 0x0                | <p>USP<br/>Unicast Slow Protocol Packet Detect<br/>When this bit is set, the MAC detects the Slow Protocol packets with unicast address of the station specified in the MAC_Address0_High and MAC_Address0_Low registers. The MAC also detects the Slow Protocol packets with the Slow Protocols multicast address (01-80-C2-00-00-02). When this bit is reset, the MAC detects only Slow Protocol packets with the Slow Protocol multicast address specified in the IEEE 802.3-2015, Section 5.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Unicast Slow Protocol Packet Detection is disabled</li> <li>1'b1: Unicast Slow Protocol Packet Detection is enabled</li> </ul> |
| 17         | RW          | 0x0                | <p>SPEN<br/>Slow Protocol Detection Enable<br/>When this bit is set, MAC processes the Slow Protocol packets (Ether Type 0x8809) and provides the Rx status. The MAC discards the Slow Protocol packets with invalid sub-types. When this bit is reset, the MAC forwards all error-free Slow Protocol packets to the application. The MAC considers such packets as normal Type packets.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Slow Protocol Detection is disabled</li> <li>1'b1: Slow Protocol Detection is enabled</li> </ul>                                                                                                                                       |
| 16         | RW          | 0x0                | <p>DCRCC<br/>Disable CRC Checking for Received Packets<br/>When this bit is set, the MAC receiver does not check the CRC field in the received packets. When this bit is reset, the MAC receiver always checks the CRC field in the received packets.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: CRC Checking is enabled</li> <li>1'b1: CRC Checking is disabled</li> </ul>                                                                                                                                                                                                                                                                                                |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0       | RW          | 0x0000             | <p>GPSL<br/>Giant Packet Size Limit</p> <p>If the received packet size is greater than the value programmed in this field in units of bytes, the MAC declares the received packet as Giant packet. The value programmed in this field must be greater than or equal to 1,518 bytes. Any other programmed value is considered as 1,518 bytes. For VLAN tagged packets, the MAC adds 4 bytes to the programmed value. When the Enable Double VLAN Processing option is selected, the MAC adds 8 bytes to the programmed value for double VLAN tagged packets. The value in this field is applicable when the GPSLCE bit is set in MAC_Configuration register.</p> |

**GMAC MAC Packet Filter**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>RA<br/>Receive All</p> <p>When this bit is set, the MAC Receiver module passes all received packets to the application, irrespective of whether they pass the address filter or not. The result of the SA or DA filtering is updated (pass or fail) in the corresponding bit in the Rx Status Word.</p> <p>When this bit is reset, the Receiver module passes only those packets to the application that pass the SA or DA address filter.</p> <p>0x0 (DISABLE): Receive All is disabled<br/>0x1 (ENABLE): Receive All is enabled</p> |
| 30:17      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 16         | RW          | 0x0                | <p>VTFE<br/>VLAN Tag Filter Enable</p> <p>When this bit is set, the MAC drops the VLAN tagged packets that do not match the VLAN Tag. When this bit is reset, the MAC forwards all packets irrespective of the match status of the VLAN Tag.</p> <p>Values:<br/>1'b0: VLAN Tag Filter is disabled<br/>1'b1: VLAN Tag Filter is enabled</p>                                                                                                                                                                                               |
| 15:11      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 10         | RW          | 0x0                | <p>HPF<br/>Hash or Perfect Filter</p> <p>When this bit is set, the address filter passes a packet if it matches either the perfect filtering or hash filtering as set by the HMC or HUC bit. When this bit is reset and the HUC or HMC bit is set, the packet is passed only if it matches the Hash filter.</p> <p>Values:<br/>1'b0: Hash or Perfect Filter is disabled<br/>2'b1: Hash or Perfect Filter is enabled</p>                                                                                                                  |
| 9:8        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6        | RW          | 0x0                | <p>PCF<br/>Pass Control Packets<br/>These bits control the forwarding of all control packets (including unicast and multicast Pause packets).</p> <p>Values:</p> <ul style="list-style-type: none"> <li>2'b00: MAC filters all control packets from reaching the application</li> <li>2'b01: MAC forwards all control packets except Pause packets to the application even if they fail the Address filter</li> <li>2'b10: MAC forwards all control packets to the application even if they fail the Address filter</li> <li>2'b11: MAC forwards the control packets that pass the Address filter</li> </ul> |
| 5          | RW          | 0x0                | <p>DBF<br/>Disable Broadcast Packets<br/>When this bit is set, the AFM module blocks all incoming broadcast packets. In addition, it overrides all other filter settings. When this bit is reset, the AFM module passes all received broadcast packets.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Enable Broadcast Packets</li> <li>1'b1: Disable Broadcast Packets</li> </ul>                                                                                                                                                                                                         |
| 4          | RW          | 0x0                | <p>PM<br/>Pass All Multicast<br/>When this bit is set, it indicates that all received packets with a multicast destination address (first bit in the destination address field is '1') are passed. When this bit is reset, filtering of multicast packet depends on HMC bit.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Pass All Multicast is disabled</li> <li>1'b1: Pass All Multicast is enabled</li> </ul>                                                                                                                                                                          |
| 3          | RW          | 0x0                | <p>DAIF<br/>DA Inverse Filtering<br/>When this bit is set, the Address Check block operates in inverse filtering mode for the DA address comparison for both unicast and multicast packets. When this bit is reset, normal filtering of packets is performed.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: DA Inverse Filtering is disabled</li> <li>1'b1: DA Inverse Filtering is enabled</li> </ul>                                                                                                                                                                                     |
| 2          | RW          | 0x0                | <p>HMC<br/>Hash Multicast<br/>When this bit is set, the MAC performs the destination address filtering of received multicast packets according to the hash table. When this bit is reset, the MAC performs the perfect destination address filtering for multicast packets, that is, it compares the DA field with the values programmed in DA registers.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Hash Multicast is disabled</li> <li>1'b1: Hash Multicast is enabled</li> </ul>                                                                                                     |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**GMAC MAC Watchdog Timeout**

Address: Operational Base + offset (0x000C)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | RW   | 0x0         | <p>PWE<br/>Programmable Watchdog Enable<br/>When this bit is set and the WD bit of the MAC_Configuration register is reset, the WTO field is used as watchdog timeout for a received packet. When this bit is cleared, the watchdog timeout for a received packet is controlled by setting of WD and JE bits in MAC_Configuration register.</p> <p>Values:<br/>1'b0: Programmable Watchdog is disabled<br/>1'b1: Programmable Watchdog is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7:4 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3:0 | RW   | 0x0         | <p>WTO<br/>Watchdog Timeout<br/>When the PWE bit is set and the WD bit of the MAC_Configuration register is reset, this field is used as watchdog timeout for a received packet. If the length of a received packet exceeds the value of this field, such packet is terminated and declared as an error packet.</p> <p>Note: When the PWE bit is set, the value in this field should be more than 1,522 (0x05F2). Otherwise, the IEEE 802.3-specified valid tagged packets are declared as error packets and then dropped.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>4'b0000: 2 KB</li> <li>4'b0001: 3 KB</li> <li>4'b0010: 4 KB</li> <li>4'b0011: 5 KB</li> <li>4'b0100: 6 KB</li> <li>4'b0101: 7 KB</li> <li>4'b0110: 8 KB</li> <li>4'b0111: 9 KB</li> <li>4'b1000: 10 KB</li> <li>4'b1001: 11 KB</li> <li>4'b1010: 12 KB</li> <li>4'b1011: 13 KB</li> <li>4'b1100: 14 KB</li> <li>4'b1101: 15 KB</li> <li>4'b1110: 16383 Bytes</li> <li>4'b1111: Reserved</li> </ul> |

**GMAC MAC Hash Table Reg0**

Address: Operational Base + offset (0x0010)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>HT31T0<br/>MAC Hash Table First 32 Bits</p> <p>This field contains the first 32 Bits [31:0] of the Hash table. The Hash table is used for group address filtering. For hash filtering, the content of the destination address in the incoming packet is passed through the CRC logic and the upper six (seven in 128-bit Hash or eight in 256-bit Hash) bits of the CRC register are used to index the content of the Hash table. The most significant bits determines the register to be used (Hash Table Register X), and the least significant five bits determine the bit within the register. For example, a hash value of 6'b100000 (in 64-bit Hash) selects Bit 0 of the Hash Table Register 1, a value of 7b'1110000 (in 128-bit Hash) selects Bit 16 of the Hash Table Register 3 and a value of 8b'10111111 (in 256-bit Hash) selects Bit 31 of the Hash Table Register 5.</p> <p>The hash value of the destination address is calculated in the following way:</p> <ol style="list-style-type: none"> <li>1. Calculate the 32-bit CRC for the DA (See IEEE 802.3, Section 3.2.8 for the steps to calculate CRC32).</li> <li>2. Perform bitwise reversal for the value obtained in Step 1.</li> <li>3. Take the upper 6 (or 7 or 8) bits from the value obtained in Step 2. If the corresponding bit value of the register is 1'b1, the packet is accepted. Otherwise, it is rejected. If the PM bit is set in MAC_Packet_Filter, all multicast packets are accepted regardless of the multicast hash values.</li> </ol> <p>If the Hash Table register is configured to be double-synchronized to the (G)MII clock domain, the synchronization is triggered only when Bits[31:24] (in little-endian mode) or Bits[7:0] (in big-endian mode) of the Hash Table Register X registers are written. If double-synchronization is enabled, consecutive writes to this register should be performed after at least four clock cycles in the destination clock domain.</p> |

**GMAC MAC Hash Table Reg1**

Address: Operational Base + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                                                                                               |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>HT63T32<br/>MAC Hash Table Second 32 Bits</p> <p>This field contains the second 32 Bits [63:32] of the Hash table.</p> |

**GMAC MAC VLAN Tag**

Address: Operational Base + offset (0x0050)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                 |
| 24    | RW   | 0x0         | <p>EVLRXS<br/>Enable VLAN Tag in Rx status</p> <p>When this bit is set, MAC provides the outer VLAN Tag in the Rx status. When this bit is reset, the MAC does not provide the outer VLAN Tag in Rx status.</p> <p>Values:</p> <p>1'b0: VLAN Tag in Rx status is disabled<br/>1'b1: VLAN Tag in Rx status is enabled</p> |
| 23    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22:21      | RW          | 0x0                | <p><b>EVLS</b><br/>Enable VLAN Tag Stripping on Receive<br/>This field indicates the stripping operation on the outer VLAN Tag in received packet.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>2'b00: Do not strip</li> <li>2'b01: Strip if VLAN filter passes</li> <li>2'b10: Strip if VLAN filter fails</li> <li>2'b11: Always strip</li> </ul>                                                                                                                                                           |
| 20         | RW          | 0x0                | <p><b>DOVLTC</b><br/>Disable VLAN Type Check<br/>When this bit is set, the MAC does not check whether the VLAN Tag specified by the ERIVLT bit is of type S-VLAN or C-VLAN.<br/>When this bit is reset, the MAC filters or matches the VLAN Tag specified by the ERIVLT bit only when VLAN Tag type is similar to the one specified by the ERSVLM bit.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: VLAN Type Check is enabled</li> <li>1'b1: VLAN Type Check is disabled</li> </ul>                   |
| 19         | RW          | 0x0                | <p><b>ERSVLM</b><br/>Enable Receive S-VLAN Match<br/>When this bit is set, the MAC receiver enables filtering or matching for S-VLAN (Type = 0x88A8) packets. When this bit is reset, the MAC receiver enables filtering or matching for C-VLAN (Type = 0x8100) packets. The ERIVLT bit determines the VLAN tag position considered for filtering or matching.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Receive S-VLAN Match is disabled</li> <li>1'b1: Receive S-VLAN Match is enabled</li> </ul> |
| 18         | RW          | 0x0                | <p><b>ESVL</b><br/>Enable S-VLAN<br/>When this bit is set, the MAC transmitter and receiver consider the S-VLAN packets (Type = 0x88A8) as valid VLAN tagged packets.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: S-VLAN is disabled</li> <li>1'b1: S-VLAN is enabled</li> </ul>                                                                                                                                                                                                                      |
| 17         | RW          | 0x0                | <p><b>VTIM</b><br/>VLAN Tag Inverse Match Enable<br/>When this bit is set, this bit enables the VLAN Tag inverse matching. The packets without matching VLAN Tag are marked as matched. When reset, this bit enables the VLAN Tag perfect matching. The packets with matched VLAN Tag are marked as matched.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: VLAN Tag Inverse Match is disabled</li> <li>1'b1: VLAN Tag Inverse Match is enabled</li> </ul>                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | <p>ETV<br/>Enable 12-Bit VLAN Tag Comparison<br/>When this bit is set, a 12-bit VLAN identifier is used for comparing and filtering instead of the complete 16-bit VLAN tag. Bits[11:0] of VLAN tag are compared with the corresponding field in the received VLAN-tagged packet. Similarly, when enabled, only 12 bits of the VLAN tag in the received packet are used for hash-based VLAN filtering. When this bit is reset, all 16 bits of the 15th and 16th bytes of the received VLAN packet are used for comparison and VLAN hash filtering.</p> <p>Values:<br/>1'b0: 12-Bit VLAN Tag Comparison is disabled<br/>1'b1: 12-Bit VLAN Tag Comparison is enabled</p>                                                                                                                                                         |
| 15:0       | RW          | 0x0000             | <p>VL<br/>VLAN Tag Identifier for Receive Packets<br/>This field contains the 802.1Q VLAN tag to identify the VLAN packets. This VLAN tag identifier is compared to the 15th and 16th bytes of the packets being received for VLAN packets.<br/>The following list describes the bits of this field:</p> <ol style="list-style-type: none"> <li>1. Bits[15:13]: User Priority</li> <li>2. Bit 12: Canonical Format Indicator (CFI) or Drop Eligible Indicator (DEI)</li> <li>3. Bits[11:0]: VLAN Identifier (VID) field of VLAN tag<br/>When the ETV bit is set, only the VID is used for comparison. If this field ([11:0] if ETV is set) is all zeros, the MAC does not check the 15th and 16th bytes for VLAN tag comparison and declares all packets with Type field value of 0x8100 or 0x88a8 as VLAN packets.</li> </ol> |

**GMAC MAC VLAN Hash Table**

Address: Operational Base + offset (0x0058)

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

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | RW   | 0x0000      | <p>VLHT<br/>VLAN Hash Table<br/>This field contains the 16-bit VLAN Hash Table.<br/>For hash filtering, the content of the 16-bit VLAN tag or 12-bit VLAN ID (based on the ETV bit of MAC_VLAN_Tag Register) in the incoming packet is passed through the CRC logic. When ETV bit of MAC_VLAN_Tag register is set, the upper four bits of the calculated CRC are used to index the contents of the VLAN Hash table. When ETV bit of MAC_VLAN_Tag register is reset, the ones-complement of upper four bits of the calculated CRC are used to index the contents of the VLAN Hash table. For example, when ETV bit is set a hash value of 4b'1000 selects Bit 8 of the VLAN Hash table, whereas when ETV bit is reset a hash value of 4b'1000 selects Bit 7 of the VLAN Hash table.</p> <p>The hash value of the destination address is calculated in the following way:</p> <ol style="list-style-type: none"> <li>1.Calculate the 32-bit CRC for the VLAN tag or ID (For steps to calculate CRC32, see Section 3.2.8 of IEEE 802.3).</li> <li>2.Perform bitwise reversal for the value obtained in step 1.</li> <li>3.Take the upper four bits from the value obtained in step 2.</li> </ol> <p>If the VLAN hash Table register is configured to be double-synchronized to the (G)MII clock domain, the synchronization is triggered only when Bits[15:8] (in little-endian mode) or Bits[7:0] (in big-endian mode) of this register are written.</p> <p>1.If double-synchronization is enabled, consecutive writes to this register should be performed after at least four clock cycles in the destination clock domain.</p> |

**GMAC MAC Q0 Tx Flow Ctrl**

Address: Operational Base + offset (0x0070)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | <p>PT<br/>Pause Time<br/>This field holds the value to be used in the Pause Time field in the Tx control packet. If the Pause Time bits are configured to be double-synchronized to the (G)MII clock domain, consecutive writes to this register should be performed only after at least four clock cycles in the destination clock domain.</p>                                                                                                                                                                                      |
| 15:8  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7     | RW   | 0x0         | <p>DZPQ<br/>Disable Zero-Quanta Pause<br/>When this bit is set, it disables the automatic generation of the zero-quanta Pause packets on de-assertion of the flow-control signal from the FIFO layer (MTL or external sideband flow control signal sbd_flowctrl_i or mti_flowctrl_i).<br/>When this bit is reset, normal operation with automatic zero-quanta Pause packet generation is enabled.<br/>Values:<br/>1'b0: Zero-Quanta Pause packet generation is enabled<br/>1'b1: Zero-Quanta Pause packet generation is disabled</p> |
| 6:2   | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p>TFE<br/>Transmit Flow Control Enable<br/>Full-Duplex Mode:<br/>In the full-duplex mode, when this bit is set, the MAC enables the flow control operation to Tx Pause packets. When this bit is reset, the flow control operation in the MAC is disabled, and the MAC does not transmit any Pause packets.</p> <p>Half-Duplex Mode:<br/>In the half-duplex mode, when this bit is set, the MAC enables the backpressure operation. When this bit is reset, the backpressure feature is disabled.</p> <p>Values:<br/>1'b0: Transmit Flow Control is disabled<br/>1'b1: Transmit Flow Control is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0          | RW          | 0x0                | <p>FCB_BPA<br/>Flow Control Busy or Backpressure Activate<br/>This bit initiates a Pause packet in the full-duplex mode and activates the backpressure function in the half-duplex mode if the TFE bit is set.</p> <p>Full-Duplex Mode:<br/>In the full-duplex mode, this bit should be read as 1'b0 before writing to this register. To initiate a Pause packet, the application must set this bit to 1'b1. During Control packet transfer, this bit continues to be set to indicate that a packet transmission is in progress. When Pause packet transmission is complete, the MAC resets this bit to 1'b0. You should not write to this register until this bit is cleared.</p> <p>Half-Duplex Mode:<br/>When this bit is set (and TFE bit is set) in the half-duplex mode, the MAC asserts the backpressure. During backpressure, when the MAC receives a new packet, the transmitter starts sending a JAM pattern resulting in a collision. This control register bit is logically ORed with the mti_flowctrl_i input signal for the backpressure function. When the MAC is configured for the full-duplex mode, the BPA is automatically disabled. Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:<br/>1'b0: Flow Control Busy or Backpressure Activate is disabled<br/>1'b1: Flow Control Busy or Backpressure Activate is enabled</p> |

**GMAC\_MAC\_Rx\_Flow\_Ctrl**

Address: Operational Base + offset (0x0090)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p>UP<br/>Unicast Pause Packet Detect<br/>A pause packet is processed when it has the unique multicast address specified in the IEEE 802.3. When this bit is set, the MAC can also detect Pause packets with unicast address of the station. This unicast address should be as specified in MAC_Address0_High and MAC_Address0_Low. When this bit is reset, the MAC only detects Pause packets with unique multicast address.</p> <p>Note: The MAC does not process a Pause packet if the multicast address is different from the unique multicast address. This is also applicable to the received PFC packet when the Priority Flow Control (PFC) is enabled. The unique multicast address (0x01_80_C2_00_00_01) is as specified in IEEE 802.1 Qbb-2011.</p> <p>Values:<br/>1'b0: Unicast Pause Packet Detect disabled<br/>1'b1: Unicast Pause Packet Detect enabled</p> |
| 0          | RW          | 0x0                | <p>RFE<br/>Receive Flow Control Enable<br/>When this bit is set and the MAC is operating in full-duplex mode, the MAC decodes the received Pause packet and disables its transmitter for a specified (Pause) time. When this bit is reset or the MAC is operating in half-duplex mode, the decode function of the Pause packet is disabled. When PFC is enabled, flow control is enabled for PFC packets. The MAC decodes the received PFC packet and disables the Transmit queue, with matching priorities, for a duration of received Pause time.</p> <p>Values:<br/>1'b0: Receive Flow Control is disabled<br/>1'b1: Receive Flow Control is enabled</p>                                                                                                                                                                                                                |

**GMAC MAC Interrupt Status**

Address: Operational Base + offset (0x00B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 18         | RO          | 0x0                | <p>MDIOIS<br/>MDIO Interrupt Status<br/>This bit indicates an interrupt event after the completion of MDIO operation. To reset this bit, the application has to read this bit/Write 1 to this bit when RCWE bit of MAC_CSR_SW_Ctrl register is set. Access restriction applies. Clears on read (or write of 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: MDIO Interrupt status not active<br/>1'b1: MDIO Interrupt status active</p> |
| 17:15      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14  | RO   | 0x0         | <p><b>RXSTSIS</b><br/>Receive Status Interrupt<br/>This bit indicates the status of received packets. This bit is set when the RWT bit is set in the MAC_Rx_Tx_Status register. This bit is cleared when the corresponding interrupt source bit is read (or corresponding interrupt source bit is written to 1 when RCWE bit of MAC_CSR_SW_Ctrl register is set) in the MAC_Rx_Tx_Status register.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Receive Interrupt status not active</li> <li>1'b1: Receive Interrupt status active</li> </ul>                                                                                                                                                                                                                                                                                          |
| 13  | RO   | 0x0         | <p><b>TXSTSIS</b><br/>Transmit Status Interrupt<br/>This bit indicates the status of transmitted packets. This bit is set when any of the following bits is set in the MAC_Rx_Tx_Status register:</p> <ol style="list-style-type: none"> <li>1. Excessive Collision (EXCOL)</li> <li>2. Late Collision (LCOL)</li> <li>3. Excessive Deferral (EXDEF)</li> <li>4. Loss of Carrier (LCARR)</li> <li>5. No Carrier (NCARR)</li> <li>6. Jabber Timeout (TJT)</li> </ol> <p>This bit is cleared when the corresponding interrupt source bit is read (or corresponding interrupt source bit is written to 1 when RCWE bit of MAC_CSR_SW_Ctrl register is set) in the MAC_Rx_Tx_Status register.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Transmit Interrupt status not active</li> <li>1'b1: Transmit Interrupt status active</li> </ul> |
| 12  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11  | RO   | 0x0         | <p><b>MMCRXIPIS</b><br/>MMC Receive Checksum Offload Interrupt Status<br/>This bit is set high when an interrupt is generated in the MMC Receive Checksum Offload Interrupt Register. This bit is cleared when all bits in this interrupt register are cleared. This bit is valid only when you select the Enable MAC Management Counters (MMC) and Enable Receive TCP/IP Checksum Check options.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: MMC Receive Checksum Offload Interrupt status not active</li> <li>1'b1: MMC Receive Checksum Offload Interrupt status active</li> </ul>                                                                                                                                                                                                                                                 |
| 10  | RO   | 0x0         | <p><b>MMCTXIS</b><br/>MMC Transmit Interrupt Status<br/>This bit is set high when an interrupt is generated in the MMC Transmit Interrupt Register. This bit is cleared when all bits in this interrupt register are cleared. This bit is valid only when you select the Enable MAC Management Counters (MMC) option.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: MMC Transmit Interrupt status not active</li> <li>1'b1: MMC Transmit Interrupt status active</li> </ul>                                                                                                                                                                                                                                                                                                                                                             |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | RO   | 0x0         | <p>MMCRXIS<br/>MMC Receive Interrupt Status<br/>This bit is set high when an interrupt is generated in the MMC Receive Interrupt Register. This bit is cleared when all bits in this interrupt register are cleared. This bit is valid only when you select the Enable MAC Management Counters (MMC) option.<br/>Values:<br/>1'b0: MMC Receive Interrupt status not active<br/>1'b1: MMC Receive Interrupt status active</p>                                                                                                                                                                                                                                               |
| 8   | RO   | 0x0         | <p>MMCIS<br/>MMC Interrupt Status<br/>This bit is set high when Bit 11, Bit 10, or Bit 9 is set high. This bit is cleared only when all these bits are low. This bit is valid only when you select the Enable MAC Management Counters (MMC) option.<br/>Values:<br/>1'b0: MMC Interrupt status not active<br/>1'b1: MMC Interrupt status active</p>                                                                                                                                                                                                                                                                                                                        |
| 7:5 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 4   | RO   | 0x0         | <p>PMTIS<br/>PMT Interrupt Status<br/>This bit is set when a Magic packet or Wake-on-LAN packet is received in the power-down mode (RWKPRCVD and MGKPRCVD bits in MAC_PMT_Control_Status register). This bit is cleared when corresponding interrupt source bit are cleared because of a Read operation to the MAC_PMT_Control_Status register (or corresponding interrupt source bit of MAC_PMT_Control_Status register is written to 1 when RCWE bit of MAC_CSR_SW_Ctrl register is set).<br/>This bit is valid only when you select the Enable Power Management option.<br/>Values:<br/>1'b0: PMT Interrupt status not active<br/>1'b1: PMT Interrupt status active</p> |
| 3   | RO   | 0x0         | <p>PHYIS<br/>PHY Interrupt<br/>This bit is set when rising edge is detected on the phy_intr_i input. This bit is cleared when this register is read (or this bit is written to 1 when RCWE bit of MAC_CSR_SW_Ctrl register is set).<br/>Values:<br/>1'b0: PHY Interrupt not detected<br/>1'b1: PHY Interrupt detected</p>                                                                                                                                                                                                                                                                                                                                                  |
| 2:0 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**GMAC MAC Interrupt Enable**

Address: Operational Base + offset (0x00B4)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                        |
| 18    | RW   | 0x0         | <p>MDIOIE<br/>MDIO Interrupt Enable<br/>When this bit is set, it enables the assertion of the interrupt when MDIOIS field is set in the MAC_Interrupt_Status register.<br/>Values:<br/>1'b0: MDIO Interrupt is disabled<br/>1'b1: MDIO Interrupt is enabled</p> |
| 17:15 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                        |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14   | RW   | 0x0         | <p><b>RXSTSIE</b><br/>Receive Status Interrupt Enable<br/>When this bit is set, it enables the assertion of the interrupt signal because of the setting of RXSTSIS bit in the MAC_Interrupt_Status register.</p> <p>Values:<br/>1'b0: Receive Status Interrupt is disabled<br/>1'b1: Receive Status Interrupt is enabled</p>      |
| 13   | RW   | 0x0         | <p><b>TXSTSIE</b><br/>Transmit Status Interrupt Enable<br/>When this bit is set, it enables the assertion of the interrupt signal because of the setting of TXSTSIS bit in the MAC_Interrupt_Status register.</p> <p>Values:<br/>1'b0: Timestamp Status Interrupt is disabled<br/>1'b1: Timestamp Status Interrupt is enabled</p> |
| 12:5 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                          |
| 4    | RW   | 0x0         | <p><b>PMTIE</b><br/>PMT Interrupt Enable<br/>When this bit is set, it enables the assertion of the interrupt signal because of the setting of PMTIS bit in MAC_Interrupt_Status register.</p> <p>Values:<br/>1'b0: PMT Interrupt is disabled<br/>1'b1: PMT Interrupt is enabled</p>                                               |
| 3    | RW   | 0x0         | <p><b>PHYIE</b><br/>PHY Interrupt Enable<br/>When this bit is set, it enables the assertion of the interrupt signal because of the setting of PHYIS bit in MAC_Interrupt_Status register.</p> <p>Values:<br/>1'b0: PHY Interrupt is disabled<br/>1'b1: PHY Interrupt is enabled</p>                                               |
| 2:0  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                          |

**GMAC MAC Rx Tx Status**

Address: Operational Base + offset (0x00B8)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 8    | RO   | 0x0         | <p><b>RWT</b><br/>Receive Watchdog Timeout<br/>This bit is set when a packet with length greater than 2,048 bytes is received (10,240 bytes when Jumbo Packet mode is enabled) and the WD bit is reset in the MAC_Configuration register. This bit is set when a packet with length greater than 16,383 bytes is received and the WD bit is set in the MAC_Configuration register. Access restriction applies. Clears on read (or write of 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: No receive watchdog timeout<br/>1'b1: Receive watchdog timed out</p> |
| 7:5  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | <p><b>LCOL</b><br/>Late Collision<br/>When the DTXSTS bit is set in the MTL_Operation_Mode register, this bit indicates that the packet transmission aborted because a collision occurred after the collision window (64 bytes including Preamble in MII mode; 512 bytes including Preamble and Carrier Extension in GMII mode). This bit is not valid if the Underflow error occurs.</p> <p>Access restriction applies. Clears on read (or write of 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: No collision</li> <li>1'b1: Late collision is sensed</li> </ul> |
| 3          | RO          | 0x0                | <p><b>EXDEF</b><br/>Excessive Deferral<br/>When the DTXSTS bit is set in the MTL_Operation_Mode register and the DC bit is set in the MAC_Configuration register, this bit indicates that the transmission ended because of excessive deferral of over 24,288 bit times (155,680 in 1000/2500 Mbps mode or when Jumbo packet is enabled).</p> <p>Access restriction applies. Clears on read (or write of 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: No Excessive deferral</li> <li>1'b1: Excessive deferral</li> </ul>                                          |
| 2          | RO          | 0x0                | <p><b>LCARR</b><br/>Loss of Carrier<br/>When the DTXSTS bit is set in the MTL_Operation_Mode register, this bit indicates that the loss of carrier occurred during packet transmission, that is, the phy_crs_i signal was inactive for one or more transmission clock periods during packet transmission. This bit is valid only for packets transmitted without collision.</p> <p>Access restriction applies. Clears on read (or write of 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Carrier is present</li> <li>1'b1: Loss of carrier</li> </ul>              |
| 1          | RO          | 0x0                | <p><b>NCARR</b><br/>No Carrier<br/>When the DTXSTS bit is set in the MTL_Operation_Mode register, this bit indicates that the carrier signal from the PHY is not present at the end of preamble transmission.</p> <p>Access restriction applies. Clears on read (or write of 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Carrier is present</li> <li>1'b1: No carrier</li> </ul>                                                                                                                                                                                 |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RO   | 0x0         | <p>TJT<br/>Transmit Jabber Timeout<br/>This bit indicates that the Transmit Jabber Timer expired which happens when the packet size exceeds 2,048 bytes (10,240 bytes when the Jumbo packet is enabled) and JD bit is reset in the MAC_Configuration register. This bit is set when the packet size exceeds 16,383 bytes and the JD bit is set in the MAC_Configuration register.</p> <p>Access restriction applies. Clears on read (or write of 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: No Transmit Jabber Timeout</li> <li>1'b1: Transmit Jabber Timeout occur</li> </ul> |

**GMAC MAC PMT Control Status**

Address: Operational Base + offset (0x00C0)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | <p>RWKFLTRST<br/>Remote Wake-Up Packet Filter Register Pointer Reset<br/>When this bit is set, the remote wake-up packet filter register pointer is reset to 3'b000. It is automatically cleared after 1 clock cycle.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Remote Wake-Up Packet Filter Register Pointer is not Reset</li> <li>1'b1: Remote Wake-Up Packet Filter Register Pointer is Reset</li> </ul> |
| 30:29 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 28:24 | RO   | 0x00        | <p>RWKPTR<br/>Remote Wake-up FIFO Pointer<br/>This field gives the current value (0 to 7, 15, or 31 when 4, 8, or 16 Remote Wake-up Packet Filters are selected) of the Remote Wake-up Packet Filter register pointer. When the value of this pointer is equal to maximum for the selected number of Remote Wake-up Packet Filters, the contents of the Remote Wake-up Packet Filter Register are transferred to the clk_rx_i domain when a Write occurs to that register.</p>                                              |
| 23:11 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10  | RW   | 0x0         | <p>RWKPE<br/>Remote Wake-up Packet Forwarding Enable<br/>When this bit is set along with RWKPKTEN, the MAC receiver drops all received frames until it receives the expected Wake-up frame. All frames after that event including the received wake-up frame are forwarded to application. This bit is then self-cleared on receiving the wake-up packet. The application can also clear this bit before the expected wake-up frame is received. In such cases, the MAC reverts to the default behavior where packets received are forwarded to the application. This bit must only be set when RWKPKTEN is set high and PWRDWN is set low. The setting of this bit has no effect when PWRDWN is set high.</p> <p>Note: If Magic Packet Enable and Wake-Up Frame Enable are both set along with setting of this bit and Magic Packet is received prior to wake-up frame, this bit is self-cleared on receiving Magic Packet, the received Magic packet is dropped, and all frames after received Magic Packet are forwarded to application.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:<br/>1'b0: Remote Wake-up Packet Forwarding is disabled<br/>1'b1: Remote Wake-up Packet Forwarding is enabled</p> |
| 9   | RW   | 0x0         | <p>GLBLUCAST<br/>Global Unicast<br/>When this bit set, any unicast packet filtered by the MAC (DAF) address recognition is detected as a remote wake-up packet.</p> <p>Values:<br/>1'b0: Global unicast is disabled<br/>1'b1: Global unicast is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8:7 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6   | RO   | 0x0         | <p>RWKPRCVD<br/>Remote Wake-Up Packet Received<br/>When this bit is set, it indicates that the power management event is generated because of the reception of a remote wake-up packet. This bit is cleared when this register is read.</p> <p>Access restriction applies. Clears on read (or write of 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: Remote wake-up packet is received<br/>1'b1: Remote wake-up packet is received</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5   | RO   | 0x0         | <p>MGKPRCVD<br/>Magic Packet Received<br/>When this bit is set, it indicates that the power management event is generated because of the reception of a magic packet. This bit is cleared when this register is read.</p> <p>Access restriction applies. Clears on read (or write of 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: No Magic packet is received<br/>1'b1: Magic packet is received</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4:3 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | <p><b>RWKPKTEN</b><br/>Remote Wake-Up Packet Enable<br/>When this bit is set, a power management event is generated when the MAC receives a remote wake-up packet.<br/>Values:<br/>1'b0: Remote wake-up packet is disabled<br/>1'b1: Remote wake-up packet is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RW          | 0x0                | <p><b>MGKPKTEN</b><br/>Magic Packet Enable<br/>When this bit is set, a power management event is generated when the MAC receives a magic packet.<br/>Values:<br/>1'b0: Magic Packet is disabled<br/>1'b1: Magic Packet is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0          | RW          | 0x0                | <p><b>PWRDWN</b><br/>Power Down<br/>When this bit is set, the MAC receiver drops all received packets until it receives the expected magic packet or remote wake-up packet. This bit is then self-cleared and the power-down mode is disabled. The software can clear this bit before the expected magic packet or remote wake-up packet is received. The packets received by the MAC after this bit is cleared are forwarded to the application. This bit must only be set when the Magic Packet Enable, Global Unicast, or Remote Wake-Up Packet Enable bit is set high.<br/>Note: You can gate-off the CSR clock during the power-down mode. However, when the CSR clock is gated-off, you cannot perform any read or write operations on this register. Therefore, the Software cannot clear this bit. Access restriction applies.<br/>Setting 1 sets. Self-cleared. Setting 0 has no effect.<br/>Values:<br/>1'b0: Power down is disabled<br/>1'b1: Power down is enabled</p> |

**GMAC MAC RWK Packet Filter**

Address: Operational Base + offset (0x00C4)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>WKUPFRMFTR(cont.)</p> <p>(4) If filters chained by And_Prev bit setting have complementary programming, then a frame may never pass the AND chained filter. For example, if Filter 2 And_Prev bit is set (bit 1 in Filter 2 command is set), Filter 1 Address_Type bit is set (bit 3 in Filter 1 command is set) indicating multicast detection and Filter 2 Address_Type bit is reset (bit 3 in Filter 2 command is reset) indicating unicast detection or vice versa, a remote wakeup frame does not pass the AND chained filter as a remote wakeup frame cannot be of both unicast and multicast address type.</p> <p>4. Bit 0 is the enable for filter i. If Bit 0 is not set, filter i is disabled.</p> <p>Filter i Byte Mask: The filter i byte mask register defines the bytes of the packet that are examined by filter i (0, 1, 2, 3, .., 15) to determine whether or not a packet is a wake-up packet.</p> <ol style="list-style-type: none"> <li>1. The MSB (31st bit) must be zero.</li> <li>2. Bit j[30:0] is the byte mask.</li> <li>3. If Bit j (byte number) of the byte mask is set, the CRC block processes the Filter i Offset + j of the incoming packet; otherwise Filter i Offset + j is ignored.</li> </ol> <p>Filter i Offset: The filter i offset register defines the offset (within the packet) from which the filter i examines the packets.</p> <ol style="list-style-type: none"> <li>1. This 8-bit pattern-offset is the offset for the filter i first byte to be examined.</li> <li>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.</li> <li>3. The offset value 0 refers to the first byte of the packet.</li> </ol> <p>Filter i CRC-16: The filter i CRC-16 register contains the CRC-16 value calculated from the pattern and the byte mask programmed in the Remote Wakeup filter register.</p> <ol style="list-style-type: none"> <li>1. The 16-bit CRC calculation uses the following polynomial: <math>G(x) = x^{16} + x^{15} + x^2 + 1</math></li> <li>2. Each mask, used in the hash function calculation, is compared with a 16-bit value associated with that mask. Each filter has the following: <ul style="list-style-type: none"> <li>(1) 32-bit Mask: Each bit in this mask corresponds to one byte in the detected packet. If the bit is 1, the corresponding byte is taken into the CRC16 calculation.</li> <li>(2) 8-bit Offset Pointer: Specifies the byte to start the CRC-16 computation. The pointer and the mask are used together to locate the bytes to be used in the CRC-16 calculations.</li> </ul> </li> </ol> |

**GMAC RWK Filter0 Byte Mask**

Address: Operational Base + offset (0x10C0)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                   |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>Filter0_Byte_Mask</p> <p>Filter0 32-bit Mask</p> <p>Each bit in this mask corresponds to one byte in the detected packet. If the bit is 1, the corresponding byte is taken into the CRC16 calculation.</p> |

**GMAC RWK Filter1 Byte Mask**

Address: Operational Base + offset (0x10C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | Filter1[Byte_Mask]<br>Filter1 32-bit Mask<br>Each bit in this mask corresponds to one byte in the detected packet. If the bit is 1', the corresponding byte is taken into the CRC16 calculation. |

**GMAC RWK Filter2 Byte Mask**

Address: Operational Base + offset (0x10C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | Filter2[Byte_Mask]<br>Filter2 32-bit Mask<br>Each bit in this mask corresponds to one byte in the detected packet. If the bit is 1', the corresponding byte is taken into the CRC16 calculation. |

**GMAC RWK Filter3 Byte Mask**

Address: Operational Base + offset (0x10CC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | Filter3[Byte_Mask]<br>Filter3 32-bit Mask<br>Each bit in this mask corresponds to one byte in the detected packet. If the bit is 1', the corresponding byte is taken into the CRC16 calculation. |

**GMAC RWK Filter01 CRC**

Address: Operational Base + offset (0x10D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | Filter1[CRC]<br>Filter1 CRC-16<br>This filter CRC-16 contains the CRC_16 value of the pattern.<br>The 16-bit CRC calculation uses the following polynomial:<br>$G(x) = x^{16} + x^{15} + x^2 + 1$ |
| 15:0       | RW          | 0x0000             | Filter0[CRC]<br>Filter0 CRC-16<br>This filter CRC-16 contains the CRC_16 value of the pattern.<br>The 16-bit CRC calculation uses the following polynomial:<br>$G(x) = x^{16} + x^{15} + x^2 + 1$ |

**GMAC RWK Filter23 CRC**

Address: Operational Base + offset (0x10D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | Filter3[CRC]<br>Filter3 CRC-16<br>This filter CRC-16 contains the CRC_16 value of the pattern.<br>The 16-bit CRC calculation uses the following polynomial:<br>$G(x) = x^{16} + x^{15} + x^2 + 1$ |
| 15:0       | RW          | 0x0000             | Filter2[CRC]<br>Filter2 CRC-16<br>This filter CRC-16 contains the CRC_16 value of the pattern.<br>The 16-bit CRC calculation uses the following polynomial:<br>$G(x) = x^{16} + x^{15} + x^2 + 1$ |

**GMAC RWK Filter Offset**

Address: Operational Base + offset (0x10D8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | <p>Filter3_Offset<br/>Filter3 Offset</p> <p>This filter offset defines the offset (within the packet) from which the filter examines the packets.</p> <ol style="list-style-type: none"> <li>1. This 8-bit pattern-offset is the offset for the filter first byte to be examined.</li> <li>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.</li> <li>3. The offset value 0 refers to the first byte of the packet.</li> </ol> |
| 23:16      | RW          | 0x00               | <p>Filter2_Offset<br/>Filter2 Offset</p> <p>This filter offset defines the offset (within the packet) from which the filter examines the packets.</p> <ol style="list-style-type: none"> <li>1. This 8-bit pattern-offset is the offset for the filter first byte to be examined.</li> <li>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.</li> <li>3. The offset value 0 refers to the first byte of the packet.</li> </ol> |
| 15:8       | RW          | 0x00               | <p>Filter1_Offset<br/>Filter1 Offset</p> <p>This filter offset defines the offset (within the packet) from which the filter examines the packets.</p> <ol style="list-style-type: none"> <li>1. This 8-bit pattern-offset is the offset for the filter first byte to be examined.</li> <li>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.</li> <li>3. The offset value 0 refers to the first byte of the packet.</li> </ol> |
| 7:0        | RW          | 0x00               | <p>Filter0_Offset<br/>Filter0 Offset</p> <p>This filter offset defines the offset (within the packet) from which the filter examines the packets.</p> <ol style="list-style-type: none"> <li>1. This 8-bit pattern-offset is the offset for the filter first byte to be examined.</li> <li>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.</li> <li>3. The offset value 0 refers to the first byte of the packet.</li> </ol> |

**GMAC RWK Filter Command**

Address: Operational Base + offset (0x10DC)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:16      | RW          | 0x0                | <p>Filter2_Command<br/>Filter2 Command</p> <p>The 4-bit filter command controls the filter operation.</p> <ol style="list-style-type: none"> <li>1. Bit 3 specifies the address type, defining the destination address type of the pattern. When the bit is set, the pattern applies to only multicast packets; when the bit is reset, the pattern applies only to unicast packet.</li> <li>2. Bit 2 (Inverse Mode), when set, reverses the logic of the CRC16 hash function signal, to reject a packet with matching CRC_16 value.</li> <li>3. Bit 2, along with Bit 1, allows a MAC to reject a subset of remote wake-up packets by creating filter logic such as "Pattern 1 AND NOT Pattern 2".</li> <li>4. Bit 1 (And_Previous) implements the Boolean logic. When set, the result of the current entry is logically ANDed with the result of the previous filter. This AND logic allows a filter pattern longer than 32 bytes by splitting the mask among two, three, or four filters. This depends on the number of filters that have the And_Previous bit set.</li> <li>5. Bit 0 is the enable for filter. If Bit 0 is not set, filter is disabled.</li> </ol> |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11:8       | RW          | 0x0                | <p>Filter1_Command<br/>Filter1 Command</p> <p>The 4-bit filter command controls the filter operation.</p> <ol style="list-style-type: none"> <li>1. Bit 3 specifies the address type, defining the destination address type of the pattern. When the bit is set, the pattern applies to only multicast packets; when the bit is reset, the pattern applies only to unicast packet.</li> <li>2. Bit 2 (Inverse Mode), when set, reverses the logic of the CRC16 hash function signal, to reject a packet with matching CRC_16 value.</li> <li>3. Bit 2, along with Bit 1, allows a MAC to reject a subset of remote wake-up packets by creating filter logic such as "Pattern 1 AND NOT Pattern 2".</li> <li>4. Bit 1 (And_Previous) implements the Boolean logic. When set, the result of the current entry is logically ANDed with the result of the previous filter. This AND logic allows a filter pattern longer than 32 bytes by splitting the mask among two, three, or four filters. This depends on the number of filters that have the And_Previous bit set.</li> <li>5. Bit 0 is the enable for filter. If Bit 0 is not set, filter is disabled.</li> </ol> |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | RW   | 0x0         | <p>Filter0_Command<br/>Filter0 Command<br/>The 4-bit filter command controls the filter operation.</p> <p>1. Bit 3 specifies the address type, defining the destination address type of the pattern. When the bit is set, the pattern applies to only multicast packets; when the bit is reset, the pattern applies only to unicast packet.</p> <p>2. Bit 2 (Inverse Mode), when set, reverses the logic of the CRC16 hash function signal, to reject a packet with matching CRC_16 value.</p> <p>3. Bit 2, along with Bit 1, allows a MAC to reject a subset of remote wake-up packets by creating filter logic such as "Pattern 1 AND NOT Pattern 2".</p> <p>4. Bit 1 (And_Previous) implements the Boolean logic. When set, the result of the current entry is logically ANDed with the result of the previous filter. This AND logic allows a filter pattern longer than 32 bytes by splitting the mask among two, three, or four filters. This depends on the number of filters that have the And_Previous bit set.</p> <p>5. Bit 0 is the enable for filter. If Bit 0 is not set, filter is disabled.</p> |

**GMAC MAC Version**

Address: Operational Base + offset (0x0110)

| Bit   | Attr | Reset Value | Description                       |
|-------|------|-------------|-----------------------------------|
| 31:16 | RO   | 0x0000      | reserved                          |
| 15:8  | RW   | 0x1e        | USERVER<br>User-defined Version   |
| 7:0   | RW   | 0x51        | RKVER<br>Rockchip-defined Version |

**GMAC MAC Debug**

Address: Operational Base + offset (0x0114)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 18:17 | RO   | 0x0         | <p>TFCSTS<br/>MAC Transmit Packet Controller Status<br/>This field indicates the state of the MAC Transmit Packet Controller module.<br/>Values:<br/>2'b00: Idle state<br/>2'b01: Waiting for one of the following: Status of the previous packet OR IPG or back off period to be over<br/>2'b10: Generating and transmitting a Pause control packet (in full-duplex mode)<br/>2'b11: Transferring input packet for transmission</p> |
| 16    | RO   | 0x0         | <p>TPESTS<br/>MAC GMII or MII Transmit Protocol Engine Status<br/>When this bit is set, it indicates that the MAC GMII or MII transmit protocol engine is actively transmitting data, and it is not in the Idle state.<br/>Values:<br/>1'b0: MAC GMII or MII Transmit Protocol Engine Status not detected<br/>1'b1: MAC GMII or MII Transmit Protocol Engine Status detected</p>                                                     |
| 15:3  | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                    |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:1 | RO   | 0x0         | RFCFCSTS<br>MAC Receive Packet Controller FIFO Status<br>When this bit is set, this field indicates the active state of the small FIFO Read and Write controllers of the MAC Receive Packet Controller module. |
| 0   | RO   | 0x0         | reserved                                                                                                                                                                                                       |

**GMAC MAC HW Feature0**

Address: Operational Base + offset (0x011C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x4         | ACTPHYSEL<br>Active PHY Selected<br>When you have multiple PHY interfaces in your configuration, this field indicates the sampled value of phy_intf_sel_i during reset de-assertion.<br>Values:<br>4'b0000: GMII or MII<br>4'b0001: RGMII<br>4'b0010: SGMII<br>4'b0011: TBI<br>4'b0100: RMII<br>4'b0101: RTBI<br>4'b0110: SMII<br>4'b0111: RevMII |
| 27    | RO   | 0x0         | SAVLANINS<br>Source Address or VLAN Insertion Enable<br>This bit is set to 1 when the Enable SA and VLAN Insertion on Tx option is selected.<br>Values:<br>1'b0: Source Address or VLAN Insertion Enable option is not selected<br>1'b1: Source Address or VLAN Insertion Enable option is selected                                               |
| 26:25 | RO   | 0x0         | TSSTSSEL<br>Timestamp System Time Source<br>This bit indicates the source of the Timestamp system time:<br>This bit is set to 1 when the Enable IEEE 1588 Timestamp Support option is selected.<br>Values:<br>2'b00: Internal<br>2'b01: External<br>2'b10: Both<br>2'b11: Reserved                                                                |
| 24    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                          |
| 23    | RO   | 0x0         | MACADR32SEL<br>MAC Addresses 32-63 Selected<br>This bit is set to 1 when the Enable Additional 32 MAC Address Registers (32-63) option is selected.<br>Values:<br>1'b0: MAC Addresses 32-63 Select option is not selected<br>1'b1: MAC Addresses 32-63 Select option is selected                                                                  |
| 22:18 | RO   | 0x00        | ADDMACADRSEL<br>MAC Addresses 1-31 Selected<br>This bit is set to 1 when the non-zero value is selected for Enable Additional 1-31 MAC Address Registers option.                                                                                                                                                                                  |
| 17    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RO          | 0x1                | <p><b>RXCOESEL</b><br/>           Receive Checksum Offload Enabled<br/>           This bit is set to 1 when the Enable Receive TCP/IP Checksum Check option is selected.<br/>           Values:<br/>           1'b0: Receive Checksum Offload Enable option is not selected<br/>           1'b1: Receive Checksum Offload Enable option is selected</p>    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                   |
| 13         | RO          | 0x0                | <p><b>EEESEL</b><br/>           Energy Efficient Ethernet Enabled<br/>           This bit is set to 1 when the Enable Energy Efficient Ethernet (EEE) option is selected.<br/>           Values:<br/>           1'b0: Energy Efficient Ethernet Enable option is not selected<br/>           1'b1: Energy Efficient Ethernet Enable option is selected</p> |
| 12         | RO          | 0x0                | <p><b>TSSEL</b><br/>           IEEE 1588-2008 Timestamp Enabled<br/>           This bit is set to 1 when the Enable IEEE 1588 Timestamp Support option is selected.<br/>           Values:<br/>           1'b0: IEEE 1588-2008 Timestamp Enable option is not selected.<br/>           1'b1: IEEE 1588-2008 Timestamp Enable option is selected.</p>       |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                   |
| 9          | RO          | 0x1                | <p><b>ARPOFFSEL</b><br/>           ARP Offload Enabled<br/>           This bit is set to 1 when the Enable IPv4 ARP Offload option is selected.<br/>           Values:<br/>           1'b0: ARP Offload Enable option is not selected<br/>           1'b1: ARP Offload Enable option is selected</p>                                                       |
| 8          | RO          | 0x1                | <p><b>MMCSEL</b><br/>           RMON Module Enable<br/>           This bit is set to 1 when the Enable MAC Management Counters (MMC) option is selected.<br/>           Values:<br/>           1'b0: RMON Module Enable option is not selected<br/>           1'b1: RMON Module Enable option is selected</p>                                              |
| 7          | RO          | 0x1                | <p><b>MGKSEL</b><br/>           PMT Magic Packet Enable<br/>           This bit is set to 1 when the Enable Magic Packet Detection option is selected.<br/>           Values:<br/>           1'b0: PMT Magic Packet Enable option is not selected<br/>           1'b1: PMT Magic Packet Enable option is selected</p>                                      |
| 6          | RO          | 0x1                | <p><b>RWKSEL</b><br/>           PMT Remote Wake-up Packet Enable<br/>           This bit is set to 1 when the Enable Remote Wake-Up Packet Detection option is selected.<br/>           Values:<br/>           1'b0: PMT Remote Wake-up Packet Enable option is not selected<br/>           1'b1: PMT Remote Wake-up Packet Enable option is selected</p>  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RO          | 0x1                | <p>SMASEL<br/>SMA (MDIO) Interface<br/>This bit is set to 1 when the Enable Station Management (MDIO Interface) option is selected.<br/>Values:<br/>1'b0: SMA (MDIO) Interface not selected<br/>1'b1: SMA (MDIO) Interface selected</p>                                                           |
| 4          | RO          | 0x0                | <p>VLHASH<br/>VLAN Hash Filter Selected<br/>This bit is set to 1 when the Enable VLAN Hash Table Based Filtering option is selected.<br/>Values:<br/>1'b0: VLAN Hash Filter not selected<br/>1'b1: VLAN Hash Filter selected</p>                                                                  |
| 3          | RO          | 0x0                | <p>PCSEL<br/>PCS Registers (TBI, SGMII, or RTBI PHY interface)<br/>This bit is set to 1 when the TBI, SGMII, or RTBI PHY interface option is selected.<br/>Values:<br/>1'b0: No PCS Registers (TBI, SGMII, or RTBI PHY interface)<br/>1'b1: PCS Registers (TBI, SGMII, or RTBI PHY interface)</p> |
| 2          | RO          | 0x0                | <p>HDSEL<br/>Half-duplex Support<br/>This bit is set to 1 when the half-duplex mode is selected.<br/>Values:<br/>1'b0: No Half-duplex support<br/>1'b1: Half-duplex support</p>                                                                                                                   |
| 1          | RO          | 0x0                | <p>GMIISEL<br/>1000 Mbps Support<br/>This bit is set to 1 when 1000 Mbps is selected as the Mode of Operation.<br/>Values:<br/>1'b0: No 1000 Mbps support<br/>1'b1: 1000 Mbps support</p>                                                                                                         |
| 0          | RO          | 0x1                | <p>MIISEL<br/>10 or 100 Mbps Support<br/>This bit is set to 1 when 10/100 Mbps is selected as the Mode of Operation.<br/>Values:<br/>1'b0: No 10 or 100 Mbps support<br/>1'b1: 10 or 100 Mbps support</p>                                                                                         |

**GMAC MAC HW Feature1**

Address: Operational Base + offset (0x0120)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:27      | RO          | 0x0                | <p>L3L4FNUM<br/>           Total number of L3 or L4 Filters<br/>           This field indicates the total number of L3 or L4 filters:<br/>           Values:<br/>           4'b0000: No L3 or L4 Filter<br/>           4'b0001: 1 L3 or L4 Filter<br/>           4'b0010: 2 L3 or L4 Filters<br/>           4'b0011: 3 L3 or L4 Filters<br/>           4'b0100: 4 L3 or L4 Filters<br/>           4'b0101: 5 L3 or L4 Filters<br/>           4'b0110: 6 L3 or L4 Filters<br/>           4'b0111: 7 L3 or L4 Filters<br/>           4'b1000: 8 L3 or L4 Filters</p> |
| 26         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 25:24      | RO          | 0x1                | <p>HASHTBLSZ<br/>           Hash Table Size<br/>           This field indicates the size of the hash table:<br/>           Values:<br/>           2'b00: No hash table<br/>           2'b01: 64<br/>           2'b10: 128<br/>           2'b11: 256</p>                                                                                                                                                                                                                                                                                                            |
| 23         | RO          | 0x0                | <p>POUOST<br/>           One Step for PTP over UDP/IP Feature Enable<br/>           This bit is set to 1 when the Enable One step timestamp for PTP over UDP/IP feature is selected.<br/>           Values:<br/>           1'b0: One Step for PTP over UDP/IP Feature is not selected<br/>           1'b1: One Step for PTP over UDP/IP Feature is selected</p>                                                                                                                                                                                                    |
| 22         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 21         | RO          | 0x0                | <p>RAVSEL<br/>           Rx Side Only AV Feature Enable<br/>           This bit is set to 1 when the Enable Audio Video Bridging option on Rx Side Only is selected.<br/>           Values:<br/>           1'b0: Rx Side Only AV Feature is not selected<br/>           1'b1: Rx Side Only AV Feature is selected</p>                                                                                                                                                                                                                                              |
| 20         | RO          | 0x0                | <p>AVSEL<br/>           AV Feature Enable<br/>           This bit is set to 1 when the Enable Audio Video Bridging option is selected.<br/>           Values:<br/>           1'b0: AV Feature is not selected<br/>           1'b1: AV Feature is selected</p>                                                                                                                                                                                                                                                                                                      |
| 19         | RO          | 0x1                | <p>DBGMEMA<br/>           DMA Debug Registers Enable<br/>           This bit is set to 1 when the Debug Mode Enable option is selected.<br/>           Values:<br/>           1'b0: DMA Debug Registers option is not selected<br/>           1'b1: DMA Debug Registers option is selected</p>                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RO          | 0x1                | <p>TSOEN<br/>TCP Segmentation Offload Enable<br/>This bit is set to 1 when the Enable TCP Segmentation Offloading for TCP/IP Packets option is selected.<br/>Values:<br/>1'b0: TCP Segmentation Offload Feature is not selected<br/>1'b1: TCP Segmentation Offload Feature is selected</p> |
| 17         | RO          | 0x1                | <p>SPHEN<br/>Split Header Feature Enable<br/>This bit is set to 1 when the Enable Split Header Structure option is selected.<br/>Values:<br/>1'b0: Split Header Feature is not selected<br/>1'b1: Split Header Feature is selected</p>                                                     |
| 16         | RO          | 0x0                | <p>DCBEN<br/>DCB Feature Enable<br/>This bit is set to 1 when the Enable Data Center Bridging option is selected.<br/>Values:<br/>1'b0: DCB Feature is not selected<br/>1'b1: DCB Feature is selected</p>                                                                                  |
| 15:14      | RO          | 0x1                | <p>ADDR64<br/>Address Width<br/>This field indicates the configured address width:<br/>Values:<br/>2'b00: 32<br/>2'b01: 40<br/>2'b10: 48<br/>2'b11: Reserved</p>                                                                                                                           |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                   |
| 12         | RO          | 0x0                | <p>PTOEN<br/>PTP Offload Enable<br/>This bit is set to 1 when the Enable PTP Timestamp Offload Feature is selected.<br/>Values:<br/>1'b0: PTP Offload feature is not selected<br/>1'b1: PTP Offload feature is selected</p>                                                                |
| 11         | RO          | 0x0                | <p>OSTEN<br/>One-Step Timestamping Enable<br/>This bit is set to 1 when the Enable One-Step Timestamp Feature is selected.<br/>Values:<br/>1'b0: One-Step Timestamping feature is not selected<br/>1'b1: One-Step Timestamping feature is selected</p>                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:6       | RO          | 0x05               | <p><b>TXFIFOSIZE</b><br/>           MTL Transmit FIFO Size<br/>           This field contains the configured value of MTL Tx FIFO in bytes expressed as Log to base 2 minus 7, that is, <math>\text{Log}_2(\text{TXFIFO\_SIZE}) - 7</math>:<br/>           Values:<br/>           0x0 (128B): 128 bytes<br/>           0x1 (256B): 256 bytes<br/>           0x2 (512B): 512 bytes<br/>           0x3 (1024B): 1024 bytes<br/>           0x4 (2048B): 2048 bytes<br/>           0x5 (4096B): 4096 bytes<br/>           0x6 (8192B): 8192 bytes<br/>           0x7 (16384B): 16384 bytes<br/>           0x8 (32KB): 32 KB<br/>           0x9 (64KB): 64 KB<br/>           0xa (128KB): 128 KB<br/>           0xb (RSVD): Reserved</p> |
| 5          | RO          | 0x1                | <p><b>SPRAM</b><br/>           Single Port RAM Enable<br/>           This bit is set to 1 when the Use single port RAM Feature is selected.<br/>           Values:<br/>           1'b0: Single Port RAM feature is not selected<br/>           1'b1: Single Port RAM feature is selected</p>                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4:0        | RO          | 0x06               | <p><b>RXFIFOSIZE</b><br/>           MTL Receive FIFO Size<br/>           This field contains the configured value of MTL Rx FIFO in bytes expressed as Log to base 2 minus 7, that is, <math>\text{Log}_2(\text{RXFIFO\_SIZE}) - 7</math>:<br/>           Values:<br/>           5'b00000: 128 bytes<br/>           5'b00001: 256 bytes<br/>           5'b00010: 512 bytes<br/>           5'b00011: 1024 bytes<br/>           5'b00100: 2048 bytes<br/>           5'b00101: 4096 bytes<br/>           5'b00110: 8192 bytes<br/>           5'b00111: 16384 bytes<br/>           5'b01000: 32 KB<br/>           5'b01001: 64 KB<br/>           5'b01010: 128 KB<br/>           5'b01011: 256 KB<br/>           5'b01100: Reserved</p> |

**GMAC MAC HW Feature2**

Address: Operational Base + offset (0x0124)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:28      | RO          | 0x1                | AUXSNAPNUM<br>Number of Auxiliary Snapshot Inputs<br>This field indicates the number of auxiliary snapshot inputs:<br>Values:<br>3'b000: No auxiliary input<br>3'b001: 1 auxiliary input<br>3'b010: 2 auxiliary input<br>3'b011: 3 auxiliary input<br>3'b100: 4 auxiliary input<br>3'b101: Reserved                                                               |
| 27         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 26:24      | RO          | 0x0                | PPSOUTNUM<br>Number of PPS Outputs<br>This field indicates the number of PPS outputs:<br>Values:<br>3'b000: No PPS output<br>3'b001: 1 PPS output<br>3'b010: 2 PPS output<br>3'b011: 3 PPS output<br>3'b100: 4 PPS output<br>3'b101: Reserved                                                                                                                     |
| 23:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 21:18      | RO          | 0x0                | TXCHCNT<br>Number of DMA Transmit Channels<br>This field indicates the number of DMA Transmit channels:<br>Values:<br>4'b0000: 1 MTL Tx Channel<br>4'b0001: 2 MTL Tx Channels<br>4'b0010: 3 MTL Tx Channels<br>4'b0011: 4 MTL Tx Channels<br>4'b0100: 5 MTL Tx Channels<br>4'b0101: 6 MTL Tx Channels<br>4'b0110: 7 MTL Tx Channels<br>4'b0111: 8 MTL Tx Channels |
| 17:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                          |
| 15:12      | RO          | 0x0                | RXCHCNT<br>Number of DMA Receive Channels<br>This field indicates the number of DMA Receive channels:<br>Values:<br>4'b0000: 1 MTL Rx Channel<br>4'b0001: 2 MTL Rx Channels<br>4'b0010: 3 MTL Rx Channels<br>4'b0011: 4 MTL Rx Channels<br>4'b0100: 5 MTL Rx Channels<br>4'b0101: 6 MTL Rx Channels<br>4'b0110: 7 MTL Rx Channels<br>4'b0111: 8 MTL Rx Channels   |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:6        | RO          | 0x0                | <p>TXQCNT<br/>Number of MTL Transmit Queues<br/>This field indicates the number of MTL Transmit queues:<br/>Values:<br/>4'b0000: 1 MTL Tx Queue<br/>4'b0001: 2 MTL Tx Queues<br/>4'b0010: 3 MTL Tx Queues<br/>4'b0011: 4 MTL Tx Queues<br/>4'b0100: 5 MTL Tx Queues<br/>4'b0101: 6 MTL Tx Queues<br/>4'b0110: 7 MTL Tx Queues<br/>4'b0111: 8 MTL Tx Queues</p> |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                       |
| 3:0        | RO          | 0x0                | <p>RXQCNT<br/>Number of MTL Receive Queues<br/>This field indicates the number of MTL Receive queues:<br/>Values:<br/>4'b0000: 1 MTL Rx Queue<br/>4'b0001: 2 MTL Rx Queues<br/>4'b0010: 3 MTL Rx Queues<br/>4'b0011: 4 MTL Rx Queues<br/>4'b0100: 5 MTL Rx Queues<br/>4'b0101: 6 MTL Rx Queues<br/>4'b0110: 7 MTL Rx Queues<br/>4'b0111: 8 MTL Rx Queues</p>   |

**GMAC MAC HW Feature3**

Address: Operational Base + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 29:28      | RO          | 0x0                | <p>ASP<br/>Automotive Safety Package<br/>Following are the encoding for the different Safety features.<br/>Values:<br/>2'b00: No Safety features selected<br/>2'b01: Only "ECC protection for external memory" feature is selected<br/>2'b10: All the Automotive Safety features are selected without the "Parity Port Enable for external interface" feature<br/>2'b11: All the Automotive Safety features are selected with the "Parity Port Enable for external interface" feature</p> |
| 27         | RO          | 0x0                | <p>TBSSEL<br/>Time Based Scheduling Enable<br/>This bit is set to 1 when the Time Based Scheduling feature is selected.<br/>Values:<br/>1'b0: Time Based Scheduling Enable feature is not selected<br/>1'b1: Time Based Scheduling Enable feature is selected</p>                                                                                                                                                                                                                         |
| 26         | RO          | 0x0                | <p>FPESEL<br/>Frame Preemption Enable<br/>This bit is set to 1 when the Enable Frame preemption feature is selected.<br/>Values:<br/>1'b0: Frame Preemption Enable feature is not selected<br/>1'b1: Frame Preemption Enable feature is selected</p>                                                                                                                                                                                                                                      |
| 25:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:20      | RO          | 0x0                | <p><b>ESTWID</b><br/> Width of the Time Interval field in the Gate Control List<br/> This field indicates the width of the Configured Time Interval Field.<br/> Values:<br/> 2'b00: Width not configured<br/> 2'b01: 16<br/> 2'b10: 20<br/> 2'b11: 24</p>                                                                                |
| 19:17      | RW          | 0x0                | <p><b>ESTDEP</b><br/> Depth of the Gate Control List<br/> This field indicates the depth of Gate Control list expressed as Log2(DWC_EQOS_EST_DEP)-5.<br/> Values:<br/> 3'b000: No Depth configured<br/> 3'b001: 64<br/> 3'b010: 128<br/> 3'b011: 256<br/> 3'b100: 512<br/> 3'b101: 1024<br/> 3'b110: Reserved</p>                        |
| 16         | RO          | 0x0                | <p><b>ESTSEL</b><br/> Enhancements to Scheduling Traffic Enable<br/> This bit is set to 1 when the Enable Enhancements to Scheduling Traffic feature is selected.<br/> Values:<br/> 1'b0: Enable Enhancements to Scheduling Traffic feature is not selected<br/> 1'b1: Enable Enhancements to Scheduling Traffic feature is selected</p> |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                 |
| 14:13      | RO          | 0x0                | <p><b>FRPES</b><br/> Flexible Receive Parser Table Entries size<br/> This field indicates the Max Number of Parser Entries supported by Flexible Receive Parser.<br/> Values:<br/> 2'b00: 64 Entries<br/> 2'b01: 128 Entries<br/> 2'b10: 256 Entries<br/> 2'b11: Reserved</p>                                                            |
| 12:11      | RO          | 0x0                | <p><b>FRPBS</b><br/> Flexible Receive Parser Buffer size<br/> This field indicates the supported Max Number of bytes of the packet data to be Parsed by Flexible Receive Parser.<br/> Values:<br/> 2'b00: 64 Bytes<br/> 2'b01: 128 Bytes<br/> 2'b10: 256 Bytes<br/> 2'b11: Reserved</p>                                                  |
| 10:6       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RO          | 0x0                | DVLAN<br>Double VLAN Tag Processing Selected<br>This bit is set to 1 when the Enable Double VLAN Processing Feature is selected.<br>Values:<br>1'b0: Double VLAN option is not selected<br>1'b1: Double VLAN option is selected                                                                                                                                                                      |
| 4          | RO          | 0x0                | CBTISEL<br>Queue/Channel based VLAN tag insertion on Tx Enable<br>This bit is set to 1 when the Enable Queue/Channel based VLAN tag insertion on Tx Feature is selected.<br>Values:<br>1'b0: Enable Queue/Channel based VLAN tag insertion on Tx feature is not selected<br>1'b1: Enable Queue/Channel based VLAN tag insertion on Tx feature is selected                                            |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                             |
| 2:0        | RO          | 0x0                | NRVF<br>Number of Extended VLAN Tag Filters Enabled<br>This field indicates the Number of Extended VLAN Tag Filters selected:<br>Values:<br>3'b000: No Extended Rx VLAN Filters<br>3'b001: 4 Extended Rx VLAN Filters<br>3'b010: 8 Extended Rx VLAN Filters<br>3'b011: 16 Extended Rx VLAN Filters<br>3'b100: 24 Extended Rx VLAN Filters<br>3'b101: 32 Extended Rx VLAN Filters<br>3'b110: Reserved |

**GMAC\_MAC\_MDIO\_Address**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                |
| 27         | RW          | 0x0                | PSE<br>Preamble Suppression Enable<br>When this bit is set, the SMA suppresses the 32-bit preamble and transmits MDIO frames with only 1 preamble bit. When this bit is 0, the MDIO frame always has 32 bits of preamble as defined in the IEEE specifications.<br>Values:<br>1'b0: Preamble Suppression disabled<br>1'b1: Preamble Suppression enabled |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26         | RW          | 0x0                | <p>BTB<br/>Back to Back transactions<br/>When this bit is set and the NTC has value greater than 0, then the MAC informs the completion of a read or write command at the end of frame transfer (before the trailing clocks are transmitted). The software can thus initiate the next command which is executed immediately irrespective of the number trailing clocks generated for the previous frame. When this bit is reset, then the read/write command completion (GB is cleared) only after the trailing clocks are generated. In this mode, it is ensured that the NTC is always generated after each frame. This bit must not be set when NTC=0.</p> <p>Values:<br/>1'b0: Back to Back transactions disabled<br/>1'b1: Back to Back transactions enabled</p> |
| 25:21      | RW          | 0x00               | <p>PA<br/>Physical Layer Address<br/>This field indicates which Clause 22 PHY devices (out of 32 devices) the MAC is accessing. For RevMII, this field gives the PHY Address of the RevMII module. This field indicates which Clause 45 capable PHYs (out of 32 PHYs) the MAC is accessing.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 20:16      | RW          | 0x00               | <p>RDA<br/>Register/Device Address<br/>These bits select the PHY register in selected Clause 22 PHY device. For RevMII, these bits select the CSR register in the RevMII Registers set. These bits select the Device (MMD) in selected Clause 45 capable PHY.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14:12      | RW          | 0x0                | <p>NTC<br/>Number of Trailing Clocks<br/>This field controls the number of trailing clock cycles generated on gmii_mdc_o (MDC) after the end of transmission of MDIO frame. The valid values can be from 0 to 7. Programming the value to 3'h3 indicates that there are additional three clock cycles on the MDC line after the end of MDIO frame transfer.</p>                                                                                                                                                                                                                                                                                                                                                                                                       |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8 | RW   | 0x0         | <p>CR<br/>CSR Clock Range<br/>The CSR Clock Range selection determines the frequency of the MDC clock according to the CSR clock frequency used in your design:</p> <p>4'b0000: CSR clock = 60-100 MHz; MDC clock = CSR clock/42<br/>4'b0001: CSR clock = 100-150 MHz; MDC clock = CSR clock/62<br/>4'b0010: CSR clock = 20-35 MHz; MDC clock = CSR clock/16<br/>4'b0011: CSR clock = 35-60 MHz; MDC clock = CSR clock/26<br/>4'b0100: CSR clock = 150-250 MHz; MDC clock = CSR clock/102<br/>4'b0101: CSR clock = 250-300 MHz; MDC clock = CSR clock/124<br/>4'b0110: CSR clock = 300-500 MHz; MDC clock = CSR clock/204<br/>4'b0111: CSR clock = 500-800 MHz; MDC clock = CSR clock/324<br/>The suggested range of CSR clock frequency applicable for each value (when Bit 11 = 0) ensures that the MDC clock is approximately between 1.0 MHz to 2.5 MHz frequency range. When Bit 11 is set, you can achieve a higher frequency of the MDC clock than the frequency limit of 2.5 MHz (specified in the IEEE 802.3) and program a clock divider of lower value. For example, when CSR clock is of 100 MHz frequency and you program these bits as 1010, the resultant MDC clock is of 12.5 MHz which is above the range specified in IEEE 802.3. Program the following values only if the interfacing chips support faster MDC clocks:</p> <p>4'b1000: CSR clock/4<br/>4'b1001: CSR clock/6<br/>4'b1010: CSR clock/8<br/>4'b1011: CSR clock/10<br/>4'b1100: CSR clock/12<br/>4'b1101: CSR clock/14<br/>4'b1110: CSR clock/16<br/>4'b1111: CSR clock/18<br/>These bits are not used for accessing RevMII. These bits are read-only if the RevMII interface is selected as single PHY interface.</p> |
| 7:5  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4    | RW   | 0x0         | <p>SKAP<br/>Skip Address Packet<br/>When this bit is set, the SMA does not send the address packets before read, write, or post-read increment address packets. This bit is valid only when C45E is set.<br/>Values:<br/>1'b0: Skip Address Packet is disabled<br/>1'b1: Skip Address Packet is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | <p>GOC_1<br/>GMII Operation Command 1<br/>This bit is higher bit of the operation command to the PHY or RevMII, GOC_1 and GOC_0 is encoded as follows:<br/>2'b00: Reserved<br/>2'b01: Write<br/>2'b10: Post Read Increment Address for Clause 45 PHY<br/>2'b11: Read<br/>When Clause 22 PHY or RevMII is enabled, only Write and Read commands are valid.<br/>Values:<br/>1'b0: GMII Operation Command 1 is disabled<br/>1'b1: GMII Operation Command 1 is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2          | RW          | 0x0                | <p>GOC_0<br/>GMII Operation Command 0<br/>This is the lower bit of the operation command to the PHY or RevMII. When in SMA mode (MDIO master) this bit along with GOC_1 determines the operation to be performed to the PHY. When only RevMII is selected in configuration this bit is read-only and tied to 1.<br/>Values:<br/>1'b0: GMII Operation Command 0 is disabled<br/>1'b1: GMII Operation Command 0 is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1          | RW          | 0x0                | <p>C45E<br/>Clause 45 PHY Enable<br/>When this bit is set, Clause 45 capable PHY is connected to MDIO. When this bit is reset, Clause 22 capable PHY is connected to MDIO.<br/>Values:<br/>1'b0: Clause 45 PHY is disabled<br/>1'b1: Clause 45 PHY is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0          | RW          | 0x0                | <p>GB<br/>GMII Busy<br/>The application sets this bit to instruct the SMA to initiate a Read or Write access to the MDIO slave. The MAC clears this bit after the MDIO frame transfer is completed. Hence the software must not write or change any of the fields in MAC_MDIO_Address and MAC_MDIO_Data registers as long as this bit is set.<br/>For write transfers, the application must first write 16-bit data in the GDI field (and also RA field when C45E is set) in MAC_MDIO_Data register before setting this bit. When C45E is set, it should also write into the RA field of MAC_MDIO_Data register before initiating a read transfer. When a read transfer is completed (GB=0), the data read from the PHY register is valid in the GD field of the MAC_MDIO_Data register.<br/>Note: Even if the addressed PHY is not present, there is no change in the functionality of this bit. Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br/>Values:<br/>1'b0: GMII Busy is disabled<br/>1'b1: GMII Busy is enabled</p> |

**GMAC MAC MDIO Data**

Address: Operational Base + offset (0x0204)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | RA<br>Register Address<br>This field is valid only when C45E is set. It contains the Register Address in the PHY to which the MDIO frame is intended for.                                                                   |
| 15:0       | RW          | 0x0000             | GD<br>GMII Data<br>This field contains the 16-bit data value read from the PHY or RevMII after a Management Read operation or the 16-bit data value to be written to the PHY or RevMII before a Management Write operation. |

**GMAC MAC ARP Address**

Address: Operational Base + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ARPPA<br>ARP Protocol Address<br>This field contains the IPv4 Destination Address of the MAC.<br>This address is used for perfect match with the Protocol Address of Target field in the received ARP packet.<br>This field is available only when the Enable IPv4 ARP Offload option is selected. |

**GMAC MAC CSR SW Ctrl**

Address: Operational Base + offset (0x0230)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0          | RW          | 0x0                | RCWE<br>Register Clear on Write 1 Enable<br>When this bit is set, the access mode of some register fields changes to Clear on Write 1, the application needs to set that respective bit to 1 to clear it. When this bit is reset, the access mode of these register fields remain as Clear on Read.<br>Values:<br>1'b0: Register Clear on Write 1 is disabled<br>1'b1: Register Clear on Write 1 is enabled |

**GMAC MAC Ext Cfg1**

Address: Operational Base + offset (0x0238)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 9:8        | RW          | 0x0                | SPLM<br>Split Mode<br>These bits indicate the mode of splitting the incoming Rx packets. They are<br>Values:<br>0x0 (L3L4): Split at L3/L4 header<br>0x1 (L2OFST): Split at L2 header with an offset. Always Split at SPLOFST bytes from the beginning of Length/Type field of the Frame<br>0x2 (COMBN): Combination mode: Split similar to SPLM=00 for IP packets that are untagged or tagged and VLAN stripped<br>0x3 (RSVD): Reserved |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:0        | RW          | 0x02               | SPLOFST<br>Split Offset<br>These bits indicate the value of offset from the beginning of Length/Type field at which header split should take place when the appropriate SPLM is selected. The reset value of this field is 2 bytes indicating a split at L2 header. Value is in terms of bytes. |

**GMAC MAC Address0 High**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | AE<br>Address Enable<br>This bit is always set to 1.<br>Values:<br>1'b0: This bit must be always set to 1<br>1'b1: This bit is always set to 1                                                                                                         |
| 30:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                               |
| 15:0       | RW          | 0xfffff            | ADDRHI<br>MAC Address0[47:32]<br>This field contains the upper 16 bits [47:32] of the first 6-byte MAC address. The MAC uses this field for filtering the received packets and inserting the MAC address in the Transmit Flow Control (Pause) Packets. |

**GMAC MAC Address0 Low**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0xffffffff         | ADDRLO<br>MAC Address0[31:0]<br>This field contains the lower 32 bits of the first 6-byte MAC address. The MAC uses this field for filtering the received packets and inserting the MAC address in the Transmit Flow Control (Pause) Packets. |

**GMAC MMC Control**

Address: Operational Base + offset (0x0700)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8          | RW          | 0x0                | UCDBC<br>Update MMC Counters for Dropped Broadcast Packets<br>Note: The CNTRST bit has a higher priority than the CNTPRST bit. Therefore, when the software tries to set both bits in the same write cycle, all counters are cleared and the CNTPRST bit is not set.<br>When set, the MAC updates all related MMC Counters for Broadcast packets that are dropped because of the setting of the DBF bit of MAC_Packet_Filter register.<br>When reset, the MMC Counters are not updated for dropped Broadcast packets.<br>Values:<br>1'b0: Update MMC Counters for Dropped Broadcast Packets is disabled<br>1'b1: Update MMC Counters for Dropped Broadcast Packets is enabled |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0x0         | <p>CNTPRSTLVL<br/>Full-Half Preset</p> <p>When this bit is low and the CNTPRST bit is set, all MMC counters get preset to almost-half value. All octet counters get preset to 0x7FFF_F800 (Half 2KBytes) and all packet-counters gets preset to 0x7FFF_FFF0 (Half 16). When this bit is high and the CNTPRST bit is set, all MMC counters get preset to almost-full value. All octet counters get preset to 0xFFFF_F800 (Full 2KBytes) and all packet-counters gets preset to 0xFFFF_FFF0 (Full 16). For 16-bit counters, the almost-half preset values are 0x7800 and 0x7FF0 for the respective octet and packet counters. Similarly, the almost-full preset values for the 16-bit counters are 0xF800 and 0xFFF0.</p> <p>Values:</p> <p>1'b0: Full-Half Preset is disabled<br/>1'b1: Full-Half Preset is enabled</p> |
| 4   | RW   | 0x0         | <p>CNTPRST<br/>Counters Preset</p> <p>When this bit is set, all counters are initialized or preset to almost full or almost half according to the CNTPRSTLVL bit. This bit is cleared automatically after 1 clock cycle. This bit, along with the CNTPRSTLVL bit, is useful for debugging and testing the assertion of interrupts because of MMC counter becoming half-full or full. Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.</p> <p>Values:</p> <p>1'b0: Counters Preset is disabled<br/>1'b1: Counters Preset is enabled</p>                                                                                                                                                                                                                                                      |
| 3   | RW   | 0x0         | <p>CNTFREEZ<br/>MMC Counter Freeze</p> <p>When this bit is set, it freezes all MMC counters to their current value. Until this bit is reset to 0, no MMC counter is updated because of any transmitted or received packet. If any MMC counter is read with the Reset on Read bit set, then that counter is also cleared in this mode.</p> <p>Values:</p> <p>1'b0: MMC Counter Freeze is disabled<br/>1'b1: MMC Counter Freeze is enabled</p>                                                                                                                                                                                                                                                                                                                                                                           |
| 2   | RW   | 0x0         | <p>RSTONRD<br/>Reset on Read</p> <p>When this bit is set, the MMC counters are reset to zero after Read (self-clearing after reset). The counters are cleared when the least significant byte lane (Bits[7:0]) is read.</p> <p>Values:</p> <p>1'b0: Reset on Read is disabled<br/>1'b1: Reset on Read is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1   | RW   | 0x0         | <p>CNTSTOPRO<br/>Counter Stop Rollover</p> <p>When this bit is set, the counter does not roll over to zero after reaching the maximum value.</p> <p>Values:</p> <p>1'b0: Counter Stop Rollover is disabled<br/>1'b1: Counter Stop Rollover is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>CNTRST<br/>Counters Reset<br/>When this bit is set, all counters are reset. This bit is cleared automatically after 1 clock cycle.</p> <p>Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.</p> <p>Values:<br/>1'b0: Counters are not reset<br/>1'b1: All counters are reset</p> |

**GMAC MMC Rx Interrupt**

Address: Operational Base + offset (0x0704)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 21         | RO          | 0x0                | <p>RXFOVPIS<br/>MMC Receive FIFO Overflow Packet Counter Interrupt Status<br/>This bit is set when the rxfifooverflow counter reaches half of the maximum value or the maximum value.</p> <p>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: MMC Receive FIFO Overflow Packet Counter Interrupt Status not detected<br/>1'b1: MMC Receive FIFO Overflow Packet Counter Interrupt Status detected</p> |
| 20         | RO          | 0x0                | <p>RXPAUSPIS<br/>MMC Receive Pause Packet Counter Interrupt Status<br/>This bit is set when the rxpausepackets counter reaches half of the maximum value or the maximum value.</p> <p>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>0x0 (INACTIVE): MMC Receive Pause Packet Counter Interrupt Status not detected<br/>0x1 (ACTIVE): MMC Receive Pause Packet Counter Interrupt Status detected</p>      |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 18         | RO          | 0x0                | <p>RXLENERPIS<br/>MMC Receive Length Error Packet Counter Interrupt Status<br/>This bit is set when the rxlengtherror counter reaches half of the maximum value or the maximum value.</p> <p>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: MMC Receive Length Error Packet Counter Interrupt Status not detected<br/>1'b1: MMC Receive Length Error Packet Counter Interrupt Status detected</p>   |
| 17:6       | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RO   | 0x0         | <p><b>RXCRCERPIS</b><br/> MMC Receive CRC Error Packet Counter Interrupt Status<br/> This bit is set when the rxcrcerror counter reaches half of the maximum value or the maximum value.<br/> Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/> 1'b0: MMC Receive CRC Error Packet Counter Interrupt Status not detected<br/> 1'b1: MMC Receive CRC Error Packet Counter Interrupt Status detected</p>                        |
| 4   | RO   | 0x0         | <p><b>RXMCGPIS</b><br/> MMC Receive Multicast Good Packet Counter Interrupt Status<br/> This bit is set when the rxmulticastpackets_g counter reaches half of the maximum value or the maximum value.<br/> Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/> 1'b0: MMC Receive Multicast Good Packet Counter Interrupt Status not detected<br/> 1'b1: MMC Receive Multicast Good Packet Counter Interrupt Status detected</p> |
| 3   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2   | RO   | 0x0         | <p><b>RXGOCTIS</b><br/> MMC Receive Good Octet Counter Interrupt Status<br/> This bit is set when the rxoctetcount_g counter reaches half of the maximum value or the maximum value.<br/> Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/> 1'b0: MMC Receive Good Octet Counter Interrupt Status not detected<br/> 1'b1: MMC Receive Good Octet Counter Interrupt Status detected</p>                                        |
| 1   | RO   | 0x0         | <p><b>RXGBOCTIS</b><br/> MMC Receive Good Bad Octet Counter Interrupt Status<br/> This bit is set when the rxoctetcount_gb counter reaches half of the maximum value or the maximum value.<br/> Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/> 1'b0: MMC Receive Good Bad Octet Counter Interrupt Status not detected<br/> 1'b1: MMC Receive Good Bad Octet Counter Interrupt Status detected</p>                          |
| 0   | RO   | 0x0         | <p><b>RXGBPKTIS</b><br/> MMC Receive Good Bad Packet Counter Interrupt Status<br/> This bit is set when the rxpacketcount_gb counter reaches half of the maximum value or the maximum value.<br/> Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/> 1'b0: MMC Receive Good Bad Packet Counter Interrupt Status not detected<br/> 1'b1: MMC Receive Good Bad Packet Counter Interrupt Status detected</p>                      |

**GMAC MMC Tx Interrupt**

Address: Operational Base + offset (0x0708)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 23         | RO          | 0x0                | <p><b>TXPAUSPIS</b><br/>           MMC Transmit Pause Packet Counter Interrupt Status<br/>           This bit is set when the txpausepacketerror counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/>           Values:<br/>           0x0 (INACTIVE): MMC Transmit Pause Packet Counter Interrupt Status not detected<br/>           0x1 (ACTIVE): MMC Transmit Pause Packet Counter Interrupt Status detected</p>    |
| 22         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 21         | RO          | 0x0                | <p><b>TXGPKTIS</b><br/>           MMC Transmit Good Packet Counter Interrupt Status<br/>           This bit is set when the txpacketcount_g counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/>           Values:<br/>           1'b0: MMC Transmit Good Packet Counter Interrupt Status not detected<br/>           1'b1: MMC Transmit Good Packet Counter Interrupt Status detected</p>                             |
| 20         | RO          | 0x0                | <p><b>TXGOCTIS</b><br/>           MMC Transmit Good Octet Counter Interrupt Status<br/>           This bit is set when the txoctetcount_g counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/>           Values:<br/>           1'b0: MMC Transmit Good Octet Counter Interrupt Status not detected<br/>           1'b1: MMC Transmit Good Octet Counter Interrupt Status detected</p>                                 |
| 19         | RO          | 0x0                | <p><b>TXCARERPIS</b><br/>           MMC Transmit Carrier Error Packet Counter Interrupt Status<br/>           This bit is set when the txcarriererror counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/>           Values:<br/>           1'b0: MMC Transmit Carrier Error Packet Counter Interrupt Status not detected<br/>           1'b1: MMC Transmit Carrier Error Packet Counter Interrupt Status detected</p> |
| 18:14      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13   | RO   | 0x0         | <p>TXUFLWERPIS<br/>MMC Transmit Underflow Error Packet Counter Interrupt Status<br/>This bit is set when the txunderflowerror counter reaches half of the maximum value or the maximum value.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: MMC Transmit Underflow Error Packet Counter Interrupt Status not detected<br/>1'b1: MMC Transmit Underflow Error Packet Counter Interrupt Status detected</p> |
| 12:2 | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1    | RO   | 0x0         | <p>TXGBPKTIS<br/>MMC Transmit Good Bad Packet Counter Interrupt Status<br/>This bit is set when the txpacketcount_gb counter reaches half of the maximum value or the maximum value.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: MMC Transmit Good Bad Packet Counter Interrupt Status not detected<br/>1'b1: MMC Transmit Good Bad Packet Counter Interrupt Status detected</p>                        |
| 0    | RO   | 0x0         | <p>TXGBOCTIS<br/>MMC Transmit Good Bad Octet Counter Interrupt Status<br/>This bit is set when the txoctetcount_gb counter reaches half of the maximum value or the maximum value.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: MMC Transmit Good Bad Octet Counter Interrupt Status not detected<br/>1'b1: MMC Transmit Good Bad Octet Counter Interrupt Status detected</p>                            |

**GMAC MMC Rx Interrupt Mask**

Address: Operational Base + offset (0x070C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                                                                              |
| 21    | RW   | 0x0         | <p>RXFOVPM<br/>MMC Receive FIFO Overflow Packet Counter Interrupt Mask<br/>Setting this bit masks the interrupt when the rxfifooverflow counter reaches half of the maximum value or the maximum value.</p> <p>Values:<br/>1'b0: MMC Receive FIFO Overflow Packet Counter Interrupt Mask is disabled<br/>1'b1: MMC Receive FIFO Overflow Packet Counter Interrupt Mask is enabled</p> |
| 20:19 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RW          | 0x0                | <p><b>RXLENERPIM</b><br/>           MMC Receive Length Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxlengtherror counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive Length Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive Length Error Packet Counter Interrupt Mask is enabled</p>            |
| 17:11      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 10         | RW          | 0x0                | <p><b>RXPAUSPIM</b><br/>           MMC Receive Pause Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxpausepackets counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           0x0 (DISABLE): MMC Receive Pause Packet Counter Interrupt Mask is disabled<br/>           0x1 (ENABLE): MMC Receive Pause Packet Counter Interrupt Mask is enabled</p>                |
| 9:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5          | RW          | 0x0                | <p><b>RXCRCERPIM</b><br/>           MMC Receive CRC Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxrcerror counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive CRC Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive CRC Error Packet Counter Interrupt Mask is enabled</p>                         |
| 4          | RW          | 0x0                | <p><b>RXMCGPIM</b><br/>           MMC Receive Multicast Good Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxmulticastpackets_g counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive Multicast Good Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive Multicast Good Packet Counter Interrupt Mask is enabled</p> |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2          | RW          | 0x0                | <p><b>RXGOCTIM</b><br/>           MMC Receive Good Octet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxoctetcount_g counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive Good Octet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive Good Octet Counter Interrupt Mask is enabled</p>                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p><b>RXGBOCTIM</b><br/>           MMC Receive Good Bad Octet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxoctetcount_gb counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive Good Bad Octet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive Good Bad Octet Counter Interrupt Mask is enabled</p>     |
| 0          | RW          | 0x0                | <p><b>RXGBPKTIM</b><br/>           MMC Receive Good Bad Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxpacketcount_gb counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive Good Bad Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive Good Bad Packet Counter Interrupt Mask is enabled</p> |

**GMAC MMC Tx Interrupt Mask**

Address: Operational Base + offset (0x0710)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 23         | RW          | 0x0                | <p><b>TXPAUSPIM</b><br/>           MMC Transmit Pause Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txpausepackets counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           0x0 (DISABLE): MMC Transmit Pause Packet Counter Interrupt Mask is disabled<br/>           0x1 (ENABLE): MMC Transmit Pause Packet Counter Interrupt Mask is enabled</p> |
| 22         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 21         | RW          | 0x0                | <p><b>TXGPKTIM</b><br/>           MMC Transmit Good Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txpacketcount_g counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Transmit Good Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Transmit Good Packet Counter Interrupt Mask is enabled</p>                     |
| 20         | RW          | 0x0                | <p><b>TXGOCTIM</b><br/>           MMC Transmit Good Octet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txoctetcount_g counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Transmit Good Octet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Transmit Good Octet Counter Interrupt Mask is enabled</p>                         |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19    | RW   | 0x0         | <p><b>TXCARERPI</b><br/>           MMC Transmit Carrier Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txcarriererror counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Transmit Carrier Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Transmit Carrier Error Packet Counter Interrupt Mask is enabled</p>          |
| 18:14 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13    | RW   | 0x0         | <p><b>TXUFLWERPI</b><br/>           MMC Transmit Underflow Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txunderflowerror counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Transmit Underflow Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Transmit Underflow Error Packet Counter Interrupt Mask is enabled</p> |
| 12:2  | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1     | RW   | 0x0         | <p><b>TXGBPKTIM</b><br/>           MMC Transmit Good Bad Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txpacketcount_gb counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Transmit Good Bad Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Transmit Good Bad Packet Counter Interrupt Mask is enabled</p>                       |
| 0     | RW   | 0x0         | <p><b>TXGBOCTIM</b><br/>           MMC Transmit Good Bad Octet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the txoctetcount_gb counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Transmit Good Bad Octet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Transmit Good Bad Octet Counter Interrupt Mask is enabled</p>                           |

**GMAC Tx Octet Count Good Bad**

Address: Operational Base + offset (0x0714)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p><b>TXOCTGB</b><br/>           Tx Octet Count Good Bad<br/>           This field indicates the number of bytes transmitted, exclusive of preamble and retried bytes, in good and bad packets.</p> |

**GMAC Tx Packet Count Good Bad**

Address: Operational Base + offset (0x0718)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXPKTGB<br>Tx Packet Count Good Bad<br>This field indicates the number of good and bad packets transmitted, exclusive of retried packets. |

**GMAC Tx Underflow Error Packets**

Address: Operational Base + offset (0x0748)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXUNDRFLW<br>Tx Underflow Error Packets<br>This field indicates the number of packets aborted because of packets underflow error. |

**GMAC Tx Carrier Error Packets**

Address: Operational Base + offset (0x0760)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXCARR<br>Tx Carrier Error Packets<br>This field indicates the number of packets aborted because of carrier sense error (no carrier or loss of carrier). |

**GMAC Tx Octet Count Good**

Address: Operational Base + offset (0x0764)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXOCTG<br>Tx Octet Count Good<br>This field indicates the number of bytes transmitted, exclusive of preamble, only in good packets. |

**GMAC Tx Packet Count Good**

Address: Operational Base + offset (0x0768)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXPKTG<br>Tx Packet Count Good<br>This field indicates the number of good packets transmitted. |

**GMAC Tx Pause Packets**

Address: Operational Base + offset (0x0770)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TXPAUSE<br>Tx Pause Packets<br>This field indicates the number of good Pause packets transmitted. |

**GMAC Rx Packets Count Good Bad**

Address: Operational Base + offset (0x0780)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXPKTGB<br>Rx Packets Count Good Bad<br>This field indicates the number of good and bad packets received. |

**GMAC Rx Octet Count Good Bad**

Address: Operational Base + offset (0x0784)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXOCTGB<br>Rx Octet Count Good Bad<br>This field indicates the number of bytes received, exclusive of preamble, in good and bad packets. |

**GMAC Rx Octet Count Good**

Address: Operational Base + offset (0x0788)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXOCTG<br>Rx Octet Count Good<br>This field indicates the number of bytes received, exclusive of preamble, only in good packets. |

**GMAC Rx Multicast Packets Good**

Address: Operational Base + offset (0x0790)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXMCASTG<br>Rx Multicast Packets Good<br>This field indicates the number of good multicast packets received. |

**GMAC Rx CRC Error Packets**

Address: Operational Base + offset (0x0794)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXCRCERR<br>Rx CRC Error Packets<br>This field indicates the number of packets received with CRC error. |

**GMAC Rx Length Error Packets**

Address: Operational Base + offset (0x07C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXLENERR<br>Rx Length Error Packets<br>This field indicates the number of packets received with length error (Length Type field not equal to packet size), for all packets with valid length field. |

**GMAC Rx Pause Packets**

Address: Operational Base + offset (0x07D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXPAUSEPKT<br>Rx Pause Packets<br>This field indicates the number of good and valid Pause packets received. |

**GMAC Rx FIFO Overflow Packets**

Address: Operational Base + offset (0x07D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXFIFOVFL<br>Rx FIFO Overflow Packets<br>This field indicates the number of missed received packets because of FIFO overflow. |

**GMAC MMC IPC Rx Interrupt Mask**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 29         | RW          | 0x0                | <p><b>RXICMPEROIM</b><br/>           MMC Receive ICMP Error Octet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxicmp_err_octets counter reaches half of the maximum value or the maximum value.</p> <p>Values:<br/>           1'b0: MMC Receive ICMP Error Octet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive ICMP Error Octet Counter Interrupt Mask is enabled</p>                          |
| 28         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 27         | RW          | 0x0                | <p><b>RXTCPEROIM</b><br/>           MMC Receive TCP Error Octet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxtcp_err_octets counter reaches half of the maximum value or the maximum value.</p> <p>Values:<br/>           1'b0: MMC Receive TCP Error Octet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive TCP Error Octet Counter Interrupt Mask is enabled</p>                               |
| 26         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25         | RW          | 0x0                | <p><b>RXUDPEROIM</b><br/>           MMC Receive UDP Error Octet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxudp_err_octets counter reaches half of the maximum value or the maximum value.</p> <p>Values:<br/>           1'b0: MMC Receive UDP Error Octet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive UDP Error Octet Counter Interrupt Mask is enabled</p>                               |
| 24:23      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 22         | RW          | 0x0                | <p><b>RXIPV6HEROIM</b><br/>           MMC Receive IPV6 Header Error Octet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxipv6_nopay_octets counter reaches half of the maximum value or the maximum value.</p> <p>Value:<br/>           1'b0: MMC Receive IPV6 Header Error Octet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive IPV6 Header Error Octet Counter Interrupt Mask is enabled</p>   |
| 21:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 17         | RW          | 0x0                | <p><b>RXIPV4HEROIM</b><br/>           MMC Receive IPV4 Header Error Octet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxipv4_hdrerr_octets counter reaches half of the maximum value or the maximum value.</p> <p>Values:<br/>           1'b0: MMC Receive IPV4 Header Error Octet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive IPV4 Header Error Octet Counter Interrupt Mask is enabled</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 13         | RW          | 0x0                | <p><b>RXICMPERPIM</b><br/>           MMC Receive ICMP Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxicmp_err_pkts counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive ICMP Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive ICMP Error Packet Counter Interrupt Mask is enabled</p>                          |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11         | RW          | 0x0                | <p><b>RXTCPERPIM</b><br/>           MMC Receive TCP Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxtcp_err_pkts counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive TCP Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive TCP Error Packet Counter Interrupt Mask is enabled</p>                               |
| 10         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 9          | RW          | 0x0                | <p><b>RXUDPERPIM</b><br/>           MMC Receive UDP Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxudp_err_pkts counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive UDP Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive UDP Error Packet Counter Interrupt Mask is enabled</p>                               |
| 8:7        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 6          | RW          | 0x0                | <p><b>RXIPV6HERPIM</b><br/>           MMC Receive IPV6 Header Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxipv6_hdrerr_pkts counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive IPV6 Header Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive IPV6 Header Error Packet Counter Interrupt Mask is enabled</p> |
| 5          | RW          | 0x0                | <p><b>RXIPV6GPIM</b><br/>           MMC Receive IPV6 Good Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxipv6_gd_pkts counter reaches half of the maximum value or the maximum value.<br/>           Values:<br/>           1'b0: MMC Receive IPV6 Good Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive IPV6 Good Packet Counter Interrupt Mask is enabled</p>                               |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p><b>RXIPV4HERPIM</b><br/>           MMC Receive IPV4 Header Error Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxipv4_hdrerr_pkts counter reaches half of the maximum value or the maximum value.</p> <p>Values:<br/>           1'b0: MMC Receive IPV4 Header Error Packet Counter Interrupt Mask is disabled<br/>           1'b1: MMC Receive IPV4 Header Error Packet Counter Interrupt Mask is enabled</p> |
| 0          | RW          | 0x0                | <p><b>RXIPV4GPIM</b><br/>           MMC Receive IPV4 Good Packet Counter Interrupt Mask<br/>           Setting this bit masks the interrupt when the rxipv4_gd_pkts counter reaches half of the maximum value or the maximum value.</p> <p>Values:<br/>           1'b0: MMC Receive IPV4 Good Packet Counter Interrupt Mask is disable<br/>           1'b1: MMC Receive IPV4 Good Packet Counter Interrupt Mask is enabled</p>                                |

**GMAC MMC IPC Rx Interrupt**

Address: Operational Base + offset (0x0808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 29         | RO          | 0x0                | <p><b>RXICMPEROIS</b><br/>           MMC Receive ICMP Error Octet Counter Interrupt Status<br/>           This bit is set when the rxicmp_err_octets counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>           1'b0: MMC Receive ICMP Error Octet Counter Interrupt Status not detected<br/>           1'b1: MMC Receive ICMP Error Octet Counter Interrupt Status detected</p> |
| 28         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 27         | RO          | 0x0                | <p><b>RXTCPEROIS</b><br/>           MMC Receive TCP Error Octet Counter Interrupt Status<br/>           This bit is set when the rxtcp_err_octets counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>           1'b0: MMC Receive TCP Error Octet Counter Interrupt Status not detected<br/>           1'b1: MMC Receive TCP Error Octet Counter Interrupt Status detected</p>      |
| 26         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25         | RO          | 0x0                | <p><b>RXUDPEROIS</b><br/> MMC Receive UDP Error Octet Counter Interrupt Status<br/> This bit is set when the rxudp_err_octets counter reaches half of the maximum value or the maximum value.<br/> Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/> 1'b0: MMC Receive UDP Error Octet Counter Interrupt Status not detected<br/> 1'b1: MMC Receive UDP Error Octet Counter Interrupt Status detected</p>                               |
| 24:23      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 22         | RO          | 0x0                | <p><b>RXIPV6HEROIS</b><br/> MMC Receive IPV6 Header Error Octet Counter Interrupt Status<br/> This bit is set when the rxipv6_hdrerr_octets counter reaches half of the maximum value or the maximum value.<br/> Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/> 1'b0: MMC Receive IPV6 Header Error Octet Counter Interrupt Status not detected<br/> 1'b1: MMC Receive IPV6 Header Error Octet Counter Interrupt Status detected</p> |
| 21:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17         | RO          | 0x0                | <p><b>RXIPV4HEROIS</b><br/> MMC Receive IPV4 Header Error Octet Counter Interrupt Status<br/> This bit is set when the rxipv4_hdrerr_octets counter reaches half of the maximum value or the maximum value.<br/> Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/> 1'b0: MMC Receive IPV4 Header Error Octet Counter Interrupt Status not detected<br/> 1'b1: MMC Receive IPV4 Header Error Octet Counter Interrupt Status detected</p> |
| 16:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 13         | RO          | 0x0                | <p><b>RXICMPERRPIS</b><br/> MMC Receive ICMP Error Packet Counter Interrupt Status<br/> This bit is set when the rxicmp_err_pkts counter reaches half of the maximum value or the maximum value.<br/> Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/> 1'b0: MMC Receive ICMP Error Packet Counter Interrupt Status not detected<br/> 1'b1: MMC Receive ICMP Error Packet Counter Interrupt Status detected</p>                        |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RO          | 0x0                | <p><b>RXTCPERPIS</b><br/>           MMC Receive TCP Error Packet Counter Interrupt Status<br/>           This bit is set when the rxtcp_err_pkts counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>           1'b0: MMC Receive TCP Error Packet Counter Interrupt Status not detected<br/>           1'b1: MMC Receive TCP Error Packet Counter Interrupt Status detected</p>                               |
| 10         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9          | RO          | 0x0                | <p><b>RXUDPERPIS</b><br/>           MMC Receive UDP Error Packet Counter Interrupt Status<br/>           This bit is set when the rxudp_err_pkts counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>           1'b0: MMC Receive UDP Error Packet Counter Interrupt Status not detected<br/>           1'b1: MMC Receive UDP Error Packet Counter Interrupt Status detected</p>                               |
| 8:7        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6          | RO          | 0x0                | <p><b>RXIPV6HERPIS</b><br/>           MMC Receive IPV6 Header Error Packet Counter Interrupt Status<br/>           This bit is set when the rxipv6_hdrerr_pkts counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>           1'b0: MMC Receive IPV6 Header Error Packet Counter Interrupt Status not detected<br/>           1'b1: MMC Receive IPV6 Header Error Packet Counter Interrupt Status detected</p> |
| 5          | RO          | 0x0                | <p><b>RXIPV6GPIS</b><br/>           MMC Receive IPV6 Good Packet Counter Interrupt Status<br/>           This bit is set when the rxipv6_gd_pkts counter reaches half of the maximum value or the maximum value.<br/>           Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>           1'b0: MMC Receive IPV6 Good Packet Counter Interrupt Status not detected<br/>           1'b1: MMC Receive IPV6 Good Packet Counter Interrupt Status detected</p>                               |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | <p>RXIPV4HERPIS<br/>MMC Receive IPV4 Header Error Packet Counter Interrupt Status<br/>This bit is set when the rxipv4_hdrerr_pkts counter reaches half of the maximum value or the maximum value.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: MMC Receive IPV4 Header Error Packet Counter Interrupt Status not detected<br/>1'b1: MMC Receive IPV4 Header Error Packet Counter Interrupt Status detected</p> |
| 0          | RO          | 0x0                | <p>RXIPV4GPIS<br/>MMC Receive IPV4 Good Packet Counter Interrupt Status<br/>This bit is set when the rxipv4_gd_pkts counter reaches half of the maximum value or the maximum value.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: MMC Receive IPV4 Good Packet Counter Interrupt Status not detected<br/>1'b1: MMC Receive IPV4 Good Packet Counter Interrupt Status detected</p>                               |

**GMAC RxIPv4 Good Packets**

Address: Operational Base + offset (0x0810)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>RXIPV4GDPKT<br/>RxIPv4 Good Packets<br/>This field indicates the number of good IPv4 datagrams received with the TCP, UDP, or ICMP payload.</p> |

**GMAC RxIPv4 Header Error Packets**

Address: Operational Base + offset (0x0814)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>RXIPV4HDRERRPKT<br/>RxIPv4 Header Error Packets<br/>This field indicates the number of IPv4 datagrams received with header (checksum, length, or version mismatch) errors.</p> |

**GMAC RxIPv6 Good Packets**

Address: Operational Base + offset (0x0824)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>RXIPV6GDPKT<br/>RxIPv6 Good Packets<br/>This field indicates the number of good IPv6 datagrams received with the TCP, UDP, or ICMP payload.</p> |

**GMAC RxIPv6 Header Error Packets**

Address: Operational Base + offset (0x0828)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>RXIPV6HDRERRPKT<br/>RxIPv6 Header Error Packets<br/>This field indicates the number of IPv6 datagrams received with header (length or version mismatch) errors.</p> |

**GMAC RxUDP Error Packets**

Address: Operational Base + offset (0x0834)

| Bit  | Attr | Reset Value | Description                                                                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | RXUDPPERPKT<br>RxUDP Error Packets<br>This field indicates the number of good IP datagrams received whose UDP payload has a checksum error. |

**GMAC RxTCP Error Packets**

Address: Operational Base + offset (0x083C)

| Bit  | Attr | Reset Value | Description                                                                                                                                 |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | RXTCPERRPKT<br>RxTCP Error Packets<br>This field indicates the number of good IP datagrams received whose TCP payload has a checksum error. |

**GMAC RxICMP Error Packets**

Address: Operational Base + offset (0x0844)

| Bit  | Attr | Reset Value | Description                                                                                                                                    |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | RXICMPERRPKT<br>RxICMP Error Packets<br>This field indicates the number of good IP datagrams received whose ICMP payload has a checksum error. |

**GMAC RxIPv4 Header Error Octets**

Address: Operational Base + offset (0x0854)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                               |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | RXIPV4HDRERROCT<br>RxIPv4 Header Error Octets<br>This field indicates the number of bytes received in IPv4 datagrams with header errors (checksum, length, version mismatch). The value in the Length field of IPv4 header is used to update this counter. (Ethernet header, FCS, pad, or IP pad bytes are not included in this counter). |

**GMAC RxIPv6 Header Error Octets**

Address: Operational Base + offset (0x0868)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | RXIPV6HDRERROCT<br>RxIPv6 Header Error Octets<br>This field indicates the number of bytes received in IPv6 datagrams with header errors (length, version mismatch). The value in the Length field of IPv6 header is used to update this counter. (Ethernet header, FCS, pad, or IP pad bytes are not included in this counter). |

**GMAC RxUDP Error Octets**

Address: Operational Base + offset (0x0874)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | RXUDPERROCT<br>RxUDP Error Octets<br>This field indicates the number of bytes received in a UDP segment that had checksum errors. This counter does not count IP header bytes. |

**GMAC RxTCP Error Octets**

Address: Operational Base + offset (0x087C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXTCPERRCT<br>RxTCP Error Octets<br>This field indicates the number of bytes received in a TCP segment that had checksum errors. This counter does not count IP header bytes. |

**GMAC RxICMP Error Octets**

Address: Operational Base + offset (0x0884)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXICMPERRCT<br>RxICMP Error Octets<br>This field indicates the number of bytes received in a ICMP segment that had checksum errors. This counter does not count IP header bytes. |

**GMAC MTL Operation Mode**

Address: Operational Base + offset (0x0C00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                              |
| 9          | RW          | 0x0                | CNTCLR<br>Counters Reset<br>When this bit is set, all counters are reset. This bit is cleared automatically after 1 clock cycle.<br>If this bit is set along with CNT_PRESET bit, CNT_PRESET has precedence.<br>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br>Values:<br>iö 0x0 (DISABLE): Counters are not reset<br>iö 0x1 (ENABLE): All counters are reset  |
| 8          | RW          | 0x0                | CNTPRST<br>Counters Reset<br>When this bit is set, all counters are reset. This bit is cleared automatically after 1 clock cycle.<br>If this bit is set along with CNT_PRESET bit, CNT_PRESET has precedence.<br>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br>Values:<br>iö 0x0 (DISABLE): Counters are not reset<br>iö 0x1 (ENABLE): All counters are reset |
| 7:2        | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                              |
| 1          | RW          | 0x0                | DTXSTS<br>Drop Transmit Status<br>When this bit is set, the Tx packet status received from the MAC is dropped in the MTL. When this bit is reset, the Tx packet status received from the MAC is forwarded to the application.<br>Values:<br>iö 0x0 (DISABLE): Drop Transmit Status is disabled<br>iö 0x1 (ENABLE): Drop Transmit Status is enabled                                                    |
| 0          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                              |

**GMAC MTL DBG CTL**

Address: Operational Base + offset (0x0C08)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15         | RW          | 0x0                | <p><b>STSIE</b><br/>         Transmit Status Available Interrupt Status Enable<br/>         When this bit is set, an interrupt is generated when Transmit status is available in slave mode.<br/>         Values:<br/>         1'b0: Transmit Packet Available Interrupt Status is disabled<br/>         1'b1: Transmit Packet Available Interrupt Status is enabled</p>                                                                                                                                                                    |
| 14         | RW          | 0x0                | <p><b>PKTIE</b><br/>         Receive Packet Available Interrupt Status Enable<br/>         When this bit is set, an interrupt is generated when EOP of received packet is written to the Rx FIFO.<br/>         Values:<br/>         1'b0: Receive Packet Available Interrupt Status is disabled<br/>         1'b1: Receive Packet Available Interrupt Status is enabled</p>                                                                                                                                                                 |
| 13:12      | RW          | 0x0                | <p><b>FIFOSEL</b><br/>         FIFO Selected for Access<br/>         This field indicates the FIFO selected for debug access:<br/>         Values:<br/>         2'b00: Tx FIFO<br/>         2'b01: Tx Status FIFO (only read access when SLVMOD is set)<br/>         2'b10: TSO FIFO (cannot be accessed when SLVMOD is set)<br/>         2'b11: Rx FIFO</p>                                                                                                                                                                                |
| 11         | RW          | 0x0                | <p><b>FIFOWREN</b><br/>         FIFO Write Enable<br/>         When this bit is set, it enables the Write operation on selected FIFO when FIFO Debug Access is enabled. This bit must not be written to 1 when FIFO Debug Access is not enabled, that is FDBGGEN bit is 0.<br/>         Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.<br/>         Values:<br/>         1'b0: FIFO Write is disabled<br/>         1'b1: FIFO Write is enabled</p>                                                             |
| 10         | RW          | 0x0                | <p><b>FIFORDEN</b><br/>         FIFO Read Enable<br/>         When this bit is set, it enables the Read operation on selected FIFO when FIFO Debug Access is enabled. This bit must not be written to 1 when FIFO Debug Access is not enabled, that is FDBGGEN bit is 0.<br/>         Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.<br/>         Values:<br/>         1'b0: FIFO Read is disabled<br/>         1'b1: FIFO Read is enabled</p>                                                                 |
| 9          | RW          | 0x0                | <p><b>RSTSEL</b><br/>         Reset Pointers of Selected FIFO<br/>         When this bit is set, the pointers of the currently-selected FIFO are reset when FIFO Debug Access is enabled. This bit must not be written to 1 when FIFO Debug Access is not enabled, that is FDBGGEN bit is 0.<br/>         Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.<br/>         Values:<br/>         1'b0: Reset Pointers of Selected FIFO is disabled<br/>         1'b1: Reset Pointers of Selected FIFO is enabled</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | RW   | 0x0         | <p>RSTALL<br/>Reset All Pointers<br/>When this bit is set, the pointers of all FIFOs are reset when FIFO Debug Access is enabled. This bit must not be written to 1 when FIFO Debug Access is not enabled, that is FDBGEN bit is 0.<br/>Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.<br/>Values:<br/>1'b0: Reset All Pointers is disabled<br/>1'b1: Reset All Pointers is enabled</p>                                                                                                                                                                                                                                                                              |
| 7   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6:5 | RW   | 0x0         | <p>PKTSTATE<br/>Encoded Packet State<br/>This field is used to write the control information to the Tx FIFO or Rx FIFO.<br/>Tx FIFO:<br/>2'b00: Packet Data<br/>2'b01: Control Word<br/>2'b10: SOP Data<br/>2'b11: EOP Data<br/>Rx FIFO:<br/>2'b00: Packet Data<br/>2'b01: Normal Status<br/>2'b10: Last Status<br/>2'b11: EOP<br/>Values:<br/>2'b00: Packet Data<br/>2'b01: Control Word/Normal Status<br/>2'b10: SOP Data/Last Status<br/>2'b11: EOP Data/EOP</p>                                                                                                                                                                                                                               |
| 4   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3:2 | RW   | 0x0         | <p>BYTEEN<br/>Byte Enables<br/>This field indicates the number of data bytes valid in the data register during Write operation. This is valid only when PKTSTATE is 2'b10 (EOP) and Tx FIFO or Rx FIFO is selected.<br/>Values:<br/>2'b00: Byte 0 valid<br/>2'b01: Byte 0 and Byte 1 are valid<br/>2'b10: Byte 0, Byte 1, and Byte 2 are valid<br/>2'b11: All four bytes are valid</p>                                                                                                                                                                                                                                                                                                            |
| 1   | RW   | 0x0         | <p>DBGMOD<br/>Debug Mode Access to FIFO<br/>When this bit is set, it indicates that the current access to the FIFO is read, write, and debug access. In this mode, the following access types are allowed:<br/>1. Read and Write access to Tx FIFO, TSO FIFO, and Rx FIFO<br/>2. Read access is allowed to Tx Status FIFO.<br/>When this bit is reset, it indicates that the current access to the FIFO is slave access bypassing the DMA. In this mode, the following access are allowed:<br/>1. Write access to the Tx FIFO<br/>2. Read access to the Rx FIFO and Tx Status FIFO<br/>Values:<br/>1'b0: Debug Mode Access to FIFO is disabled<br/>1'b1: Debug Mode Access to FIFO is enabled</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | <p>FDBGEN<br/>FIFO Debug Access Enable<br/>When this bit is set, it indicates that the debug mode access to the FIFO is enabled. When this bit is reset, it indicates that the FIFO can be accessed only through a master interface.</p> <p>Values:<br/>1'b0: FIFO Debug Access is disabled<br/>1'b1: FIFO Debug Access is enabled</p> |

**GMAC MTL DBG STS**

Address: Operational Base + offset (0x0C0C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15    | RO   | 0x320       | <p>LOCR<br/>Remaining Locations in the FIFO<br/>Slave Access Mode:<br/>This field indicates the space available in selected FIFO.<br/>Debug Access Mode:<br/>This field contains the Write or Read pointer value of the selected FIFO during Write or Read operation, respectively.<br/>Reset: In single Tx Queue configurations,<br/>(DWC_EQOS_TXFIFO_SIZE/(DWC_EQOS_DATAWIDTH/8)),<br/>Otherwise 0000H.</p> |
| 14:10 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                      |
| 9     | RW   | 0x0         | <p>STSI<br/>Transmit Status Available Interrupt Status<br/>When set, this bit indicates that the Slave mode Tx packet is transmitted, and the status is available in Tx Status FIFO. This bit is reset when 1 is written to this bit.</p> <p>Values:<br/>1'b0: Transmit Status Available Interrupt Status not detected<br/>1'b1: Transmit Status Available Interrupt Status detected</p>                      |
| 8     | RW   | 0x0         | <p>PKTI<br/>Receive Packet Available Interrupt Status<br/>When set, this bit indicates that MAC layer has written the EOP of received packet to the Rx FIFO. This bit is reset when 1 is written to this bit.</p> <p>Values:<br/>1'b0: Receive Packet Available Interrupt Status not detected<br/>1'b1: Receive Packet Available Interrupt Status detected</p>                                                |
| 7:5   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4:3   | RO   | 0x0         | <p>BYTEEN<br/>Byte Enables<br/>This field indicates the number of data bytes valid in the data register during Read operation. This is valid only when PKTSTATE is 2'b10 (EOP) and Tx FIFO or Rx FIFO is selected.</p> <p>Values:<br/>2'b00: Byte 0 valid<br/>2'b01: Byte 0 and Byte 1 are valid<br/>2'b10: Byte 0, Byte 1, and Byte 2 are valid<br/>2'b11: All four bytes are valid</p>                      |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:1 | RO   | 0x0         | <p>PKTSTATE<br/>Encoded Packet State<br/>This field is used to get the control or status information of the selected FIFO.</p> <p>Tx FIFO:<br/>2'b00: Packet Data<br/>2'b01: Control Word<br/>2'b10: SOP Data<br/>2'b11: EOP Data</p> <p>Rx FIFO:<br/>2'b00: Packet Data<br/>2'b01: Normal Status<br/>2'b10: Last Status<br/>2'b11: EOP</p> <p>This field is applicable only for Tx FIFO and Rx FIFO during Read operation.</p> <p>Values:<br/>2'b00: Packet Data<br/>2'b01: Control Word/Normal Status<br/>2'b10: SOP Data/Last Status<br/>2'b11: EOP Data/EOP</p> |
| 0   | RO   | 0x0         | <p>FIFOBUSY<br/>FIFO Busy<br/>When set, this bit indicates that a FIFO operation is in progress in the MAC and content of the following fields is not valid:</p> <ol style="list-style-type: none"> <li>1. All other fields of this register</li> <li>2. All fields of the MTL_FIFO_Debug_Data register</li> </ol> <p>Values:<br/>1'b0: FIFO Busy not detected<br/>1'b1: FIFO Busy detected</p>                                                                                                                                                                     |

**GMAC MTL FIFO Debug Data**

Address: Operational Base + offset (0x0C10)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>FDBGDATA<br/>FIFO Debug Data<br/>During debug or slave access write operation, this field contains the data to be written to the Tx FIFO, Rx FIFO, or TSO FIFO.<br/>During debug or slave access read operation, this field contains the data read from the Tx FIFO, Rx FIFO, TSO FIFO, or Tx Status FIFO.</p> |

**GMAC MTL Interrupt Status**

Address: Operational Base + offset (0x0C20)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                           |
| 17    | RO   | 0x0         | <p>DBGIS<br/>Debug Interrupt status<br/>This bit indicates an interrupt event during the slave access. To reset this bit, the application must read the FIFO Debug Access Status register to get the exact cause of the interrupt and clear its source.</p> <p>Values:<br/>1'b0: Debug Interrupt status not detected<br/>1'b1: Debug Interrupt status detected</p> |
| 16:1  | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | <p>Q0IS<br/>Queue 0 Interrupt status<br/>This bit indicates that there is an interrupt from Queue 0. To reset this bit, the application must read Queue 0 Interrupt Control and Status register to get the exact cause of the interrupt and clear its source.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Queue 0 Interrupt status not detected</li> <li>1'b1: Queue 0 Interrupt status detected</li> </ul> |

**GMAC MTL TxQ0 Operation Mode**

Address: Operational Base + offset (0x0D00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6:4        | RW          | 0x0                | <p>TTC<br/>Transmit Threshold Control<br/>These bits control the threshold level of the MTL Tx Queue. The transmission starts when the packet size within the MTL Tx Queue is larger than the threshold. In addition, full packets with length less than the threshold are also transmitted. These bits are used only when the TSF bit is reset.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>3'b000: 32 bytes</li> <li>3'b001: 64 bytes</li> <li>3'b010: 96 bytes</li> <li>3'b011: 128 bytes</li> <li>3'b100: 192 bytes</li> <li>3'b101: 256 bytes</li> <li>3'b110: 384 bytes</li> <li>3'b111: 512 bytes</li> </ul> |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RW          | 0x0                | <p>TSF<br/>Transmit Store and Forward<br/>When this bit is set, the transmission starts when a full packet resides in the MTL Tx queue. When this bit is set, the TTC values specified in Bits[6:4] of this register are ignored. This bit should be changed only when the transmission is stopped.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Transmit Store and Forward is disabled</li> <li>1'b1: Transmit Store and Forward is enabled</li> </ul>                                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | <p>FTQ<br/>Flush Transmit Queue<br/>When this bit is set, the Tx queue controller logic is reset to its default values. Therefore, all the data in the Tx queue is lost or flushed. This bit is internally reset when the flushing operation is complete. Until this bit is reset, you should not write to the MTL_TxQ1_Operation_Mode register. The data which is already accepted by the MAC transmitter is not flushed. It is scheduled for transmission and results in underflow and runt packet transmission.</p> <p>Note: The flush operation is complete only when the Tx queue is empty and the application has accepted the pending Tx Status of all transmitted packets. To complete this flush operation, the PHY Tx clock (clk_tx_i) should be active.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Flush Transmit Queue is disabled</li> <li>1'b1: Flush Transmit Queue is enabled</li> </ul> |

**GMAC MTL TxQ0 Underflow**

Address: Operational Base + offset (0x0D04)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 11    | RO   | 0x0         | <p>UFCNTOVF<br/>Overflow Bit for Underflow Packet Counter<br/>This bit is set every time the Tx queue Underflow Packet Counter field overflows, that is, it has crossed the maximum count. In such a scenario, the overflow packet counter is reset to all-zeros and this bit indicates that the rollover happened.</p> <p>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Overflow not detected for Underflow Packet Counter</li> <li>1'b1: Overflow detected for Underflow Packet Counter</li> </ul> |
| 10:0  | RO   | 0x000       | <p>UFFRMCNT<br/>Underflow Packet Counter<br/>This field indicates the number of packets aborted by the controller because of Tx Queue Underflow. This counter is incremented each time the MAC aborts outgoing packet because of underflow. The counter is cleared when this register is read with mci_be_i[0] at 1'b1.</p> <p>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p>                                                                                                                                                                                     |

**GMAC MTL TxQ0 Debug**

Address: Operational Base + offset (0x0D08)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23 | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                 |
| 22:20 | RO   | 0x0         | <p>STXSTS<br/>Number of Status Words in Tx Status FIFO of Queue<br/>This field indicates the current number of status in the Tx Status FIFO of this queue. When the DTXSTS bit of MTL_Operation_Mode register is set to 1, this field does not reflect the number of status words in Tx Status FIFO.</p> |
| 19    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:16      | RO          | 0x0                | PTXQ<br>Number of Packets in the Transmit Queue<br>This field indicates the current number of packets in the Tx Queue. When the DTXSTS bit of MTL_Operation_Mode register is set to 1, this field does not reflect the number of packets in the Transmit queue.                                                                                                                                                                                                                                          |
| 15:6       | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5          | RO          | 0x0                | TXSTSFSTS<br>MTL Tx Status FIFO Full Status<br>When high, this bit indicates that the MTL Tx Status FIFO is full. Therefore, the MTL cannot accept any more packets for transmission.<br>Values:<br>1'b0: MTL Tx Status FIFO Full status is not detected<br>1'b1: MTL Tx Status FIFO Full status is detected                                                                                                                                                                                             |
| 4          | RO          | 0x0                | TXQSTS<br>MTL Tx Queue Not Empty Status<br>When this bit is high, it indicates that the MTL Tx Queue is not empty and some data is left for transmission.<br>Values:<br>1'b0: MTL Tx Queue Not Empty status is not detected<br>1'b1: MTL Tx Queue Not Empty status is detected                                                                                                                                                                                                                           |
| 3          | RO          | 0x0                | TWCSTS<br>MTL Tx Queue Write Controller Status<br>When high, this bit indicates that the MTL Tx Queue Write Controller is active, and it is transferring the data to the Tx Queue.<br>Values:<br>1'b0: MTL Tx Queue Write Controller status is not detected<br>1'b1: MTL Tx Queue Write Controller status is detected                                                                                                                                                                                    |
| 2:1        | RO          | 0x0                | TRCSTS<br>MTL Tx Queue Read Controller Status<br>This field indicates the state of the Tx Queue Read Controller:<br>Values:<br>2'b00: Idle state<br>2'b01: Read state (transferring data to the MAC transmitter)<br>2'b10: Waiting for pending Tx Status from the MAC transmitter<br>2'b11: Flushing the Tx queue because of the Packet Abort request from the MAC                                                                                                                                       |
| 0          | RO          | 0x0                | TXQPAUSED<br>Transmit Queue in Pause<br>When this bit is high and the Rx flow control is enabled, it indicates that the Tx Queue is in the Pause condition (in the full-duplex only mode) because of the following:<br>1. Reception of the PFC packet for the priorities assigned to the Tx Queue when PFC is enabled<br>2. Reception of 802.3x Pause packet when PFC is disabled<br>Values:<br>1'b0: Transmit Queue in Pause status is not detected<br>1'b1: Transmit Queue in Pause status is detected |

**GMAC MTL Q0 Interrupt Ctrl Status**

Address: Operational Base + offset (0x0D2C)

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24    | RW   | 0x0         | <p><b>RXOIE</b><br/>Receive Queue Overflow Interrupt Enable<br/>When this bit is set, the Receive Queue Overflow interrupt is enabled. When this bit is reset, the Receive Queue Overflow interrupt is disabled.<br/>Values:<br/>1'b0: Receive Queue Overflow Interrupt is disabled<br/>1'b1: Receive Queue Overflow Interrupt is enabled</p>                                                                                                                                                                                                                                |
| 23:17 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16    | RW   | 0x0         | <p><b>RXOVFIS</b><br/>Receive Queue Overflow Interrupt Status<br/>This bit indicates that the Receive Queue had an overflow while receiving the packet. If a partial packet is transferred to the application, the overflow status is set in RDES3[21]. This bit is cleared when the application writes 1 to this bit.<br/>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.<br/>Values:<br/>1'b0: Receive Queue Overflow Interrupt Status not detected<br/>1'b1: Receive Queue Overflow Interrupt Status detected</p> |
| 15:9  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8     | RW   | 0x0         | <p><b>TXUIE</b><br/>Transmit Queue Underflow Interrupt Enable<br/>When this bit is set, the Transmit Queue Underflow interrupt is enabled. When this bit is reset, the Transmit Queue Underflow interrupt is disabled.<br/>Values:<br/>1'b0: Transmit Queue Underflow Interrupt Status is disabled<br/>1'b1: Transmit Queue Underflow Interrupt Status is enabled</p>                                                                                                                                                                                                        |
| 7:1   | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0     | RW   | 0x0         | <p><b>TXUNFIS</b><br/>Transmit Queue Underflow Interrupt Status<br/>This bit indicates that the Transmit Queue had an underflow while transmitting the packet. Transmission is suspended and an Underflow Error TDES3[2] is set. This bit is cleared when the application writes 1 to this bit.<br/>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.<br/>Values:<br/>1'b0: Transmit Queue Underflow Interrupt Status not detected<br/>1'b1: Transmit Queue Underflow Interrupt Status detected</p>                    |

**GMAC MTL RxQ0 Operation Mode**

Address: Operational Base + offset (0x0D30)

| Bit   | Attr | Reset Value | Description |
|-------|------|-------------|-------------|
| 31:18 | RO   | 0x0000      | reserved    |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:14 | RW   | 0x0         | <p>RFD<br/>Threshold for Deactivating Flow Control (in half-duplex and full-duplex modes)</p> <p>These bits control the threshold (fill-level of Rx queue) at which the flow control is de-asserted after activation:</p> <ul style="list-style-type: none"> <li>0: Full minus 1 KB, that is, FULL 1 KB</li> <li>1: Full minus 1.5 KB, that is, FULL 1.5 KB</li> <li>2: Full minus 2 KB, that is, FULL 2 KB</li> <li>3: Full minus 2.5 KB, that is, FULL 2.5 KB</li> <li>...</li> <li>62: Full minus 32 KB, that is, FULL 32 KB</li> <li>63: Full minus 32.5 KB, that is, FULL 32.5 KB</li> </ul> <p>The de-assertion is effective only after flow control is asserted.</p> <p>Note: The value must be programmed in such a way to make sure that the threshold is a positive number. When the EHFC is set high, these values are applicable only when the Rx queue size determined by the RQS field of this register, is equal to or greater than 4 KB. For a given queue size, the values ranges between 0 and the encoding for FULL minus (QSIZE - 0.5 KB) and all other values are illegal. Here the term FULL and QSIZE refers to the queue size determined by the RQS field of this register. The width of this field depends on RX FIFO size selected during the configuration. Remaining bits are reserved and read only.</p> |
| 13:12 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11:8  | RW   | 0x0         | <p>RFA<br/>Threshold for Activating Flow Control (in half-duplex and full-duplex)</p> <p>These bits control the threshold (fill-level of Rx queue) at which the flow control is activated:For more information on encoding for this field, see RFD.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7     | RW   | 0x0         | <p>EHFC<br/>Enable Hardware Flow Control</p> <p>When this bit is set, the flow control signal operation, based on the fill-level of Rx queue, is enabled. When reset, the flow control operation is disabled.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Hardware Flow Control is disabled</li> <li>1'b1: Hardware Flow Control is enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6     | RW   | 0x0         | <p>DIS_TCP_EF<br/>Disable Dropping of TCP/IP Checksum Error Packets</p> <p>When this bit is set, the MAC does not drop the packets which only have the errors detected by the Receive Checksum Offload engine. Such packets have errors only in the encapsulated payload. There are no errors (including FCS error) in the Ethernet packet received by the MAC. When this bit is reset, all error packets are dropped if the FEP bit is reset.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Dropping of TCP/IP Checksum Error Packets is enabled</li> <li>1'b1: Dropping of TCP/IP Checksum Error Packets is disabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | <p>RSF<br/>Receive Queue Store and Forward<br/>When this bit is set, the GMAC reads a packet from the Rx queue only after the complete packet has been written to it, ignoring the RTC field of this register. When this bit is reset, the Rx queue operates in the Threshold (cut-through) mode, subject to the threshold specified by the RTC field of this register.</p> <p>Values:<br/>1'b0: Receive Queue Store and Forward is disabled<br/>1'b1: Receive Queue Store and Forward is enabled</p>                                                                                                                                                                                                                                                                                                                                                           |
| 4          | RW          | 0x0                | <p>FEP<br/>Forward Error Packets<br/>When this bit is reset, the Rx queue drops packets with error status (CRC error, GMII_ER, watchdog timeout, or overflow). However, if the start byte (write) pointer of a packet is already transferred to the read controller side (in Threshold mode), the packet is not dropped.</p> <p>When this bit is set, all packets except the runt error packets are forwarded to the application or DMA. If the RSF bit is set and the Rx queue overflows when a partial packet is written, the packet is dropped irrespective of the setting of this bit. However, if the RSF bit is reset and the Rx queue overflows when a partial packet is written, a partial packet may be forwarded to the application or DMA.</p> <p>Values:<br/>1'b0: Forward Error Packets is disabled<br/>1'b1: Forward Error Packets is enabled</p> |
| 3          | RW          | 0x0                | <p>FUP<br/>Forward Undersized Good Packets<br/>When this bit is set, the Rx queue forwards the undersized good packets (packets with no error and length less than 64 bytes), including pad-bytes and CRC. When this bit is reset, the Rx queue drops all packets of less than 64 bytes, unless a packet is already transferred because of the lower value of Rx Threshold, for example, RTC = 01.</p> <p>Values:<br/>1'b0: Forward Undersized Good Packets is disabled<br/>1'b1: Forward Undersized Good Packets is enabled</p>                                                                                                                                                                                                                                                                                                                                |
| 2          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1:0        | RW          | 0x0                | <p>RTC<br/>Receive Queue Threshold Control<br/>These bits control the threshold level of the MTL Rx queue (in bytes): The received packet is transferred to the application or DMA when the packet size within the MTL Rx queue is larger than the threshold. In addition, full packets with length less than the threshold are automatically transferred. This field is valid only when the RSF bit is zero. This field is ignored when the RSF bit is set to 1.</p>                                                                                                                                                                                                                                                                                                                                                                                           |

**GMAC MTL RxQ0 Miss Pkt Ovf Cnt**

Address: Operational Base + offset (0x0D34)

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27    | RO   | 0x0         | MISCNTOVF<br>Missed Packet Counter Overflow Bit<br>When set, this bit indicates that the Rx Queue Missed Packet Counter crossed the maximum limit.<br>Access restriction applies. Clears on read. Self-set to 1 on internal event.<br>Values:<br>1'b0: Missed Packet Counter overflow not detected<br>1'b1: Missed Packet Counter overflow detected                                                                                                                                                                                                                                     |
| 26:16 | RO   | 0x000       | MISPKTCNT<br>Missed Packet Counter<br>This field indicates the number of packets missed by the GMAC because the application asserted ari_pkt_flush_i[] for this queue. This counter is incremented each time the application issues ari_pkt_flush_i[] for this queue. This counter is reset when this register is read with mci_be_i[0] at 1b1. In EQOS-DMA, EQOS-AXI, and EQOS-AHB configurations, This counter is incremented by 1 when the DMA discards the packet because of buffer unavailability.<br>Access restriction applies. Clears on read. Self-set to 1 on internal event. |
| 15:12 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11    | RO   | 0x0         | OVFCNTOVF<br>Overflow Counter Overflow Bit<br>When set, this bit indicates that the Rx Queue Overflow Packet Counter field crossed the maximum limit.<br>Access restriction applies. Clears on read. Self-set to 1 on internal event.<br>Values:<br>1'b0: Overflow Counter overflow not detected<br>1'b1: Overflow Counter overflow detected                                                                                                                                                                                                                                            |
| 10:0  | RO   | 0x000       | OVFPKTCNT<br>Overflow Packet Counter<br>This field indicates the number of packets discarded by the GMAC because of Receive queue overflow. This counter is incremented each time the GMAC discards an incoming packet because of overflow. This counter is reset when this register is read with mci_be_i[0] at 1'b1.<br>Access restriction applies. Clears on read. Self-set to 1 on internal event.                                                                                                                                                                                  |

**GMAC MTL RxQ0 Debug**

Address: Operational Base + offset (0x0D38)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                                                                                                                                                                                            |
| 19:16 | RO   | 0x0         | PRXQ<br>Number of Packets in Receive Queue<br>This field indicates the current number of packets in the Rx Queue. The theoretical maximum value for this field is 256KB/16B = 16K Packets, that is, Max_Queue_Size/Min_Packet_Size. |
| 15:6  | RO   | 0x000       | reserved                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:4        | RO          | 0x0                | <p><b>RXQSTS</b><br/>           MTL Rx Queue Fill-Level Status<br/>           This field gives the status of the fill-level of the Rx Queue:<br/>           Values:<br/>           2'b00: Rx Queue empty<br/>           2'b01: Rx Queue fill-level below flow-control deactivate threshold<br/>           2'b10: Rx Queue fill-level above flow-control activate threshold<br/>           2'b11: Rx Queue full</p>      |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2:1        | RO          | 0x0                | <p><b>RRCSTS</b><br/>           MTL Rx Queue Read Controller State<br/>           This field gives the state of the Rx queue Read controller:<br/>           Values:<br/>           2'b00: Idle state<br/>           2'b01: Reading packet data<br/>           2'b10: Reading packet status (or timestamp)<br/>           2'b11: Flushing the packet data and status</p>                                                |
| 0          | RO          | 0x0                | <p><b>RWCSTS</b><br/>           MTL Rx Queue Write Controller Active Status<br/>           When high, this bit indicates that the MTL Rx queue Write controller is active, and it is transferring a received packet to the Rx Queue.<br/>           Values:<br/>           1'b0: MTL Rx Queue Write Controller Active Status not detected<br/>           1'b1: MTL Rx Queue Write Controller Active Status detected</p> |

**GMAC DMA Mode**

Address: Operational Base + offset (0x1000)

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16 | RW   | 0x0         | <p>INTM<br/>Interrupt Mode<br/>This field defines the interrupt mode of GMAC. The behavior of the following outputs changes depending on the following settings:</p> <ul style="list-style-type: none"> <li>1. sbd_perch_tx_intr_o[] (Transmit Per Channel Interrupt)</li> <li>2. sbd_perch_rx_intr_o[] (Receive Per Channel Interrupt)</li> <li>3. sbd_intr_o (Common Interrupt)</li> </ul> <p>It also changes the behavior of the RI/TI bits in the DMA_CH0_Status.</p> <p>2'b00: sbd_perch_* are pulse signals for each TX/RX packet transfer completion events (irrespective of whether corresponding interrupts are enabled) for which IOC bits are enabled in descriptor. sbd_intr_o is also asserted when corresponding interrupts are enabled and cleared only when software clears the corresponding RI/TI status bits.</p> <p>2'b01: sbd_perch_* are level signals asserted on TX/RX packet transfer completion event when corresponding interrupts are enabled and de-asserted when the software clears the corresponding RI/TI status bits. The sbd_intr_o is not asserted for these TX/RX packet transfer completion events.</p> <p>2'b10: sbd_perch_* are level signals asserted on TX/RX packet transfer completion event when corresponding interrupts are enabled and de-asserted when the software clears the corresponding RI/TI status bits. However, the signal is asserted again if the same event occurred again before it was cleared. The sbd_intr_o is not asserted for these TX/RX packet transfer completion events.</p> <p>2'b11: Reserved</p> <p>Values:</p> <p>2'b00: See above description</p> <p>2'b01: See above description</p> <p>2'b10: See above description</p> <p>2'b11: Reserved</p> |
| 15:9  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8     | RW   | 0x0         | <p>DSPW<br/>Descriptor Posted Write<br/>When this bit is set to 0, the descriptor writes are always non-posted.</p> <p>When this bit is set to 1, the descriptor writes are non-posted only when IOC (Interrupt on completion) is set in last descriptor, otherwise the descriptor writes are always posted.</p> <p>Values:</p> <p>1'b0: Descriptor Posted Write is disabled</p> <p>1'b1: Descriptor Posted Write is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7:1   | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | <p>SWR<br/>Software Reset</p> <p>When this bit is set, the MAC and the DMA controller reset the logic and all internal registers of the DMA, MTL, and MAC. This bit is automatically cleared after the reset operation is complete in all GMAC clock domains. Before reprogramming any GMAC register, a value of zero should be read in this bit. This bit must be read at least 4 CSR clock cycles after it is written to 1.</p> <p>Note: The reset operation is complete only when all resets in all active clock domains are de-asserted. Therefore, it is essential that all PHY inputs clocks (applicable for the selected PHY interface) are present for software reset completion. The time to complete the software reset operation depends on the frequency of the slowest active clock.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Software Reset is disabled</li> <li>1'b1: Software Reset is enabled</li> </ul> |

**GMAC DMA SysBus Mode**

Address: Operational Base + offset (0x1004)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | <p>EN_LPI<br/>Enable Low Power Interface (LPI)</p> <p>When set to 1, this bit enables the LPI mode supported by the EQOS-AXI configuration and accepts the LPI request from the AXI System Clock controller.</p> <p>When set to 0, this bit disables the LPI mode and always denies the LPI request from the AXI System Clock controller.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Low Power Interface (LPI) is disabled</li> <li>1'b1: Low Power Interface (LPI) is enabled</li> </ul>                                 |
| 30    | RW   | 0x0         | <p>LPI_XIT_PKT<br/>Unlock on Magic Packet or Remote Wake-Up Packet</p> <p>When set to 1, this bit enables the AXI master to come out of the LPI mode only when the magic packet or remote wake-up packet is received. When set to 0, this bit enables the AXI master to come out of the LPI mode when any packet is received.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Unlock on Magic Packet or Remote Wake-Up Packet is disabled</li> <li>1'b1: Unlock on Magic Packet or Remote Wake-Up Packet is enabled</li> </ul> |
| 29:26 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 25:24 | RW   | 0x0         | <p>WR_OSR_LMT<br/>AXI Maximum Write Outstanding Request Limit</p> <p>This value limits the maximum outstanding request on the AXI write interface. Maximum outstanding requests = WR_OSR_LMT + 1</p> <p>Note:</p> <ul style="list-style-type: none"> <li>1. Bit 26 is reserved if GMAC_AXI_MAX_WR_REQ = 4</li> <li>2. Bit 27 is reserved if GMAC_AXI_MAX_WR_REQ != 16</li> </ul>                                                                                                                                                               |
| 23:19 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:16      | RW          | 0x1                | <p><b>RD_OSR_LMT</b><br/> AXI Maximum Read Outstanding Request Limit<br/> This value limits the maximum outstanding request on the AXI read interface. Maximum outstanding requests = RD_OSR_LMT + 1</p> <p><b>Note:</b></p> <ol style="list-style-type: none"> <li>1. Bit 18 is reserved if parameter GMAC_AXI_-MAX_RD_REQ = 4</li> <li>2. Bit 19 is reserved if parameter GMAC_AXI_-MAX_RD_REQ!=16</li> </ol>  |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                         |
| 12         | RW          | 0x0                | <p><b>AAL</b><br/> Address-Aligned Beats<br/> When this bit is set to 1, the EQOS-AXI or EQOS-AHB master performs address-aligned burst transfers on Read and Write channels.</p> <p><b>Values:</b></p> <p>1'b0: Address-Aligned Beats is disabled<br/> 1'b1: Address-Aligned Beats is enabled</p>                                                                                                               |
| 11         | RW          | 0x0                | <p><b>EAME</b><br/> Enhanced Address Mode Enable.<br/> When this bit is set to 1, the DMA master enables the enhanced address mode (40-bit or 48-bit addressing mode). In this mode, the DMA engine uses either the 40- or 48-bit address, depending on the configuration.</p> <p><b>Values:</b></p> <p>0x0 (DISABLE): Enhanced Address Mode is disabled<br/> 0x1 (ENABLE): Enhanced Address Mode is enabled</p> |
| 10         | RW          | 0x0                | <p><b>AALE</b><br/> Automatic AXI LPI enable<br/> When set to 1, enables the AXI master to enter into LPI state when there is no activity in the GMAC for number of system clock cycles programmed in the LPIEI field of AXI_LPI_Entry_Interval register.</p> <p><b>Values:</b></p> <p>1'b0: Automatic AXI LPI is disabled<br/> 1'b1: Automatic AXI LPI is enabled</p>                                           |
| 9:4        | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3          | RW          | 0x0                | <p><b>BLEN16</b><br/> AXI Burst Length 16<br/> When this bit is set to 1 or the FB bit is set to 0, the EQOS-AXI master can select a burst length of 16 on the AXI interface. When the FB bit is set to 0, setting this bit has no effect.</p> <p><b>Values:</b></p> <p>1'b0: No effect<br/> 1'b1: AXI Burst Length 16</p>                                                                                       |
| 2          | RW          | 0x0                | <p><b>BLEN8</b><br/> AXI Burst Length 8<br/> When this bit is set to 1 or the FB bit is set to 0, the EQOS-AXI master can select a burst length of 8 on the AXI interface. When the FB bit is set to 0, setting this bit has no effect.</p> <p><b>Values:</b></p> <p>1'b0: No effect<br/> 1'b1: AXI Burst Length 8</p>                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p>BLEN4<br/>AXI Burst Length 4<br/>When this bit is set to 1 or the FB bit is set to 0, the EQOS-AXI master can select a burst length of 4 on the AXI interface. When the FB bit is set to 0, setting this bit has no effect.</p> <p>Values:<br/>1'b0: No effect<br/>1'b1: AXI Burst Length 4</p>                                                                                                                                                                                                                                                                                                                                                  |
| 0          | RW          | 0x0                | <p>FB<br/>Fixed Burst Length<br/>When this bit is set to 1, the EQOS-AXI master initiates burst transfers of specified lengths as given below.</p> <ol style="list-style-type: none"> <li>1. Burst transfers of fixed burst lengths as indicated by the BLEN256, BLEN128, BLEN64, BLEN32, BLEN16, BLEN8, or BLEN4 field</li> <li>2. Burst transfers of length 1</li> </ol> <p>When this bit is set to 0, the EQOS-AXI master initiates burst transfers that are equal to or less than the maximum allowed burst length programmed in Bits[7:1].</p> <p>Values:<br/>1'b0: Fixed Burst Length is disabled<br/>1'b1: Fixed Burst Length is enabled</p> |

**GMAC DMA Interrupt Status**

Address: Operational Base + offset (0x1008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                       |
| 17         | RO          | 0x0                | <p>MACIS<br/>MAC Interrupt Status<br/>This bit indicates an interrupt event in the MAC. To reset this bit to 1'b0, the software must read the corresponding register in the MAC to get the exact cause of the interrupt and clear its source.</p> <p>Values:<br/>1'b0: MAC Interrupt Status not detected<br/>1'b1: MAC Interrupt Status detected</p>                                           |
| 16         | RO          | 0x0                | <p>MTLIS<br/>MTL Interrupt Status<br/>This bit indicates an interrupt event in the MTL. To reset this bit to 1'b0, the software must read the corresponding register in the MTL to get the exact cause of the interrupt and clear its source.</p> <p>Values:<br/>1'b0: MTL Interrupt Status not detected<br/>1'b1: MTL Interrupt Status detected</p>                                           |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                       |
| 0          | RO          | 0x0                | <p>DC0IS<br/>DMA Channel 0 Interrupt Status<br/>This bit indicates an interrupt event in DMA Channel 0. To reset this bit to 1'b0, the software must read the corresponding register in DMA Channel 0 to get the exact cause of the interrupt and clear its source.</p> <p>Values:<br/>1'b0: DMA Channel 0 Interrupt Status not detected<br/>1'b1: DMA Channel 0 Interrupt Status detected</p> |

**GMAC DMA Debug Status0**

Address: Operational Base + offset (0x100C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15:12      | RO          | 0x0                | <p>TPS0<br/>DMA Channel 0 Transmit Process State<br/>This field indicates the Tx DMA FSM state for Channel 0. The MSB of this field always returns 0. This field does not generate an interrupt.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>4'b0000: Stopped (Reset or Stop Transmit Command issued)</li> <li>4'b0001: Running (Fetching Tx Transfer Descriptor)</li> <li>4'b0010: Running (Waiting for status)</li> <li>4'b0011: Running (Reading Data from system memory buffer and queuing it to the Tx buffer (Tx FIFO))</li> <li>4'b0100: Timestamp write state</li> <li>4'b0101: Reserved for future use</li> <li>4'b0110: Suspended (Tx Descriptor Unavailable or Tx Buffer Underflow)</li> <li>4'b0111: Running (Closing Tx Descriptor)</li> </ul> |
| 11:8       | RO          | 0x0                | <p>RPS0<br/>DMA Channel 0 Receive Process State<br/>This field indicates the Rx DMA FSM state for Channel 0. The MSB of this field always returns 0. This field does not generate an interrupt.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>4'b0000: Stopped (Reset or Stop Receive Command issued)</li> <li>4'b0001: Running (Fetching Rx Transfer Descriptor)</li> <li>4'b0010: Reserved for future use</li> <li>4'b0011: Running (Waiting for Rx packet)</li> <li>4'b0100: Suspended (Rx Descriptor Unavailable)</li> <li>4'b0101: Running (Closing the Rx Descriptor)</li> <li>4'b0110: Timestamp write state</li> <li>4'b0111: Running (Transferring the received packet data from the Rx buffer to the system memory)</li> </ul>                      |
| 7:2        | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1          | RO          | 0x0                | <p>AXRHSTS<br/>AXI Master Read Channel Status<br/>When high, this bit indicates that the read channel of the AXI master is active, and it is transferring the data.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: AXI Master Read Channel Status not detected</li> <li>1'b1: AXI Master Read Channel Status detected</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0          | RO          | 0x0                | <p>AXWHSTS<br/>AXI Master Write Channel or AHB Master Status<br/>EQOS-AXI Configuration:<br/>When high, this bit indicates that the write channel of the AXI master is active, and it is transferring data.<br/>EQOS-AHB Configuration:<br/>When high, this bit indicates that the AHB master FSMs are in the non-idle state.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: AXI Master Write Channel or AHB Master Status not detected</li> <li>1'b1: AXI Master Write Channel or AHB Master Status detected</li> </ul>                                                                                                                                                                                                                                 |

**GMAC AXI LPI Entry Interval**

Address: Operational Base + offset (0x1040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                             |
| 3:0        | RW          | 0x0                | LPIEI<br>LPI Entry Interval<br>Contains the number of system clock cycles, multiplied by 64, to wait for an activity in the GMAC to enter into the AXI low power state. 0 indicates 64 clock cycles. |

**GMAC DMA CH0 Control**

Address: Operational Base + offset (0x1100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 24         | RW          | 0x0                | SPH<br>Split Headers<br>When this bit is set, the DMA splits the header and payload in the Receive path. The DMA writes the header to the Buffer Address1 of RDES0. The DMA writes the payload to the buffer to which the Buffer Address2 is pointing.<br>The software must ensure that the header fits into the Receive buffers. If the header length exceeds the receive buffer size, the DMA does not split the header and payload.<br>This bit is available only if Enable Split Header Structure option is selected.<br>Values:<br>0x0 (DISABLE): Split Headers feature is disabled<br>0x1 (ENABLE): Split Headers feature is enabled |
| 23:21      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 20:18      | RW          | 0x0                | DSL<br>Descriptor Skip Length<br>This bit specifies the Word, Dword, or Lword number (depending on the 32-bit, 64-bit, or 128-bit bus) to skip between two unchained descriptors. The address skipping starts from the end of the current descriptor to the start of the next descriptor.<br>When the DSL value is equal to zero, the DMA takes the descriptor table as contiguous.                                                                                                                                                                                                                                                        |
| 17         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 16         | RW          | 0x0                | PBLx8<br>8xPBL mode<br>When this bit is set, the PBL value programmed in Bits[21:16] in DMA_CH0_Tx_Control and Bits[21:16] in DMA_CH0_Rx_Control is multiplied by eight times. Therefore, the DMA transfers the data in 8, 16, 32, 64, 128, and 256 beats depending on the PBL value.<br>0x0 (DISABLE): 8xPBL mode is disabled<br>0x1 (ENABLE): 8xPBL mode is enabled                                                                                                                                                                                                                                                                      |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13:0       | RW          | 0x0000             | MSS<br>Maximum Segment Size<br>This field specifies the maximum segment size that should be used while segmenting the packet. This field is valid only if the TSE bit of DMA_CH0_Tx_Control register is set.<br>The value programmed in this field must be more than the configured Datawidth in bytes. It is recommended to use a MSS value of 64 bytes or more.                                                                                                                                                                                                                                                                          |

**GMAC DMA CH0 Tx Control**

Address: Operational Base + offset (0x1104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 21:16      | RW          | 0x00               | <p><b>TxPBL</b><br/>         Transmit Programmable Burst Length<br/>         These bits indicate the maximum number of beats to be transferred in one DMA block data transfer. The DMA always attempts max burst as specified in PBL each time it starts a burst transfer on the application bus. You can program PBL with any of the following values: 1, 2, 4, 8, 16, or 32. Any other value results in undefined behavior.</p> <p>To transfer more than 32 beats, perform the following steps:</p> <ol style="list-style-type: none"> <li>1. Set the 8xPBL mode in DMA_CH0_Control register.</li> <li>2. Set the TxPBL.</li> </ol> <p>Note: The maximum value of TxPBL must be less than or equal to half the Tx Queue size (TQS field of MTL_TxQ[n]_Operation_Mode register) in terms of beats. This is required so that the Tx Queue has space to store at least another Tx PBL worth of data while the MTL Tx Queue Controller is transferring data to MAC. For example, in 64-bit data width configurations the total locations in Tx Queue of size 512 bytes is 64, TxPBL and 8xPBL needs to be programmed to less than or equal to 32.</p> |
| 15         | RW          | 0x0                | <p><b>IPBL</b><br/> <b>Ignore PBL Requirement</b><br/>         When this bit is set, the DMA does not check for PBL number of locations in the MTL before initiating a transfer. If space is not available, the MTL may use handshaking to slow the DMA.</p> <p>Note: This bit/mode must not be used when multiple Transmit DMA Channels are enabled as it may block other Transmit and Receive DMA Channels from accessing the Read Data Channel of AXI bus until space is available in Transmit Queue for current transfer.</p> <p>0x0 (DISABLE): Ignore PBL Requirement is disabled<br/>         0x1 (ENABLE): Ignore PBL Requirement is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 14:13      | RW          | 0x0                | <p><b>TSE_MODE</b><br/> <b>TSE Mode</b><br/>         00: TSO/USO (segmentation functionality is enabled). In this mode, the setting of TSE bit enables the TSO/USO segmentation.<br/>         01: UFO with Checksum (UDP Fragmentation over IPv4 with Checksum). In this mode, the setting of TSE bit enables the UDP fragmentation functionality with Checksum for all the UDP packets.<br/>         10: UFO without Checksum (UDP Fragmentation over IPv4 with Checksum). In this mode, the setting of TSE bit enables the UDP fragmentation functionality without Checksum for all the UDP packets.<br/>         11: Reserved</p> <p>0x0 (TSO_USO): TSO/USO<br/>         0x1 (UFOWC): UFO with Checksum<br/>         0x2 (UFOWOC): UFO without Checksum<br/>         0x3 (RSVD): Reserved</p>                                                                                                                                                                                                                                                                                                                                                    |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RW   | 0x0         | <p>TSE<br/>TCP Segmentation Enabled<br/>When this bit is set, the DMA performs the TCP segmentation or UDP Segmentation/Fragmentation for packets in this channel.<br/>The TCP segmentation or UDP packet's segmentation/Fragmentation is done only for those packets for which the TSE bit (TDES0[19]) is set in the Tx Normal descriptor. When this bit is set, the TxPBL value must be greater than 4.<br/>0x0 (DISABLE): TCP Segmentation is disabled<br/>0x1 (ENABLE): TCP Segmentation is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11:5 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4    | RW   | 0x0         | <p>OSF<br/>Operate on Second Packet<br/>When this bit is set, it instructs the DMA to process the second packet of the Transmit data even before the status for the first packet is obtained.<br/>0x0 (DISABLE): Operate on Second Packet disabled<br/>0x1 (ENABLE): Operate on Second Packet enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3:1  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0    | RW   | 0x0         | <p>ST<br/>Start or Stop Transmission Command<br/>When this bit is set, transmission is placed in the Running state. The DMA checks the Transmit list at the current position for a packet to be transmitted.<br/>The DMA tries to acquire descriptor from either of the following positions:<br/>1. The current position in the list<br/>This is the base address of the Transmit list set by the DMA_CH0_TxDesc_List_Address register.<br/>2. The position at which the transmission was previously stopped<br/><br/>If the DMA does not own the current descriptor, the transmission enters the Suspended state and the TBU bit of the DMA_CH0_Status register is set. The Start Transmission command is effective only when the transmission is stopped. If the command is issued before setting the DMA_CH0_TxDesc_List_Address register, the DMA behavior is unpredictable.<br/>When this bit is reset, the transmission process is placed in the Stopped state after completing the transmission of the current packet. The Next Descriptor position in the Transmit list is saved, and it becomes the current position when the transmission is restarted. To change the list address, you need to program DMA_CH0_TxDesc_List_Address register with a new value when this bit is reset. The new value is considered when this bit is set again. The stop transmission command is effective only when the transmission of the current packet is complete or the transmission is in the Suspended state.<br/>0x0 (STOP): Stop Transmission Command<br/>0x1 (START): Start Transmission Command</p> |

**GMAC DMA CH0 Rx Control**

Address: Operational Base + offset (0x1108)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | <p>RPF<br/>Rx Packet Flush</p> <p>When this bit is set to 1, then GMAC automatically flushes the packet from the Rx Queues destined to this DMA Rx Channel, when it is stopped. When this bit remains set and the DMA is re-started by the software driver, the packets residing in the Rx Queues that were received when this RxDMA was stopped, get flushed out. The packets that are received by the MAC after the RxDMA is re-started are routed to the RxDMA. The flushing happens on the Read side of the Rx Queue.</p> <p>When this bit is set to 0, the GMAC does not flush the packet in the Rx Queue destined to this RxDMA Channel when it is STOP state. This may in turn cause head-of-line blocking in the corresponding RxQueue.</p> <p>0x0 (DISABLE): Rx Packet Flush is disabled<br/>0x1 (ENABLE): Rx Packet Flush is enabled</p>                                                                                                                                                                                                                                                                     |
| 30:22 | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 21:16 | RW   | 0x00        | <p>RxPBL<br/>Receive Programmable Burst Length</p> <p>These bits indicate the maximum number of beats to be transferred in one DMA block data transfer. The DMA always attempts max burst as specified in PBL each time it starts a burst transfer on the application bus. You can program PBL with any of the following values: 1, 2, 4, 8, 16, or 32. Any other value results in undefined behavior.</p> <p>To transfer more than 32 beats, perform the following steps:</p> <ol style="list-style-type: none"> <li>1. Set the 8xPBL mode in the DMA_CH0_Control register.</li> <li>2. Set the RxPBL.</li> </ol> <p>Note: The maximum value of RxPBL must be less than or equal to half the Rx Queue size (RQS field of MTL_RxQ[n]_Operation_Mode register) in terms of beats. This is required so that the Rx Queue has space to store at least another Rx PBL worth of data while the Rx DMA is transferring a block of data. For example, in 64-bit data width configurations the total locations in Rx Queue of size 512 bytes is 64, so RxPBL and 8xPBL needs to be programmed to less than or equal to 32.</p> |
| 15    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 14:4  | RW   | 0x000       | <p>RBSZ_13_y<br/>Receive Buffer size High</p> <p>RBSZ[13:0] is split into two fields higher RBSZ_13_y and lower RBSZ_3_0. The RBSZ[13:0] field indicates the size of the Rx buffers specified in bytes. The maximum buffer size is limited to 16K bytes. The buffer size is applicable to payload buffers when split headers are enabled.</p> <p>Note: The buffer size must be a multiple of 4, 8, or 16 depending on the data bus widths (32-bit, 64-bit, or 128-bit respectively). This is required even if the value of buffer address pointer is not aligned to data bus width. Hence the lower RBSZ_3_0 bits are read-only and the value is considered as all-zero. Thus the RBSZ_13_y indicates the buffer size in terms of locations (with the width same as bus-width).</p>                                                                                                                                                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1        | RO          | 0x0                | <p>RBSZ_3_0<br/>Receive Buffer size Low<br/>RBSZ[13:0] is split into two fields RBSZ_13_y and RBSZ_3_0. The RBSZ_3_0 is the lower field whose width is based on data bus width of the configuration.<br/>This field is of width 2, 3, or 4 bits for 32-bit, 64-bit, or 128-bit data bus width respectively. This field is read-only (RO)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0          | RW          | 0x0                | <p>SR<br/>Start or Stop Receive<br/>When this bit is set, the DMA tries to acquire the descriptor from the Receive list and processes the incoming packets. The DMA tries to acquire descriptor from either of the following positions:<br/>1. The current position in the list<br/>This is the address set by the DMA_CH0_RxDesc_List_Address register.<br/>2. The position at which the Rx process was previously stopped<br/>If the DMA does not own the current descriptor, the reception is suspended and the RBU bit of the DMA_CH0_Status register is set. The Start Receive command is effective only when the reception is stopped. If the command is issued before setting the DMA_CH0_RxDesc_List_Address register, the DMA behavior is unpredictable.<br/>When this bit is reset, the Rx DMA operation is stopped after the transfer of the current packet. The next descriptor position in the Receive list is saved, and it becomes the current position after the Rx process is restarted. The Stop Receive command is effective only when the Rx process is in the Running (waiting for Rx packet) or Suspended state.<br/>0x0 (STOP): Stop Receive<br/>0x1 (START): Start Receive</p> |

**GMAC DMA CH0 TxDesc List HAddress**

Address: Operational Base + offset (0x1110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                      |
| 7:0        | RW          | 0x00               | <p>TDESHA<br/>Start of Transmit List<br/>This field contains the most-significant 8 or 16 bits of the 40- or 48-bit base address of the first descriptor in the Transmit descriptor list.</p> |

**GMAC DMA CH0 TxDesc List Address**

Address: Operational Base + offset (0x1114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RW          | 0x00000000         | <p>TDESLA<br/>Start of Transmit List<br/>This field contains the base address of the first descriptor in the Transmit descriptor list. The DMA ignores the LSB bits (1:0, 2:0, or 3:0) for 32-bit, 64-bit, or 128-bit bus width and internally takes these bits as all-zero. Therefore, these LSB bits are read-only (RO).<br/>The width of this field depends on the configuration:<br/>31:2 for 32-bit configuration<br/>31:3 for 64-bit configuration<br/>31:4 for 128-bit configuration</p> |
| 2:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**GMAC DMA CH0 RxDesc List HAaddress**

Address: Operational Base + offset (0x1118)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                         |
| 7:0  | RW   | 0x00        | RDESHA<br>Start of Receive List<br>This field contains the most-significant 8 or 16 bits of the 40-bit or 48-bit base address of the first descriptor in the Rx Descriptor list. |

**GMAC DMA CH0 RxDesc List Address**

Address: Operational Base + offset (0x111C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | RW   | 0x000000000 | RDESLA<br>Start of Receive List<br>This field contains the base address of the first descriptor in the Rx Descriptor list. The DMA ignores the LSB bits (1:0, 2:0, or 3:0) for 32-bit, 64-bit, or 128-bit bus width and internally takes these bits as all-zero. Therefore, these LSB bits are read-only (RO).<br>The width of this field depends on the configuration:<br>31:2 for 32-bit configuration<br>31:3 for 64-bit configuration<br>31:4 for 128-bit configuration |
| 2:0  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**GMAC DMA CH0 TxDesc Tail Pointer**

Address: Operational Base + offset (0x1120)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | RW   | 0x000000000 | TDTP<br>Transmit Descriptor Tail Pointer<br>This field contains the tail pointer for the Tx descriptor ring. The software writes the tail pointer to add more descriptors to the Tx channel. The hardware tries to transmit all packets referenced by the descriptors between the head and the tail pointer registers.<br>The width of this field depends on the configuration:<br>31:2 for 32-bit configuration<br>31:3 for 64-bit configuration<br>31:4 for 128-bit configuration |
| 2:0  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**GMAC DMA CH0 RxDesc Tail Pointer**

Address: Operational Base + offset (0x1128)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | RW   | 0x000000000 | RDRT<br>Receive Descriptor Tail Pointer<br>This field contains the tail pointer for the Rx descriptor ring. The software writes the tail pointer to add more descriptors to the Rx channel. The hardware tries to write all received packets to the descriptors referenced between the head and the tail pointer registers.<br>The width of this field depends on the configuration:<br>31:2 for 32-bit configuration<br>31:3 for 64-bit configuration<br>31:4 for 128-bit configuration |

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

**GMAC DMA CH0 TxDesc Ring Length**

Address: Operational Base + offset (0x112C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 9:0        | RW          | 0x000              | TDRL<br>Transmit Descriptor Ring Length<br>This field sets the maximum number of Tx descriptors in the circular descriptor ring. The maximum number of descriptors is limited to 1K descriptors. we recommends a minimum ring descriptor length of 4. For example, You can program any value up to 0x3FF in this field. This field is 10 bits wide, if you program 0x3FF, you can have 1024 descriptors. If you want to have 10 descriptors, program it to a value of 0x9. |

**GMAC DMA CH0 RxDesc Ring Length**

Address: Operational Base + offset (0x1130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9:0        | RW          | 0x000              | RDRL<br>Receive Descriptor Ring Length<br>This register sets the maximum number of Rx descriptors in the circular descriptor ring. The maximum number of descriptors is limited to 1K descriptors. For example, You can program any value up to 0x3FF in this field. This field is 10 bits wide, if you program 0x3FF, you can have 1024 descriptors. If you want to have 10 descriptors, program it to a value of 0x9. |

**GMAC DMA CH0 Interrupt Enable**

Address: Operational Base + offset (0x1134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15         | RW          | 0x0                | NIE<br>Normal Interrupt Summary Enable<br>When this bit is set, the normal interrupt summary is enabled. This bit enables the following interrupts in the DMA_CH0_Status register:<br>Bit 0: Transmit Interrupt<br>Bit 2: Transmit Buffer Unavailable<br>Bit 6: Receive Interrupt<br>Bit 11: Early Receive Interrupt<br>When this bit is reset, the normal interrupt summary is disabled.<br>0x0 (DISABLE): Normal Interrupt Summary is disabled<br>0x1 (ENABLE): Normal Interrupt Summary is enabled |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | <p>AIE<br/>Abnormal Interrupt Summary Enable<br/>When this bit is set, the abnormal interrupt summary is enabled.<br/>This bit enables the following interrupts in the DMA_CH0_Status register:</p> <ul style="list-style-type: none"> <li>Bit 1: Transmit Process Stopped</li> <li>Bit 7: Rx Buffer Unavailable</li> <li>Bit 8: Receive Process Stopped</li> <li>Bit 9: Receive Watchdog Timeout</li> <li>Bit 10: Early Transmit Interrupt</li> <li>Bit 12: Fatal Bus Error</li> <li>Bit 13: Context Descriptor Error</li> </ul> <p>When this bit is reset, the abnormal interrupt summary is disabled.</p> <p>0x0 (DISABLE): Abnormal Interrupt Summary is disabled<br/>0x1 (ENABLE): Abnormal Interrupt Summary is enabled</p> |
| 13         | RW          | 0x0                | <p>CDEE<br/>Context Descriptor Error Enable<br/>When this bit is set along with the AIE bit, the Descriptor error interrupt is enabled. When this bit is reset, the Descriptor error interrupt is disabled.</p> <p>0x0 (DISABLE): Context Descriptor Error is disabled<br/>0x1 (ENABLE): Context Descriptor Error is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                  |
| 12         | RW          | 0x0                | <p>FBEE<br/>Fatal Bus Error Enable<br/>When this bit is set along with the AIE bit, the Fatal Bus error interrupt is enabled. When this bit is reset, the Fatal Bus Error error interrupt is disabled.</p> <p>0x0 (DISABLE): Fatal Bus Error is disabled<br/>0x1 (ENABLE): Fatal Bus Error is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11         | RW          | 0x0                | <p>ERIE<br/>Early Receive Interrupt Enable<br/>When this bit is set along with the NIE bit, the Early Receive interrupt is enabled. When this bit is reset, the Early Receive interrupt is disabled.</p> <p>0x0 (DISABLE): Early Receive Interrupt is disabled<br/>0x1 (ENABLE): Early Receive Interrupt is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10         | RW          | 0x0                | <p>ETIE<br/>Early Transmit Interrupt Enable<br/>When this bit is set along with the AIE bit, the Early Transmit interrupt is enabled. When this bit is reset, the Early Transmit interrupt is disabled.</p> <p>0x0 (DISABLE): Early Transmit Interrupt is disabled<br/>0x1 (ENABLE): Early Transmit Interrupt is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                      |
| 9          | RW          | 0x0                | <p>RWTE<br/>Receive Watchdog Timeout Enable<br/>When this bit is set along with the AIE bit, the Receive Watchdog Timeout interrupt is enabled. When this bit is reset, the Receive Watchdog Timeout interrupt is disabled.</p> <p>0x0 (DISABLE): Receive Watchdog Timeout is disabled<br/>0x1 (ENABLE): Receive Watchdog Timeout is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                  |
| 8          | RW          | 0x0                | <p>RSE<br/>Receive Stopped Enable<br/>When this bit is set along with the AIE bit, the Receive Stopped Interrupt is enabled. When this bit is reset, the Receive Stopped interrupt is disabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RW   | 0x0         | RBUE<br>Receive Buffer Unavailable Enable<br>When this bit is set along with the AIE bit, the Receive Buffer Unavailable interrupt is enabled. When this bit is reset, the Receive Buffer Unavailable interrupt is disabled.<br>0x0 (DISABLE): Receive Buffer Unavailable is disabled<br>0x1 (ENABLE): Receive Buffer Unavailable is enabled      |
| 6   | RW   | 0x0         | RIE<br>Receive Interrupt Enable<br>When this bit is set along with the NIE bit, the Receive Interrupt is enabled. When this bit is reset, the Receive Interrupt is disabled.<br>0x0 (DISABLE): Receive Interrupt is disabled<br>0x1 (ENABLE): Receive Interrupt is enabled                                                                        |
| 5:3 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                          |
| 2   | RW   | 0x0         | TBUE<br>Transmit Buffer Unavailable Enable<br>When this bit is set along with the NIE bit, the Transmit Buffer Unavailable interrupt is enabled. When this bit is reset, the Transmit Buffer Unavailable interrupt is disabled.<br>0x0 (DISABLE): Transmit Buffer Unavailable is disabled<br>0x1 (ENABLE): Transmit Buffer Unavailable is enabled |
| 1   | RW   | 0x0         | TXSE<br>Transmit Stopped Enable<br>When this bit is set along with the AIE bit, the Transmission Stopped interrupt is enabled. When this bit is reset, the Transmission Stopped interrupt is disabled.<br>0x0 (DISABLE): Transmit Stopped is disabled<br>0x1 (ENABLE): Transmit Stopped is enabled                                                |
| 0   | RW   | 0x0         | TIE<br>Transmit Interrupt Enable<br>When this bit is set along with the NIE bit, the Transmit Interrupt is enabled. When this bit is reset, the Transmit Interrupt is disabled.<br>0x0 (DISABLE): Transmit Interrupt is disabled<br>0x1 (ENABLE): Transmit Interrupt is enabled                                                                   |

**GMAC DMA CH0 Rx Interrupt Watchdog Timer**

Address: Operational Base + offset (0x1138)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                         |
| 17:16 | RW   | 0x0         | RWTU<br>Receive Interrupt Watchdog Timer Count Units<br>This field indicates the number of system clock cycles corresponding to one unit in RWT field.<br>2'b00: 256<br>2'b01: 512<br>2'b10: 1024<br>2'b11: 2048<br>For example, when RWT=2 and RWTU=1, the watchdog timer is set for $2 \times 512 = 1024$ system clock cycles. |
| 15:8  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                         |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | RW   | 0x00        | <p>RWT<br/>Receive Interrupt Watchdog Timer Count<br/>This field indicates the number of system clock cycles, multiplied by factor indicated in RWTU field, for which the watchdog timer is set.</p> <p>The watchdog timer is triggered with the programmed value after the Rx DMA completes the transfer of a packet for which the RI bit is not set in the DMA_CH0_Status register, because of the setting of Interrupt Enable bit in the corresponding descriptor RDES3[30].</p> <p>When the watchdog timer runs out, the RI bit is set and the timer is stopped. The watchdog timer is reset when the RI bit is set high because of automatic setting of RI as per the Interrupt Enable bit RDES3[30] of any received packet.</p> |

**GMAC DMA CH0 Current App TxDesc**

Address: Operational Base + offset (0x1144)

| Bit  | Attr | Reset Value | Description                                                                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>CURTDESAPTR<br/>Application Transmit Descriptor Address Pointer<br/>The DMA updates this pointer during Tx operation. This pointer is cleared on reset.</p> |

**GMAC DMA CH0 Current App RxDesc**

Address: Operational Base + offset (0x114C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                   |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>CURRDESAPTR<br/>Application Receive Descriptor Address Pointer<br/>The DMA updates this pointer during Rx operation. This pointer is cleared on reset.</p> |

**GMAC DMA CH0 Curren App TxBuffer H**

Address: Operational Base + offset (0x1150)

| Bit  | Attr | Reset Value | Description                                                                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                                                                    |
| 7:0  | RO   | 0x00        | <p>CURTBUFAPTRH<br/>Application Transmit Buffer Address Pointer<br/>The DMA updates this pointer during Tx operation. This pointer is cleared on reset.</p> |

**GMAC DMA CH0 Current App TxBuffer**

Address: Operational Base + offset (0x1154)

| Bit  | Attr | Reset Value | Description                                                                                                                                                |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | <p>CURTBUFAPTR<br/>Application Transmit Buffer Address Pointer<br/>The DMA updates this pointer during Tx operation. This pointer is cleared on reset.</p> |

**GMAC DMA CH0 Current App RxBuffer H**

Address: Operational Base + offset (0x1158)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x00000000  | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | RO          | 0x00               | CURRBUFAPTRH<br>Application Receive Buffer Address Pointer<br>The DMA updates this pointer during Rx operation. This pointer is cleared on reset. |

**GMAC DMA CH0 Current App RxBuffer**

Address: Operational Base + offset (0x115C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | CURRBUFAPTR<br>Application Receive Buffer Address Pointer<br>The DMA updates this pointer during Rx operation. This pointer is cleared on reset. |

**GMAC DMA CH0 Status**

Address: Operational Base + offset (0x1160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 21:19      | RO          | 0x0                | REB<br>Rx DMA Error Bits<br>This field indicates the type of error that caused a Bus Error.<br>For example, error response on the AHB or AXI interface.<br>1.Bit 21<br>1'b1: Error during data transfer by Rx DMA<br>1'b0: No Error during data transfer by Rx DMA<br>2.Bit 20<br>1'b1: Error during descriptor access<br>1'b0: Error during data buffer access<br>3.Bit 19<br>1'b1: Error during read transfer<br>1'b0: Error during write transfer<br>This field is valid only when the FBE bit is set. This field does not generate an interrupt. |
| 18:16      | RO          | 0x0                | TEB<br>Tx DMA Error Bits<br>This field indicates the type of error that caused a Bus Error.<br>For example, error response on the AHB or AXI interface.<br>1.Bit 18<br>1'b1: Error during data transfer by Tx DMA<br>1'b0: No Error during data transfer by Tx DMA<br>2.Bit 17<br>1'b1: Error during descriptor access<br>1'b0: Error during data buffer access<br>3.Bit 16<br>1'b1: Error during read transfer<br>1'b0: Error during write transfer<br>This field is valid only when the FBE bit is set. This field does not generate an interrupt. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | <p>NIS<br/>Normal Interrupt Summary<br/>Normal Interrupt Summary bit value is the logical OR of the following bits when the corresponding interrupt bits are enabled in the DMA_CH0_Interrupt_Enable register:</p> <ul style="list-style-type: none"> <li>Bit 0: Transmit Interrupt</li> <li>Bit 2: Transmit Buffer Unavailable</li> <li>Bit 6: Receive Interrupt</li> <li>Bit 11: Early Receive Interrupt</li> </ul> <p>Only unmasked bits (interrupts for which interrupt enable is set in DMA_CH0_Interrupt_Enable register) affect the Normal Interrupt Summary bit.</p> <p>This is a sticky bit. You must clear this bit (by writing 1 to this bit) each time a corresponding bit which causes NIS to be set is cleared.</p> <p>Access restriction applies. Self-set to 1 on internal event.<br/>Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Normal Interrupt Summary status not detected<br/>0x1 (ACTIVE): Normal Interrupt Summary status detected</p>  |
| 14         | RW          | 0x0                | <p>AIS<br/>Abnormal Interrupt Summary<br/>Abnormal Interrupt Summary bit value is the logical OR of the following when the corresponding interrupt bits are enabled in the DMA_CH0_Interrupt_Enable register:</p> <ul style="list-style-type: none"> <li>Bit 1: Transmit Process Stopped</li> <li>Bit 7: Receive Buffer Unavailable</li> <li>Bit 8: Receive Process Stopped</li> <li>Bit 10: Early Transmit Interrupt</li> <li>Bit 12: Fatal Bus Error</li> <li>Bit 13: Context Descriptor Error</li> </ul> <p>Only unmasked bits affect the Abnormal Interrupt Summary bit.</p> <p>This is a sticky bit. You must clear this bit (by writing 1 to this bit) each time a corresponding bit, which causes AIS to be set, is cleared.</p> <p>Access restriction applies. Self-set to 1 on internal event.<br/>Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Abnormal Interrupt Summary status not detected<br/>0x1 (ACTIVE): Abnormal Interrupt Summary status</p> |
| 13         | RW          | 0x0                | <p>CDE<br/>Context Descriptor Error<br/>This bit indicates that the DMA Tx/Rx engine received a descriptor error, which indicates invalid context in the middle of packet flow ( intermediate descriptor) or all one's descriptor in Tx case and on Rx side it indicates DMA has read a descriptor with either of the buffer address as ones which is considered to be invalid.</p> <p>Access restriction applies. Self-set to 1 on internal event.<br/>Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Context Descriptor Error status not detected<br/>0x1 (ACTIVE): Context Descriptor Error status detected</p>                                                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | <p>FBE<br/>Fatal Bus Error</p> <p>This bit indicates that a bus error occurred (as described in the EB field). When this bit is set, the corresponding DMA channel engine disables all bus accesses.</p> <p>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Fatal Bus Error status not detected<br/>0x1 (ACTIVE): Fatal Bus Error status detected</p>                                                                                                                                                                                                                                                       |
| 11         | RW          | 0x0                | <p>ERI<br/>Early Receive Interrupt</p> <p>This bit when set indicates that the RxDMA has completed the transfer of packet data to the memory. In configs supporting ERIC, When ERIC=0, this bit is set only after the Rx DMA has filled up a complete receive buffer with packet data. When ERIC=1, this bit is set after every burst transfer of data from the Rx DMA to the buffer. The setting of RI bit automatically clears this bit.</p> <p>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Early Receive Interrupt status not detected<br/>0x1 (ACTIVE): Early Receive Interrupt status detected</p> |
| 10         | RW          | 0x0                | <p>ETI<br/>Early Transmit Interrupt</p> <p>This bit when set indicates that the TxDMA has completed the transfer of packet data to the MTL TXFIFO memory. In configs supporting ERIC: When ETIC=0, this bit is set only after the Tx DMA has transferred a complete packet to MTL.</p> <p>When ETIC=1, this bit is set after completion of (partial) packet data transfer from buffers in the Transmit descriptor in which IOC=1.</p> <p>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Early Transmit Interrupt status not detected<br/>0x1 (ACTIVE): Early Transmit Interrupt status detected</p>        |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8          | RW          | 0x0                | <p>RPS<br/>Receive Process Stopped</p> <p>This bit is asserted when the Rx process enters the Stopped state.</p> <p>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Receive Process Stopped status not detected<br/>0x1 (ACTIVE): Receive Process Stopped status detected</p>                                                                                                                                                                                                                                                                                                                               |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RW   | 0x0         | <p>RBU<br/>Receive Buffer Unavailable<br/>This bit indicates that the application owns the next descriptor in the Receive list, and the DMA cannot acquire it. The Rx process is suspended. To resume processing Rx descriptors, the application should change the ownership of the descriptor and issue a Receive Poll Demand command. If this command is not issued, the Rx process resumes when the next recognized incoming packet is received. In ring mode, the application should advance the Receive Descriptor Tail Pointer register of a channel. This bit is set only when the DMA owns the previous Rx descriptor.<br/>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Receive Buffer Unavailable status not detected<br/>0x1 (ACTIVE): Receive Buffer Unavailable status detected</p>                    |
| 6   | RW   | 0x0         | <p>RI<br/>Receive Interrupt<br/>This bit indicates that the packet reception is complete. When packet reception is complete, Bit 31 of RDES3 is reset in the last descriptor, and the specific packet status information is updated in the descriptor.<br/>The reception remains in the Running state.<br/>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Receive Interrupt status not detected<br/>0x1 (ACTIVE): Receive Interrupt status detected</p>                                                                                                                                                                                                                                                                                                                                                              |
| 5:3 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2   | RW   | 0x0         | <p>TBU<br/>Transmit Buffer Unavailable<br/>This bit indicates that the application owns the next descriptor in the Transmit list, and the DMA cannot acquire it.<br/>Transmission is suspended. The TPS0 field of the DMA_Debug_Status0 register explains the Transmit Process state transitions.<br/>To resume processing the Transmit descriptors, the application should do the following:<br/>           1. Change the ownership of the descriptor by setting Bit 31 of TDES3.<br/>           2. Issue a Transmit Poll Demand command.<br/>For ring mode, the application should advance the Transmit Descriptor Tail Pointer register of a channel. Access restriction applies. Self-set to 1 on internal event.<br/>Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Transmit Buffer Unavailable status not detected<br/>0x1 (ACTIVE): Transmit Buffer Unavailable status</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p>TPS<br/>Transmit Process Stopped<br/>This bit is set when the transmission is stopped.<br/>Access restriction applies. Self-set to 1 on internal event.<br/>Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Transmit Process Stopped status not detected<br/>0x1 (ACTIVE): Transmit Process Stopped status detected</p>                                                                                                                                                      |
| 0          | RW          | 0x0                | <p>TI<br/>Transmit Interrupt<br/>This bit indicates that the packet transmission is complete.<br/>When transmission is complete, Bit 31 of TDES3 is reset in the last descriptor, and the specific packet status information is updated in the descriptor.<br/>Access restriction applies. Self-set to 1 on internal event.<br/>Setting 1 clears. Setting 0 has no effect.</p> <p>0x0 (INACTIVE): Transmit Interrupt status not detected<br/>0x1 (ACTIVE): Transmit Interrupt status detected</p> |

**GMAC DMA CH0 Miss Frame Cnt**

Address: Operational Base + offset (0x1164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                    |
| 15         | RO          | 0x0                | <p>MFC0<br/>Overflow status of the MFC Counter<br/>When this bit is set then the MFC counter does not get incremented further. The bit gets cleared when this register is read.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>0x0 (INACTIVE): Miss Frame Counter overflow not occurred<br/>0x1 (ACTIVE): Miss Frame Counter overflow occurred</p> |
| 14:11      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                    |
| 10:0       | RO          | 0x000              | <p>MFC<br/>Dropped Packet Counters<br/>This counter indicates the number of packet counters that are dropped by the DMA either because of bus error or because of programming RPF field in DMA_CH0_Rx_Control register.<br/>The counter gets cleared when this register is read.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p>                       |

**GMAC DMA CH0 RX ERI Cnt**

Address: Operational Base + offset (0x1168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                           |
| 0          | RO          | 0x0                | <p>ECNT<br/>ERI Counter<br/>When ERIC bit of DMA_CH0_RX_Control register is set, this counter increments for burst transfer completed by the Rx DMA from the start of packet transfer. This counter will get reset at the start of new packet.</p> |

## 19.5 Application Note

### 19.5.1 Descriptors

The DMA engine uses descriptors to efficiently move data from source to destination with minimal application CPU intervention. The DMA is designed for packet-oriented data transfers such as packets in Ethernet. The DMA controller can be programmed to interrupt the application CPU for situations such as Packet Transmit and Receive Transfer completion, and other normal or error conditions.

The DMA and the application communicate through the following two data structures:

- Control and Status registers (CSR)
- Descriptor lists and data buffers

The base address of each list is written to the respective Tx Descriptor List Address register and Rx Descriptor List Address register. The descriptor list is forward linked and the next descriptor is always considered at a fixed offset to the current one. The offset is controlled by the DSL field of DMA\_Ch[n]\_Control register. The number of descriptors in the list is programmed in the respective Tx (or Rx) Descriptor Ring Length register. Once the DMA processes the last descriptor in the list, it automatically jumps back to the descriptor in the List Address register to create a descriptor ring.

The descriptor lists reside in the physical memory address space of the application. Each descriptor can point to a maximum of two buffers in the system memory. This enables two buffers to be used, physically addressed, rather than contiguous buffers in memory.

A data buffer resides in the application physical memory space and consists of an entire packet or part of a packet but cannot exceed a single packet. Buffers contain only data. Buffer status is maintained in the descriptor. Data chaining refers to packets that span multiple data buffers. However, a single descriptor cannot span multiple packets. The DMA skips to the data buffer of next packet when EOP is detected.

The GMAC supports the following two types of descriptors:

- Normal Descriptor: Normal descriptors are used for packet data and to provide control information applicable to the packets to be transmitted
- Context Descriptor: Context descriptors are used to provide control information applicable to the packet to be transmitted

The GMAC supports the ring structure for the DMA descriptor.



Fig. 19-10 Descriptor Ring Structure

In Ring structure, descriptors are separated by the Word, DWord, or LWord number programmed in the DSL field of the DMA\_CH#\_Control register. The application needs to program the total ring length, that is, the total number of descriptors in ring span in the following registers of a DMA channel:

- Transmit Descriptor Ring Length Register (DMA\_CH#\_TxDesc\_Ring\_Length)
- Receive Descriptor Ring Length Register (DMA\_CH#\_RxDesc\_Ring\_Length)

The Descriptor Tail Pointer Register contains the pointer to the descriptor address (N). The base address and the current descriptor pointer decide the address of the current descriptor that the DMA can process.

The descriptors up to one location less than the one indicated by the descriptor tail pointer ( $N - 1$ ) are owned by the DMA. The DMA continues to process the descriptors until the following condition occurs:

Current Descriptor Pointer == Descriptor Tail Pointer

The DMA goes into the Suspend mode when this condition occurs. The application must perform a write to the Descriptor Tail pointer register and update the tail pointer so that the following condition is true:

Current Descriptor Pointer < Descriptor Tail Pointer

The DMA automatically wraps around the base address when the end of ring is reached. For descriptors owned by the application, the OWN bit of DES3 is reset to 0. For descriptors owned by the DMA, the OWN bit is set to 1. If the application has only one descriptor in the beginning, the application sets the last descriptor address (tail pointer) to Descriptor Base Address + 1. The DMA processes the first descriptor and then waits for the application to advance the tail pointer.

### **19.5.2 Transmit Descriptors**

The DMA in GMAC requires at least one descriptor for a transmit packet. In addition to two buffers, two byte-count buffers, and two address pointers, the transmit descriptor has control fields which can be used to control the MAC operation on per-transmit packet basis. The Transmit Normal descriptor has two formats: Read format and Write-Back format.

### **19.5.3 Transmit Normal Descriptor (Read Format)**

Table 19-3 TDES0 Normal Descriptor (Read Format)

| <b>Bit</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | BUF1AP      | Buffer 1 Address Pointer or TSO Header Address Pointer<br>These bits indicate the physical address of Buffer 1. These bits indicate the TSO Header Address pointer when the following bits are set:<br><ul style="list-style-type: none"> <li>■ TSE bit of TDES3</li> <li>■ FD bit of TDES3</li> </ul> |

Table 19-4 TDES1 Normal Descriptor (Read Format)

| <b>Bit</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                           |
|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | BUF2AP      | Buffer 2 or Buffer 1 Address Pointer<br>This bit indicates the physical address of Buffer 2 when a descriptor ring structure is used. There is no limitation for the buffer address alignment.<br>In 40- or 48-bit addressing mode, these bits indicate the most-significant 8- or 16- bits of the Buffer 1 Address Pointer. |

Table 19-5 TDES2 Normal Descriptor (Read Format)

| <b>Bit</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                    |
|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | IOC         | Interrupt on Completion<br>This bit controls the setting of TI and ETI status bits in the DMA_CH#_Status register. When ETIC = 1 and TDES2[LD] = 0, this bit sets the ETI bit. When TDES3[LD] = 1, this bit sets the TI status bit.                                                                   |
| 30         | TTSE/T MWD  | Transmit Timestamp Enable or External TSO Memory Write Enable<br>This bit enables the IEEE1588 time stamping for Transmit packet referenced by the descriptor, if TSE bit is not set. If TSE bit is set and external TSO memory is enabled, setting this bit disables external TSO memory writing for |

| Bit   | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           | this packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 29:16 | B2L       | Buffer 2 Length<br>The driver sets this field. When set, this field indicates Buffer 2 length                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15:14 | VTIR      | VLAN Tag Insertion or Replacement<br>These bits request the MAC to perform VLAN tagging or untagging before transmitting the packets. The application must set the CRC Pad Control bits appropriately when VLAN Tag Insertion, Replacement, or Deletion is enabled for the packet. The following list describes the values of these bits:<br><ul style="list-style-type: none"> <li>■ 2'b00: Do not add a VLAN tag.</li> <li>■ 2'b01: Remove the VLAN tag from the packets before transmission. This option should be used only with the VLAN packets.</li> <li>■ 2'b10: Insert a VLAN tag with the tag value programmed in the MAC_VLAN_Incl register or context descriptor.</li> <li>■ 2'b11: Replace the VLAN tag in packets with the tag value programmed in the MAC_VLAN_Incl register or context descriptor. This option should be used only with the VLAN packets.</li> </ul> <p>These bits are valid when the Enable SA and VLAN Insertion on Tx option is selected while configuring the core</p> |
| 13:0  | HL or B1L | Header Length or Buffer 1 Length<br>For Header length only bits [9:0] are taken. The size 13:0 is applicable only when interpreting buffer 1 length.<br>If the TCP Segmentation Offload feature is enabled through the TSE bit of TDES3, this field is equal to the header length. When the TSE bit is set in TDES3, the header length includes the length in bytes from Ethernet Source address till the end of the TCP header. The maximum header length supported for TSO feature is 1023 bytes. The maximum header length supported for TSO feature is 1023 bytes.<br>If the TCP Segmentation Offload feature is not enabled, this field is equal to Buffer 1 length.                                                                                                                                                                                                                                                                                                                                  |

Table 19-6 TDES3 Normal Descriptor (Read Format)

| Bit   | Name | Description                                                                                                                                                                                                                                                       |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | OWN  | Own Bit<br>When this bit is set, it indicates that the DMA owns the descriptor. When this bit is reset, it indicates that the application owns the descriptor. The DMA clears this bit after it completes the transfer of data given in the associated buffer(s). |
| 30    | CTXT | Context Type<br>This bit should be set to 1'b0 for normal descriptor.                                                                                                                                                                                             |
| 29    | FD   | First Descriptor<br>When this bit is set, it indicates that the buffer contains the first segment of a packet.                                                                                                                                                    |
| 28    | LD   | Last Descriptor<br>When this bit is set, it indicates that the buffer contains the last segment of the packet. When this bit is set, the B1L or B2L field should have a non-zero value.                                                                           |
| 27:26 | CPC  | CRC Pad Control                                                                                                                                                                                                                                                   |

| Bit   | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                    | <p>This field controls the CRC and Pad Insertion for Tx packet. This field is valid only when the first descriptor bit (TDES3[29]) is set. The following list describes the values of Bits[27:26]:</p> <ul style="list-style-type: none"> <li>■ 2'b00: CRC and Pad Insertion. The MAC appends the cyclic redundancy check (CRC) at the end of the transmitted packet of length greater than or equal to 60 bytes. The MAC automatically appends padding and CRC to a packet with length less than 60 bytes.</li> <li>■ 2'b01: CRC Insertion (Disable Pad Insertion). The MAC appends the CRC at the end of the transmitted packet but it does not append padding. The application should ensure that the padding bytes are present in the packet being transferred from the Transmit Buffer, that is, the packet being transferred from the Transmit Buffer is of length greater than or equal to 60 bytes.</li> <li>■ 2'b10: Disable CRC Insertion. The MAC does not append the CRC at the end of the transmitted packet. The application should ensure that the padding and CRC bytes are present in the packet being transferred from the Transmit Buffer.</li> <li>■ 2'b11: CRC Replacement. The MAC replaces the last four bytes of the transmitted packet with recalculated CRC bytes. The application should ensure that the padding and CRC bytes are present in the packet being transferred from the Transmit Buffer.</li> </ul> <p>This field is valid only for the first descriptor.</p> <p>Note: When the TSE bit is set, the MAC ignores this field because the CRC and pad insertion is always done for segmentation.</p> |
| 25:23 | SAIC               | <p>SA Insertion Control</p> <p>These bits request the MAC to add or replace the Source Address field in the Ethernet packet with the value given in the MAC Address 0 register. The application must set the CRC Pad Control bits appropriately when SA Insertion Control is enabled for the packet. Bit 25 specifies the MAC Address Register (1 or 0) value that is used for Source Address insertion or replacement.</p> <p>The following list describes the values of Bits[24:23]:</p> <ul style="list-style-type: none"> <li>■ 2'b00: Do not include the source address</li> <li>■ 2'b01: Include or insert the source address. For reliable transmission, the application must provide frames without source addresses.</li> <li>■ 2'b10: Replace the source address. For reliable transmission, the application must provide frames with source addresses.</li> <li>■ 2'b11: Reserved</li> </ul> <p>These bits are valid in the EQOS-DMA, EQOS-AXI, and EQOS-AHB configurations when the Enable SA and VLAN Insertion on Tx option is selected while configuring the core and when the First Segment control bit (TDES3 [29]) is set.</p> <p>This field is valid only for the first descriptor.</p>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 22:19 | SLOTPNUM<br>or THL | <p>SLOTPNUM: Slot Number Control Bits in AV Mode</p> <p>These bits indicate the slot interval in which the data should be fetched from the corresponding buffers</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Bit   | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |         | <p>addressed by TDES0 or TDES1. When the Transmit descriptor is fetched, the DMA compares the slot number value in this field with the slot interval maintained in the RSN field DMA_CH#_Slot_Function_Control_Status. It fetches the data from the buffers only if a value matches. These bits are valid only for the AV channels.</p> <p>THL: TCP/UDP Header Length</p> <p>If the TSE bit is set, this field contains the length of the TCP/UDP header. The minimum value of this field must be 5 for TCP header. The value must be equal to 2 for UDP header.</p> <p>This field is valid only for the first descriptor.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 18    | TSE     | <p>TCP Segmentation Enable</p> <p>When this bit is set, the DMA performs the TCP/UDP segmentation or UDP fragmentation for a packet depending on the TSE_MODE[1:0] bit of the DMA_CH(#i)_Tx_Control Register. This bit is valid only if the FD bit is set.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 17:16 | CIC/TPL | <p>Checksum Insertion Control or TCP Payload Length</p> <p>These bits control the checksum calculation and insertion. The following list describes the bit encoding:</p> <ul style="list-style-type: none"> <li>■ 2'b00: Checksum Insertion Disabled.</li> <li>■ 2'b01: Only IP header checksum calculation and insertion are enabled.</li> <li>■ 2'b10: IP header checksum and payload checksum calculation and insertion are enabled, but pseudo-header checksum is not calculated in hardware.</li> <li>■ 2'b11: IP Header checksum and payload checksum calculation and insertion are enabled, and pseudo-header checksum is calculated in hardware. This field is valid when the Enable Transmit TCP/IP Checksum Offload option is selected and the TSE bit is reset.</li> </ul> <p>When the TSE bit is set, this field contains the upper bits [17:16] of the TCP Payload (or IP Payload for UDP fragmentation). This allows the TCP/UDP packet length field to be spanned across TDES3[17:0] to provide 256 KB packet length support.</p> <p>This field is valid only for the first descriptor.</p> |
| 15    | TPL     | <p>Reserved or TCP Payload Length</p> <p>When the TSE bit is reset, this bit is reserved. When the TSE bit is set, this is Bit 15 of the TCP payload length [17:0]. This field is valid only when the Enable TCP Segmentation Offloading for TCP/IP Packets option is selected while configuring the core.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 14:0  | FL/TPL  | <p>Frame Length or TCP Payload Length</p> <p>This field is equal to the length of the packet to be transmitted in bytes. When the TSE bit is not set, this field is equal to the total length of the packet to be transmitted:</p> <p>Ethernet Header Length + TCP /IP Header Length – Preamble Length – SFD Length + Ethernet Payload Length</p> <p>When the TSE bit is set, this field is equal to the lower 15 bits of the TCP payload length in case of segmentation and IP payload in case of UDP fragmentation. In case of segmentation, this length does not include Ethernet</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Bit | Name | Description                                                                                                                                                                                                               |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | header or TCP/UDP/IP header length. In case of fragmentation, this length does not include Ethernet header and IP header. When DWRR/WFQ algorithm is NOT enabled, value written into this field is not used when TSE = 0. |

#### 19.5.4 Transmit Normal Descriptor (Write-back Format)

The write-back format of the Transmit Descriptor includes timestamp low, timestamp high, OWN, and Status bits. The write-back format is applicable only for the last descriptor of the corresponding packet. The LD bit (TDES3[28]) is set in the descriptor where the DMA writes back the status and timestamp information for the corresponding Transmit packet. This format is only applicable to the last descriptor of a packet.

Table 19-7 TDES0 Normal Descriptor (Write-Back Format)

| Bit  | Name | Description                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TTSL | Transmit Packet Timestamp Low<br>The DMA updates this field with least significant 32 bits of the timestamp captured for the corresponding Transmit packet. The DMA writes the timestamp only if TTSE bit of TDES2 is set in the first descriptor of the packet. This field has the timestamp only if the Last Segment bit (LS) in the descriptor is set and the Timestamp status (TTSS) bit is set |

Table 19-8 TDES1 Normal Descriptor (Write-Back Format)

| Bit  | Name | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TTSH | Transmit Packet Timestamp High<br>The DMA updates this field with the most significant 32 bits of the timestamp captured for corresponding transmit packet. The DMA writes the timestamp only if the TTSE bit of TDES2 is set in the first descriptor of the packet. This field has the timestamp only if the Last Segment bit (LS) in the descriptor is set and Timestamp status (TTSS) bit is set. |

Table 19-9 TDES2 Normal Descriptor (Write-Back Format)

| Bit  | Name     | Description |
|------|----------|-------------|
| 31:0 | Reserved | Reserved    |

Table 19-10 TDES2 Normal Descriptor (Write-Back Format)

| Bit   | Name     | Description                                                                                                                                                                                                                                                       |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | OWN      | Own Bit<br>When this bit is set, it indicates that the DMA owns the descriptor. When this bit is reset, it indicates that the application owns the descriptor. The DMA clears this bit after it completes the transfer of data given in the associated buffer(s). |
| 30    | CTXT     | Context Type<br>This bit should be set to 1'b0 for normal descriptor.                                                                                                                                                                                             |
| 29    | FD       | First Descriptor<br>When this bit is set, it indicates that the buffer contains the first segment of a packet.                                                                                                                                                    |
| 28    | LD       | Last Descriptor<br>When this bit is set, it indicates that the buffer contains the last segment of the packet. When this bit is set, the B1L or B2L field should have a non-zero value.                                                                           |
| 27:24 | Reserved | Reserved                                                                                                                                                                                                                                                          |
| 23    | DE       | Descriptor Error<br>When this bit is set, it indicates that the descriptor content is incorrect. The DMA sets this bit during write-                                                                                                                              |

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | <p>back while closing the descriptor. Descriptor Errors can be:</p> <ul style="list-style-type: none"> <li>■ Incorrect sequence from the context descriptor. For example, a location after the first descriptor for a packet</li> <li>■ All 1s</li> <li>■ CTXT, LD, and FD bits set to 1</li> </ul> <p>Note 1: When Descriptor Error occurs due to All 1s or CTXT, LD, and FD bits set to 1, the Transmit DMA closes the transmit descriptor with DE and LD bits set to 1. When IOC bit in TDES2 of corresponding first descriptor is set to 1, Transmit DMA will set the TI bit in the DMA_CH#_Status register.</p> <p>Note 2: Based on CTXT, LD, and FD bits of the transmit descriptor, the subsequent descriptor might be considered as the First Descriptor (even if FD bit is not set) and partial packet is sent.</p> |
| 22:18 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 17    | TTSS     | <p>Tx Timestamp Status</p> <p>This status bit indicates that a timestamp has been captured for the corresponding transmit packet. When this bit is set, TDES0 and TDES1 have timestamp values that were captured for the Transmit packet. This field is valid only when the Last Segment control bit (TDES3 [28]) in a descriptor is set. This bit is valid only when IEEE1588 timestamping feature is enabled; otherwise, it is reserved.</p>                                                                                                                                                                                                                                                                                                                                                                               |
| 16    | EUE      | <p>ECC Uncorrectable Error Status</p> <p>Indicates the ECC uncorrectable error in the TSO memory. Note: Uncorrectable error in Transmit FIFO memory is reported with (Bit 13) FF = 1. This is because, all such packets are flushed by GMAC.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15    | ES       | <p>Error Summary</p> <p>This bit indicates the logical OR of the following bits:</p> <ul style="list-style-type: none"> <li>■ TDES3[0]: IP Header Error</li> <li>■ TDES3[14]: Jabber Timeout</li> <li>■ TDES3[13]: Packet Flush</li> <li>■ TDES3[12]: Payload Checksum Error</li> <li>■ TDES3[11]: Loss of Carrier</li> <li>■ TDES3[10]: No Carrier</li> <li>■ TDES3[9]: Late Collision</li> <li>■ TDES3[8]: Excessive Collision</li> <li>■ TDES3[3]: Excessive Deferral</li> <li>■ TDES3[2]: Underflow Error</li> </ul> <p>This bit is also set when EUE (bit 16) is set</p>                                                                                                                                                                                                                                                |
| 14    | JT       | <p>Jabber Timeout</p> <p>This bit indicates that the MAC transmitter has experienced a jabber time-out. This bit is set only when the JD bit of the MAC_Configuration register is not set.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 13    | PF       | <p>Packet Flushed</p> <p>This bit indicates that the DMA or MTL flushed the packet because of a software flush command given by the CPU.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12    | PCE      | <p>Payload Checksum Error</p> <p>This bit indicates that the Checksum Offload engine had a failure and did not insert any checksum into the</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | encapsulated TCP, UDP, or ICMP payload. This failure can be either because of insufficient bytes, as indicated by the Payload Length field of the IP Header or the MTL starting to forward the packet 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 packet being transmitted to avoid deadlock, the MTL starts forwarding the packet when the FIFO is full, even in the store-and-forward mode. This error can also occur when Bus Error is detected during packet transfer. When the Full Checksum Offload engine is not enabled, this bit is reserved. |
| 11  | LoC  | <p><b>Loss of Carrier</b><br/>           This bit indicates that Loss of Carrier occurred during packet transmission (that is, the gmii_crs_i signal was inactive for one or more transmit clock periods during packet transmission). This is valid only for the packets transmitted without collision and when the MAC operates in the half-duplex mode.</p>                                                                                                                                                                                                                                                                                                                                                             |
| 10  | NC   | <p><b>No Carrier</b><br/>           This bit indicates that the carrier sense signal from the PHY was not asserted during transmission.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9   | LC   | <p><b>Late Collision</b><br/>           This bit indicates that packet transmission was aborted because a collision occurred after the collision window (64 byte times including Preamble in MII mode and 512 byte times including Preamble and Carrier Extension in GMII mode). This bit is not valid if Underflow Error is set.</p>                                                                                                                                                                                                                                                                                                                                                                                     |
| 8   | EC   | <p><b>Excessive Collision</b><br/>           This bit indicates that the transmission was aborted after 16 successive collisions while attempting to transmit the current packet. If the DR bit is set in the MAC_Configuration register, this bit is set after first collision and the transmission of the packet is aborted.</p>                                                                                                                                                                                                                                                                                                                                                                                        |
| 7:4 | CC   | <p><b>Collision Count</b><br/>           This 4-bit counter value indicates the number of collisions occurred before the packet was transmitted. The count is not valid when the EC bit is set.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3   | ED   | <p><b>Excessive Deferral</b><br/>           This bit indicates that the transmission ended because of excessive deferral of over 24,288 bit times (155,680 bits times in 1000 Mbps mode or Jumbo Packet enabled mode) if DC bit is set in the MAC_Configuration register. When TBS is enabled in full duplex mode and this bit is set, it indicates that the frame has been dropped after the expiry time has reached.</p>                                                                                                                                                                                                                                                                                                |
| 2   | UF   | <p><b>Underflow Error</b><br/>           This bit indicates that the MAC aborted the packet because the data arrived late from the system memory. The underflow error can occur because of either of the following conditions:</p> <ul style="list-style-type: none"> <li>■ The DMA encountered an empty Transmit Buffer while transmitting the packet</li> <li>■ The application filled the MTL Tx FIFO slower than the MAC transmit rate</li> </ul>                                                                                                                                                                                                                                                                     |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | The transmission process enter the suspended state and sets the underflow bit corresponding to a queue in the MTL_Interrupt_Status register.                                                                                                                                                                                                                                                                                                                                                                 |
| 1   | DB   | Deferred Bit<br>This bit indicates that the MAC deferred before transmitting because of presence of carrier. This bit is valid only in the half-duplex mode.                                                                                                                                                                                                                                                                                                                                                 |
| 0   | IHE  | IP Header Error<br>When IP Header Error is set, this bit indicates that the Checksum Offload engine detected an IP header error. This bit is valid only when Tx Checksum Offload is enabled. Otherwise, it is reserved. If COE detects an IP header error, it still inserts an IPv4 header checksum if the Ethernet Type field indicates an IPv4 payload.<br>In full duplex mode, when EST/Qbv is enabled and this bit is set, it indicates the frame drop status due to Frame Size error or Schedule Error. |

## 19.5.5 Programming Guide

### 19.5.5.1 Initializing DMA

Complete the following steps to initialize the DMA:

1. Provide a software reset. This resets all of the MAC internal registers and logic (bit-0 of DMA\_Mode).
2. Wait for the completion of the reset process (poll bit 0 of the DMA\_Mode, which is only cleared after the reset operation is completed).
3. Program the following fields to initialize the DMA\_SysBus\_Mode register:
  - a. AAL
  - b. Fixed burst or undefined burst
  - c. Burst mode values in case of AHB bus interface, OSR\_LMT in case of AXI bus interface.
  - d. If fixed length value is enabled, select the maximum burst length possible on the AXI Bus (bits [7:1])
4. Create a descriptor list for transmit and receive. In addition, ensure that the descriptors are owned by DMA (set bit 31 of descriptor TDES3/RDES3). For more information about descriptors, see section "Descriptors".
5. Program the Transmit and Receive Ring length registers  
(DMA\_CH(#i)\_TxDesc\_Ring\_Length (for i = 0; i <= GMAC\_NUM\_DMA\_TX\_CH-1) and DMA\_CH(#i)\_RxDesc\_Ring\_Length (for i = 0; i <= GMAC\_NUM\_DMA\_RX\_CH-1)). The ring length programmed must be at least 4.
6. Initialize receive and transmit descriptor list address with the base address of the transmit and receive descriptor (DMA\_CH(#i)\_TxDesc\_List\_Address (for i = 0; i <= GMAC\_NUM\_DMA\_TX\_CH-1), DMA\_CH(#i)\_RxDesc\_List\_Address (for i = 0; i <= GMAC\_NUM\_DMA\_RX\_CH-1)). Also, program transmit and receive tail pointer registers indicating to the DMA about the available descriptors (DMA\_CH(#i)\_TxDesc\_Tail\_Pointer (for i = 0; i <= GMAC\_NUM\_DMA\_TX\_CH-1) and DMA\_CH(#i)\_RxDesc\_Tail\_Pointer (for i = 0; i <= GMAC\_NUM\_DMA\_RX\_CH-1)).
7. Program the settings of the following registers for the parameters like maximum burst-length (PBL) initiated by DMA, descriptor skip lengths, OSP in case of TxDMA, RBSZ in case of RxDMA, and so on:
  - DMA\_CH(#i)\_Control (for i = 0; i <= GMAC\_NUM\_DMA\_TX\_CH-1)
  - DMA\_CH(#i)\_TX\_Control (for i = 0; i <= GMAC\_NUM\_DMA\_TX\_CH-1)
  - DMA\_CH(#i)\_RX\_Control (for i = 0; i <= GMAC\_NUM\_DMA\_RX\_CH-1)
8. Enable the interrupts by programming the DMA\_CH(#i)\_Interrupt\_Enable (for i = 0; i <= GMAC\_NUM\_DMA\_TX\_CH-1) register.
9. Start the Receive and Transmit DMAs by setting SR (bit 0) of the DMA\_CH(#i)\_RX\_Control (for i = 0; i <= GMAC\_NUM\_DMA\_RX\_CH-1) and ST (bit 0) of the DMA\_CH(#i)\_TX\_Control (for i = 0; i <= GMAC\_NUM\_DMA\_TX\_CH-1) register.

10. Repeat steps 4 to 9 for all the Tx DMA and Rx DMA channels selected in the hardware.

### **19.5.5.2 Initializing MTL Registers**

The Transaction Layer (MTL) registers must be initialized to establish the transmit and receive operating modes and commands.

Complete the following steps to initialize the MTL registers:

1. Program the Tx Scheduling (SCHALG) and Receive Arbitration Algorithm (RAA) fields in MTL\_Operation\_Mode to initialize the MTL operation in case of multiple Tx and Rx queues.
2. Program the Receive Queue to DMA mapping in MTL\_RxQ\_DMA\_Map0 and MTL\_RxQ\_DMA\_Map1 registers.
3. Program the following fields to initialize the mode of operation in the MTL\_TxQ0\_Operation\_Mode register.
  - a. Transmit Store And Forward (TSF) or Transmit Threshold Control (TTC) in case of threshold mode
  - b. Transmit Queue Enable (TXQEN) to value 2'b10 to enable Transmit Queue0
  - c. Transmit Queue Size (TQS)
4. Program the following fields to initialize the mode of operation in the MTL\_RxQ0\_Operation\_Mode register:
  - a. Receive Store and Forward (RSF) or RTC in case of Threshold mode
  - b. Flow Control Activation and De-activation thresholds for MTL Receive FIFO (RFA and RFD)
  - c. Error Packet and undersized good Packet forwarding enable (FEP and FUP)
  - d. Receive Queue Size (RQS)
5. Repeat previous two steps for all MTL Tx and Rx queues selected in the configuration.

### **19.5.5.3 Initializing MAC**

The MAC configuration registers establish the operating mode of the MAC. These registers must be initialized before initializing the DMA.

The following MAC Initialization operations can be performed after DMA initialization. If the MAC initialization is completed before the DMA is configured, enable the MAC receiver (last step in the following sequence) only after the DMA is active. Otherwise, received frames fill the Rx FIFO and overflow.

1. Provide the MAC address registers: MAC\_Address0\_High and MAC\_Address0\_Low. If more than one MAC address is enabled in your configuration, program the MAC addresses appropriately.
2. Program the following fields to set the appropriate filters for the incoming frames in the MAC\_Packet\_Filter register:
  - a. Receive All
  - b. Promiscuous mode
  - c. Hash or Perfect Filter
  - d. Unicast, multicast, broadcast, and control frames filter settings
3. Program the following fields for proper flow control in the MAC\_Q0\_Tx\_Flow\_Ctrl register:
  - a. Pause time and other Pause frame control bits
  - b. Transmit Flow control bits
  - c. Flow Control Busy
4. Program the MAC\_Interrupt\_Enable register, as required, and if applicable, for your configuration.
5. Program the appropriate fields in the MAC\_Configuration register. For ex: Inter-packet gap while transmission and jabber disable.
6. Set bit 0 and 1 in MAC\_Configuration registers to start the MAC transmitter and receiver.

### **19.5.5.4 Performing Normal Receive and Transmit Operation**

During normal operation of the GMAC, normal and transmit interrupts are read, descriptors polled, the DMA is suspended (if it does not own descriptors), and values of current host transmitter or receiver descriptor pointers are read for debugging.

For normal operation, complete the following steps:

1. 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).
2. 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.
3. If the descriptors are not owned by the DMA (or no descriptor is available), the DMA goes into SUSPEND state. The transmission or reception can be resumed by freeing the descriptors and writing the descriptor tail pointer to Tx/Rx tail pointer register (DMA\_CH[n].TxDesc\_Tail\_Pointer and DMA\_CH[n].RxDesc\_Tail\_Pointer).
4. The values of the current host transmitter or receiver descriptor address pointer can be read for the debug process (DMA\_CH[n].Current\_App\_TxDesc and DMA\_CH[n].Current\_App\_RxDesc).
5. The values of the current host transmit buffer address pointer and receive buffer address pointer can be read for the debug process (Register DMA\_CH[n].Current\_App\_TxBuffer and DMA\_CH[n].Current\_App\_RxBuffer)

### **19.5.5.5 Stopping and Starting Transmission**

Complete the following steps to pause the transmission for some time.

1. Disable the Transmit DMA (if applicable) by clearing Bit 0 (ST) of DMA\_CH(#i).TX\_Control (for i = 0; i <= GMAC\_NUM\_DMA\_TX\_CH-1) Register.
2. Wait for any previous frame transmissions to complete. You can check this by reading the appropriate bits of MTL\_TxQ0\_Debug Register (TRCSTS is not 01 and TXQSTS=0).
3. Disable the MAC transmitter and MAC receiver by clearing Bit (RE) and Bit 1(TE) of the MAC\_Configuration Register.
4. Disable the Receive DMA (if applicable), after making sure that the data in the Rx FIFO is transferred to the system memory (by reading the appropriate bits of MTL\_TxQ0\_Debug Register, PRXQ=0 and RXQSTS=00).
5. Make sure that both Tx Queue and Rx Queue are empty (TXQSTS is 0 in MTL\_TxQ0\_Debug Register and RXQSTS is 0 in MTL\_RxQ0\_Debug Register).
6. To restart the operation, first start the DMAs, and then enable the MAC Transmitter and Receiver.

### **19.5.5.6 Initialization Guidelines for System Time Generation**

You can enable the timestamp feature by setting Bit 0 of the MAC\_Timestamp\_Control Register. However, it is essential that the timestamp counter be initialized after this bit is set. Complete the following steps during GMAC initialization:

1. Mask the Timestamp Trigger interrupt by clearing the bit 16 of MAC\_Interrupt\_Enable Register.
2. Set Bit 0 of MAC\_Timestamp\_Control Register to enable timestamping.
3. Program MAC\_Sub\_Second\_Increment Register based on the PTP clock frequency.
4. If you are using the Fine Correction approach, program MAC\_Timestamp\_Addend and set Bit 5 of MAC\_Timestamp\_Control Register.
5. Poll the MAC\_Timestamp\_Control Register until Bit 5 is cleared.
6. Program Bit 1 of MAC\_Timestamp\_Control Register to select the Fine Update method (if required).
7. Program MAC\_System\_Time\_Seconds\_Update Register and MAC\_System\_Time\_Nanoseconds\_Update Register with the appropriate time value.
8. Set Bit 2 in MAC\_Timestamp\_Control Register.

The timestamp counter starts operation as soon as it is initialized with the value written in the Timestamp Update registers. If one-step timestamping is enabled

- a. To enable one-step timestamping, program Bit 27 of the TDES3 Context Descriptor.

- b. Program registers MAC\_Timestamp\_Ingress\_Asym\_Corr and

MAC\_Timestamp\_Egress\_Asym\_Corr to update the correction field in PDelay\_Req PTP messages.

9. Enable the MAC receiver and transmitter for proper timestamping.

### **19.5.5.7 Coarse Correction Method**

To synchronize or update the system time in one process (coarse correction method), complete the following steps:

1. Set the offset (positive or negative) in the Timestamp Update registers (MAC\_System\_Time\_Seconds\_Update and MAC\_System\_Time\_Nanoseconds\_Update).
2. Set Bit 3 (TSUPDT) of MAC\_Timestamp\_Control Register. The value in the Timestamp Update registers is added to or subtracted from the system time when the TSUPDT bit is cleared.

### **19.5.5.8 Programming Guidelines for TSO**

The TCP Segmentation Offload (TSO) engine is used to offload the TCP segmentation functions to the hardware. To program the TSO, set the TSE bit to enable TCP packet segmentation, and program descriptor fields to enable TSO for the current packet.

Complete the following steps to program TSO:

1. Program the TSE bit of corresponding DMA\_CH[n]\_Tx\_Control register to enable TCP packet segmentation in that DMA.
2. In addition to the normal transfer descriptor setting, the following descriptor fields must be programmed to enable TSO for the current packet:
  - a. Enable TSE in Bit 18 of TDES3
  - b. Program the length of the un-segmented TCP/IP packet payload in bits [17:0] of TDES3 and the TCP header in bits [22:19] of TDES3.
  - c. Program the maximum size of the segment in MSS of DMA\_CH[n]\_Control register or MSS in the context descriptor. If MSS field is programmed in both DMA\_CH[n]\_Control register and in the context descriptor, the latest software programmed sequence is considered.
3. The header of the unsegmented TCP/IP packet should be in Buffer 1 of the first descriptor and this buffer must not hold any payload bytes. The payload is allocated to Buffer 2 and the buffers of the subsequent descriptors.

### **19.5.5.9 Programming Guidelines for Multi-Channel Multi-Queueing Transmit**

1. Program the Transmit queue size in the TQS field of MTL\_TxQ[n]\_Operation\_Mode register. Based on the value programmed in the TQS field, the size of the queue is determined.

In the Transmit operation, the number of channels is equal to the number of the queues. Due to this reason, the Channel-to-Queue mapping is fixed.

2. For a queue to be used, the queue needs to be enabled in TXQEN in the corresponding MTL\_TxQ[n]\_Operation\_Mode Register. In DMA configurations, the ST bit of DMA\_CH[n]\_Tx\_Control Register and corresponding TXQEN in MTL\_TxQ[n]\_Operation Mode Register needs to be enabled.
3. The scheduling method needs to be programmed in SCHALG of MTL\_Operation\_Mode register.
4. Program the MTL\_TxQ[n]\_Quantum\_Weight for DCB queue as per the selected algorithm. In case of CBS algorithm in AVB queues, the MTL\_TxQ[n]\_ETS\_Control, MTL\_TxQ[n]\_SendSlopeCredit, MTL\_TxQ[n]\_HiCredit and MTL\_TxQ[n]\_LoCredit registers also need to be programmed as required.
5. If DCB is enabled and PFC function is required, program MAC\_TxQ\_Prty\_Map0 Register to assign a fixed priority to the queue. This priority assigned is used for determining if the corresponding queue should stop transmitting packet based on the received PFC packet.

### **Receive**

1. Program the Receive queue size in the RQS field of MTL\_RxQ[n]\_Operation\_Mode Register. Based on the value programmed in RQS field, the size of the queue is determined.
2. Enable the Receive Queues 0 to 7 in the fields RXQ0EN to RXQ7EN in MAC\_RxQ\_Ctrl0 Register for AV or DCB. In DMA configurations, SR bit of statically or dynamically mapped DMA\_CH[n]\_Rx\_Control Register and corresponding RXQ[n]\_EN in MAC\_RxQ\_Ctrl0 Register needs to be enabled.

3. The MAC routes the Rx packets to the Rx Queues based on following packet types:
  - a. AV PTP Packets: Based on the programming of AVPTPQ in MAC\_RxQ\_Ctrl1 Register.
  - b. AV Untagged Control packets: Based on the programming of AVCPQ in MAC\_RxQ\_Ctrl1 Register.
  - c. Data Center Bridging (DCB) related Link Layer Discovery Protocol (LLDP) packets.  
Program DCBCPQ in MAC\_RxQ\_Ctrl1 Register to indicate to MAC which queue should get the DCB packets.
  - d. VLAN Tag Priority field in VLAN Tagged packets: Program PSRQ7-0 of the MAC\_RxQ\_Ctrl2 and MAC\_RxQ\_Ctrl3 Register for the routing of tagged packets based on the USP (user Priority) field of the received packets to the Rx Queues 0 to 7.
  - e. The AV tagged control and data packets are also routed based on PSRQ field of the MAC\_RxQ\_Ctrl2 and MAC\_RxQ\_Ctrl3 registers.
4. If multiple RX DMA channels are enabled, the following programming should be done for proper arbitration and mapping:
  - a. Program the RAA field of MTL\_Operation\_Mode register to select the arbitration algorithm to decide which RxQ is read out from the RxFIFO memory.
  - b. Program the MTL\_RxQ[n]\_Control to decide the weights and the packet arbitration for each RxQ.
  - c. If static mapping is programmed in MTL\_RxQ\_DMA\_Map[n] register (RXQ[n]DADMACH is reset to 0), bits RXQx2DMA and others need to be programmed to select the channel for which each queue is mapped.
  - d. Set RXQ[n]DADMACH bit in MTL\_RxQ\_DMA\_Map0 Register to select dynamic mapping of packets in each RxQueue.
  - e. In dynamic channel mapping, the routing of a packet to a specific RxDMA channel is decided by the value of DCS field in the lowest MAC Address Register.

### **19.5.6 Transmit Context Descriptor**

The context descriptor is used to provide the timestamps for one-step timestamp correction, VLAN Tag ID for VLAN insertion feature. The Transmit Context descriptor can be provided any time before a packet descriptor. The context is valid for the current packet and subsequent packets. The context descriptor is used to provide the timestamps for one-step timestamp correction and VLAN Tag ID for VLAN insertion feature. Write back is done on a context descriptor only to reset the OWN bit.

Table 19-11 TDES0 Context Descriptor

| Bit  | Name | Description                                                                                                                                                                                                                                                                                                            |
|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TTSL | Transmit Packet Timestamp Low<br>For one-step correction, the driver can provide the lower 32 bits of timestamp in this descriptor word.<br>The DMA uses this value as the low word for doing one-step timestamp correction. This field is valid only if the OSTC and TCMSSV bits of TDES3 context descriptor are set. |

Table 19-12 TDES1 Context Descriptor

| Bit  | Name | Description                                                                                                                                                                                                                                                                                                      |
|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TTSH | Transmit Packet Timestamp High<br>For one-step correction, the driver can provide the upper 32 bits of timestamp in this descriptor. The DMA uses this value as the high word for doing one-step timestamp correction. This field is valid only if the OSTC and TCMSSV bits of TDES3 context descriptor are set. |

Table 19-13 TDES2 Context Descriptor

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                   |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | IVT      | Inner VLAN Tag<br>When the IVLTV bit of TDES3 context descriptor is set and the TCMSSV and OSTC bits of TDES3 context descriptor are reset, TDES2[31:16] contains the inner VLAN Tag to be inserted in the subsequent Transmit packets.                                                                                                                                       |
| 15:14 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 13:0  | MSS      | Maximum Segment Size<br>When the Enable TCP Segmentation Offloading for TCP/IP Packets option is selected, the driver can provide maximum segment size in this field. This segment size is used while segmenting the TCP/IP payload. This field is valid only if the TCMSSV bit of TDES3 context descriptor is set and the OSTC bit of the TDES3 context descriptor is reset. |

Table 19-14 TDES3 Context Descriptor

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                     |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | OWN      | Own Bit<br>When this bit is set, it indicates that the GMAC DMA owns the descriptor. When this bit is reset, it indicates that the application owns the descriptor. The DMA clears this bit immediately after the read.                                                                                                                         |
| 30    | CTXT     | Context Type<br>This bit should be set to 1'b1 for Context descriptor.                                                                                                                                                                                                                                                                          |
| 29:28 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                        |
| 27    | OSTC     | One-Step Timestamp Correction Enable<br>When this bit is set, the DMA performs a one-step timestamp correction with reference to the timestamp values provided in TDES0 and TDES1.                                                                                                                                                              |
| 26    | TCMSSV   | One-Step Timestamp Correction Input or MSS Valid<br>When this bit and the OSTC bit are set, it indicates that the Timestamp Correction input provided in TDES0 and TDES1 is valid. When the OSTC bit is reset and this bit and the TSE bit of TDES3 are set in subsequent normal descriptor, it indicates that the MSS input in TDES2 is valid. |

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:24 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 23    | DE       | <p>Descriptor Error<br/>When this bit is set, it indicates that the descriptor content is incorrect. The DMA sets this bit during write-back while closing the context descriptor.</p> <p>Descriptor Errors can be:</p> <ul style="list-style-type: none"> <li>■ Incorrect sequence from the context descriptor. For example, a location before the first descriptor for a packet</li> <li>■ All 1s</li> <li>■ CD, LD, and FD bits set to 1</li> </ul> <p>Note 1: When Descriptor Error occurs due to All 1s or CTXT, LD, and FD bits set to 1, the Transmit DMA closes the transmit descriptor with DE and LD bits set to 1.</p> <p>When IOC bit in TDES2 of corresponding first descriptor is set to 1, Transmit DMA will set the TI bit in the DMA_CH#_Status Register.</p> <p>Note 2: Based on CTXT, LD, and FD bits of the transmit descriptor, the subsequent descriptor might be considered as the First Descriptor (even if FD bit is not set) and partial packet is sent.</p>                                                                       |
| 22:20 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 19:18 | IVTIR    | <p>Inner VLAN Tag Insert or Replace<br/>When this bit is set, these bits request the MAC to perform Inner VLAN tagging or un-tagging before transmitting the packets. If the packet is modified for VLAN tags, the MAC automatically recalculates and replaces the CRC bytes.</p> <p>The following list describes the values of these bits:</p> <ul style="list-style-type: none"> <li>■ 2'b00: Do not add the inner VLAN tag.</li> <li>■ 2'b01: Remove the inner VLAN tag from the packets before transmission. This option should be used only with the VLAN frames.</li> <li>■ 2'b10: Insert an inner VLAN tag with the tag value programmed in the MAC_Inner_VLAN_Incl register or context descriptor.</li> <li>■ 2'b11: Replace the inner VLAN tag in packets with the tag value programmed in the MAC_Inner_VLAN_Incl register or context descriptor. This option should be used only with the VLAN frames.</li> </ul> <p>These bits are valid when the Enable SA and VLAN Insertion on Tx and Enable Double VLAN Processing options are selected.</p> |
| 17    | IVLTV    | <p>Inner VLAN Tag Valid<br/>When this bit is set, it indicates that the IVT field of TDES2 is valid.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16    | VLTW     | <p>VLAN Tag Valid<br/>When this bit is set, it indicates that the VT field of TDES3 is valid.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15:0  | VT       | <p>VLAN Tag<br/>This field contains the VLAN Tag to be inserted or replaced in the packet. This field is used as VLAN Tag only when the VLTI bit of the MAC_VLAN_Incl register is reset.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 19.5.7 Receive Descriptors

The DMA in GMAC attempts to read a descriptor only if the Tail Pointer is different from the Base Pointer or current pointer. It is recommended to have a descriptor ring with a length

that can accommodate at least two complete packets received by the MAC. Otherwise, the performance of the DMA is impacted greatly because of the unavailability of the descriptors. In such situations, the Rx FIFO in MTL becomes full and starts dropping packets.

The following Receive Descriptors are present:

- Normal descriptors
- Context descriptors

All RX descriptors are prepared by the software and given to the DMA as "Normal" Descriptors with the content as shown in Receive Normal Descriptor (Read Format). The DMA reads this descriptor and after transferring a received packet (or part of) to the buffers indicated by the descriptor, the Rx DMA will close the descriptor with the corresponding packet status. The format of this status is given in the "Receive Normal Descriptor (Write-Back Format)". For some packets, the normal descriptor bits are not enough to write the complete status. For such packets, the RX DMA writes the extended status to the next descriptor (without processing or using the Buffers/ Pointers embedded in that descriptor). The format and content of the descriptor write back is described in "Receive Context Descriptor".

### **19.5.8 Receive Normal Descriptors(Read Format)**

Table 19-15 TDES0 Normal Descriptor(Read Format)

| <b>Bit</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | BUF1AP      | <p>Header or Buffer 1 Address Pointer</p> <p>When the SPH bit of Control register of a channel is reset, these bits indicate the physical address of Buffer 1. When the SPH bit is set, these bits indicate the physical address of Header Buffer where the Rx DMA writes the L2/L3/L4 header bytes of the received packet.</p> <p>The application can program a byte-aligned address for this buffer which means that the LS bits of this field can be non-zero. However, while transferring the start of packet, the DMA performs a Write operation with RDES0[1:0] (or RDES0[2:0]/[3:0] in case of 64-/128-bit configuration) as zero. However, the packet data is shifted as per actual offset as given by buffer address pointer.</p> <p>If the address pointer points to a buffer where the middle or last part of the packet is stored, the DMA ignores the offset address and writes to the full location as indicated by the data-width.</p> |

Table 19-16 TDES1 Normal Descriptor(Read Format)

| <b>Bit</b> | <b>Name</b>        | <b>Description</b>                                                                                                                              |
|------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | Reserved or BUF1AP | In 64-bit addressing mode, this field contains the most-significant 32 bits of the Buffer 1 Address Pointer. Otherwise, this field is reserved. |

Table 19-17 TDES2 Normal Descriptor(Read Format)

| <b>Bit</b> | <b>Name</b>        | <b>Description</b>                                                                                                                              |
|------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | Reserved or BUF1AP | In 64-bit addressing mode, this field contains the most-significant 32 bits of the Buffer 1 Address Pointer. Otherwise, this field is reserved. |

Table 19-18 TDES3 Normal Descriptor(Read Format)

| <b>Bit</b> | <b>Name</b> | <b>Description</b> |
|------------|-------------|--------------------|
| 31         | OWN         | Own Bit            |

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | When this bit is set, it indicates that the GMAC DMA owns the descriptor. When this bit is reset, it indicates that the application owns the descriptor. The DMA clears this bit when either of the following conditions is true:<br><ul style="list-style-type: none"> <li>■ The DMA completes the packet reception</li> <li>■ The buffers associated with the descriptor are full</li> </ul> |
| 30    | IOC      | Interrupt Enabled on Completion<br>When this bit is set, an interrupt is issued to the application when the DMA closes this descriptor.                                                                                                                                                                                                                                                        |
| 29:26 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                       |
| 25    | BUF2V    | Buffer 2 Address Valid<br>When this bit is set, it indicates to the DMA that the buffer 2 address specified in RDES2 is valid.<br>The application must set this bit so that the DMA can use the address, to which the Buffer 2 address in RDES2 is pointing, to write received packet data.                                                                                                    |
| 24    | BUF1V    | Buffer 1 Address Valid<br>When set, this indicates to the DMA that the buffer 1 address specified in RDES1 is valid.<br>The application must set this value if the address pointed to by Buffer 1 address in RDES1 can be used by the DMA to write received packet data.                                                                                                                       |
| 23:0  | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                       |

### 19.5.9 Receive Normal Descriptors(Write-Back Format)

Table 19-19 TDES0 Normal Descriptor(Write-Back Format)

| Bit   | Name | Description                                                                                                                                                                                                |
|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | IVT  | Inner VLAN Tag<br>This field contains the Inner VLAN tag of the received packet if the RS0V bit of RDES3 is set.<br>This is valid only when Double VLAN tag processing and VLAN tag stripping are enabled. |
| 15:0  | OVT  | Outer VLAN Tag<br>This field contains the Outer VLAN tag of the received packet if the RS0V bit of RDES3 is set.                                                                                           |

Table 19-20 TDES1 Normal Descriptor(Write-Back Format)

| Bit   | Name | Description                                                                                                                                                                                                                                                                                                  |
|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | OPC  | OAM Sub-Type Code, or MAC Control Packet opcode<br>OAM Sub-Type Code<br>If Bits[18:16] of RDES3 are set to 3'b111, this field contains the OAM sub-type and code fields.<br>MAC Control Packet opcode<br>If Bits[18:16] of RDES3 are set to 3'b110, this field contains the MAC Control packet opcode field. |
| 15    | TD   | Timestamp Dropped<br>This bit indicates that the timestamp was captured for this packet but it got dropped in the MTL Rx FIFO because of overflow.<br>This bit is available only when you select the Timestamp feature. Otherwise, this bit is reserved.                                                     |
| 14    | TSA  | Timestamp Available<br>When Timestamp is present, this bit indicates that the timestamp value is available in a context descriptor word 2 (RDES2) and word 1(RDES1). This is valid only when the Last Descriptor bit (RDES3 [28]) is set.                                                                    |

| Bit  | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      | The context descriptor is written in the next descriptor just after the last normal descriptor for a packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13   | PV   | <p>PTP Version</p> <p>This bit indicates that the received PTP message has the IEEE 1588 version 2 format. When this bit is reset, it indicates the IEEE 1588 version 1 format.</p> <p>This bit is available only when you select the Timestamp feature. Otherwise, this bit is reserved.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12   | PFT  | <p>PTP Packet Type</p> <p>This bit indicates that the PTP message is sent directly over Ethernet. This bit is available only when you select the Timestamp feature. Otherwise, this bit is reserved.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11:8 | PMT  | <p>PTP Message Type</p> <p>These bits are encoded to give the type of the message received:</p> <ul style="list-style-type: none"> <li>■ 0000: No PTP message received</li> <li>■ 0001: SYNC (all clock types)</li> <li>■ 0010: Follow_Up (all clock types)</li> <li>■ 0011: Delay_Req (all clock types)</li> <li>■ 0100: Delay_Resp (all clock types)</li> <li>■ 0101: Pdelay_Req (in peer-to-peer transparent clock)</li> <li>■ 0110: Pdelay_Resp (in peer-to-peer transparent clock)</li> <li>■ 0111: Pdelay_Resp_Follow_Up (in peer-to-peer transparent clock)</li> <li>■ 1000: Announce</li> <li>■ 1001: Management</li> <li>■ 1010: Signaling</li> <li>■ 1011–1110: Reserved</li> <li>■ 1111: PTP packet with Reserved message type</li> </ul> <p>These bits are available only when you select the Timestamp feature.</p> |
| 7    | IPCE | <p>IP Payload Error</p> <p>When this bit is set, it indicates either of the following:</p> <ul style="list-style-type: none"> <li>■ The 16-bit IP payload checksum (that is, the TCP, UDP, or ICMP checksum) calculated by the MAC does not match the corresponding checksum field in the received segment.</li> <li>■ The TCP, UDP, or ICMP segment length does not match the payload length value in the IP Header field.</li> <li>■ The TCP, UDP, or ICMP segment length is less than minimum allowed segment length for TCP, UDP, or ICMP.</li> </ul> <p>Bit 15 (ES) of RDES3 is not set when this bit is set.</p>                                                                                                                                                                                                           |
| 6    | IPCB | <p>IP Checksum Bypassed</p> <p>This bit indicates that the checksum offload engine is bypassed. This bit is available when you select the Enable Receive TCP/IP Checksum Check feature.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5    | IPV6 | <p>IPv6 header Present</p> <p>This bit indicates that an IPV6 header is detected. When the Enable Split Header Feature option is selected and the SPH bit of Control Register of a channel is set, the IPV6 header is available in the header buffer area to which RDES0 is pointing.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4    | IPV4 | IPV4 Header Present                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | <p>This bit indicates that an IPV4 header is detected. When the SPH bit of RDES3 is set, the IPV4 header is available in the header buffer area to which RDES0 is pointing.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3   | IPHE | <p>IP Header Error<br/>When this bit is set, it indicates either of the following:</p> <ul style="list-style-type: none"> <li>■ The 16-bit IPv4 header checksum calculated by the MAC does not match the received checksum bytes.</li> <li>■ The IP datagram version is not consistent with the Ethernet Type value.</li> <li>■ Ethernet packet does not have the expected number of IP header bytes.</li> </ul> <p>This bit is valid when either Bit 5 or Bit 4 is set. This bit is available when you select the Enable Receive TCP/IP Checksum Check feature.</p>                                                                                                                                                   |
| 2:0 | PT   | <p>Payload Type<br/>These bits indicate the type of payload encapsulated in the IP datagram processed by the Receive Checksum Offload Engine (COE):</p> <ul style="list-style-type: none"> <li>■ 3'b000: Unknown type or IP/AV payload not processed</li> <li>■ 3'b001: UDP</li> <li>■ 3'b010: TCP</li> <li>■ 3'b011: ICMP</li> <li>■ 3'b110: AV Tagged Data Packet</li> <li>■ 3'b111: AV Tagged Control Packet</li> <li>■ 3'b101: AV Untagged Control Packet</li> <li>■ 3'b100: IGMP if IPV4 Header Present bit is set else DCB (LLDP) Control Packet</li> </ul> <p>If the COE does not process the payload of an IP datagram because there is an IP header error or fragmented IP, it sets these bits to 3'b000.</p> |

Table 19-21 TDES2 Normal Descriptor(Write-Back Format)

| Bit   | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | L3L4FM | <p>Layer 3 and Layer 4 Filter Number Matched<br/>These bits indicate the number of the Layer 3 and Layer 4 Filter that matched the received packet:</p> <ul style="list-style-type: none"> <li>■ 000: Filter 0</li> <li>■ 001: Filter 1</li> <li>■ 010: Filter 2</li> <li>■ 011: Filter 3</li> <li>■ 100: Filter 4</li> <li>■ 101: Filter 5</li> <li>■ 110: Filter 6</li> <li>■ 111: Filter 7</li> </ul> <p>This field is valid only when Bit 28 or Bit 27 is set high. When more than one filter matches, these bits give the number of lowest filter.</p> <p>Note: This status is not available when Flexible RX Parser is enabled.</p> |
| 28    | L4FM   | <p>Layer 4 Filter Match<br/>When this bit is set, it indicates that the received packet matches one of the enabled Layer 4 Port Number fields. This status is given only when one of the following conditions is true:</p> <ul style="list-style-type: none"> <li>■ Layer 3 fields are not enabled and all enabled Layer 4 fields match</li> </ul>                                                                                                                                                                                                                                                                                        |

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | <ul style="list-style-type: none"> <li>■ All enabled Layer 3 and Layer 4 filter fields match</li> </ul> <p>When more than one filter matches, this bit gives the layer 4 filter status of filter indicated by Bits[31:29]. Note: This status is not available when Flexible RX Parser is enabled.</p>                                                                                                                                                                                                                                                                                                  |
| 27    | L3FM     | <p>Layer 3 Filter Match</p> <p>When this bit is set, it indicates that the received packet matches one of the enabled Layer 3 IP Address fields. This status is given only when one of the following conditions is true:</p> <ul style="list-style-type: none"> <li>■ All enabled Layer 3 fields match and all enabled Layer 4 fields are bypassed</li> <li>■ All enabled filter fields match</li> </ul> <p>When more than one filter matches, this bit gives the layer 3 filter status of filter indicated by Bits[31:29]. Note: This status is not available when Flexible RX Parser is enabled.</p> |
| 26:19 | MADRM    | <p>MAC Address Match or Hash Value</p> <p>When the HF bit is reset, this field contains the MAC address register number that matched the Destination address of the received packet. This field is valid only if the DAF bit is reset.</p> <p>When the HF bit is set, this field contains the hash value computed by the MAC. A packet passes the hash filter when the bit corresponding to the hash value is set in the hash filter register.</p> <p>Note: This status is not available when Flexible RX Parser is enabled.</p>                                                                       |
| 18    | HF       | <p>Hash Filter Status</p> <p>When this bit is set, it indicates that the packet passed the MAC address hash filter. Bits[26:19] indicate the hash value.</p> <p>Note: This status is not available when Flexible RX Parser is enabled.</p>                                                                                                                                                                                                                                                                                                                                                             |
| 17    | DAF/RXPI | <p>Destination Address Filter Fail</p> <p>When Flexible RX Parser is disabled, and this bit is set, it indicates that the packet failed the DA Filter in the MAC. When Flexible RX Parser is enabled, this bit is set to indicate that the packet parsing is incomplete (RXPI) due to ECC error.</p> <p>Note: When this bit is set, ES bit of RDES3 is also set.</p>                                                                                                                                                                                                                                   |
| 16    | SAF/RXPD | <p>SA Address Filter Fail</p> <p>When Flexible RX Parser is disabled, and this bit is set, it indicates that the packet failed the SA Filter in the MAC. When Flexible RX Parser is enabled, this bit is set to indicate that the packet is dropped (RXPD) by the parser.</p> <p>Note: When this bit is set, ES bit of RDES3 is also set.</p>                                                                                                                                                                                                                                                          |
| 15    | OTS      | <p>VLAN Filter Status</p> <p>When set, this bit indicates that the VLAN Tag of the received packet passed the VLAN filter.</p> <p>This bit is valid only when GMAC_ERVFE is not enabled. If GMAC_ERVFE is enabled, the bit is redefined as Outer VLAN Tag Filter Status (OTS).</p> <p>This bit is valid for both Single and Double VLAN Tagged frames.</p>                                                                                                                                                                                                                                             |
| 14    | ITS      | Inner VLAN Tag Filter Status (ITS)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | This bit is valid only when GMAC_ERVFE is enabled.<br>This bit is valid only for Double VLAN Tagged frames, when Double VLAN Processing is enabled.<br>For more information, see the Filter Status topic.                                                                                                                                                                                                                                                                                                                   |
| 13:11 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10    | ARPNR    | ARP Reply Not Generated<br>When this bit is set, it indicates that the MAC did not generate the ARP Reply for received ARP Request packet. This bit is set when the MAC is busy transmitting ARP reply to earlier ARP request (only one ARP request is processed at a time).<br>This bit is reserved when the Enable IPv4 ARP Offload option is not selected.                                                                                                                                                               |
| 9:0   | HL       | L3/L4 Header Length<br>This field contains the length of the header of the packet split by the MAC at L3 or L4 header boundary as identified by the MAC receiver. This field is valid only when the first descriptor bit is set (FD = 1). The header data is written to the Buffer 1 address of corresponding descriptor. If header length is zero, this field is not valid. It implies that the MAC did not identify and split the header.<br>This field is valid when the Enable Split Header Feature option is selected. |

Table 19-22 TDES3 Normal Descriptor(Write-Back Format)

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | OWN  | Own Bit<br>When this bit is set, it indicates that the GMAC DMA owns the descriptor. When this bit is reset, it indicates that the application owns the descriptor. The DMA clears this bit when either of the following conditions is true: <ul style="list-style-type: none"><li>■ The DMA completes the packet reception</li><li>■ The buffers associated with the descriptor are full</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 30  | CTXT | Receive Context Descriptor<br>When this bit is set, it indicates that the current descriptor is a context type descriptor. The DMA writes 1'b0 to this bit for normal receive descriptor.<br>When CTXT and FD bits are used together, {CTXT, FD} <ul style="list-style-type: none"><li>■ 2'b00: Intermediate Descriptor</li><li>■ 2'b01: First Descriptor</li><li>■ 2'b10: Reserved</li><li>■ 2'b11: Descriptor Error (due to all 1s)</li></ul> Note: When Descriptor Error occurs, the Receive DMA closes the receive descriptor indicating Descriptor Error. This receive descriptor is skipped and the buffer addresses are not used to write the packet data. Receive DMA will set the CDE bit in DMA_CH#_Status register but not the RI bit even when IOC is set, as this is not marked as last receive descriptor for the packet. The subsequent valid receive descriptor is used to write the packet data. |
| 29  | FD   | First Descriptor<br>When this bit is set, it indicates that this descriptor contains the first buffer of the packet. If the size of the first buffer is 0, the second buffer contains the beginning of the packet. If the size of the second buffer is also 0, the next descriptor contains the beginning of the packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |             | See the CTXT bit description for details of using the CTXT bit and FD bit together.                                                                                                                                                                                                                                                                                                    |
| 28         | LD          | Last Descriptor<br>When this bit is set, it indicates that the buffers to which this descriptor is pointing are the last buffers of the packet.                                                                                                                                                                                                                                        |
| 27         | RS2V        | Receive Status RDES2 Valid<br>When this bit is set, it indicates that the status in RDES2 is valid and it is written by the DMA. This bit is valid only when the LD bit of RDES3 is set.                                                                                                                                                                                               |
| 26         | RS1V        | Receive Status RDES1 Valid<br>When this bit is set, it indicates that the status in RDES1 is valid and it is written by the DMA. This bit is valid only when the LD bit of RDES3 is set.                                                                                                                                                                                               |
| 25         | RS0V        | Receive Status RDES0 Valid<br>When this bit is set, it indicates that the status in RDES0 is valid and it is written by the DMA. This bit is valid only when the LD bit of RDES3 is set.                                                                                                                                                                                               |
| 24         | CE          | CRC Error<br>When this bit is set, it indicates that a Cyclic Redundancy Check (CRC) Error occurred on the received packet. This field is valid only when the LD bit of RDES3 is set.                                                                                                                                                                                                  |
| 23         | GP          | Giant Packet<br>When this bit is set, it indicates that the packet length exceeds the specified maximum Ethernet size of 1518, 1522, or 2000 bytes (9018 or 9022 bytes if jumbo packet enable is set).<br>Note: Giant packet indicates only the packet length. It does not cause any packet truncation.                                                                                |
| 22         | RWT         | Receive Watchdog Timeout<br>When this bit is set, it indicates that the Receive Watchdog Timer has expired while receiving the current packet. The current packet is truncated after watchdog timeout.                                                                                                                                                                                 |
| 21         | OE          | Overflow Error<br>When this bit is set, it indicates that the received packet is damaged because of buffer overflow in Rx FIFO.<br>Note: This bit is set only when the DMA transfers a partial packet to the application. This happens only when the Rx FIFO is operating in the threshold mode. In the store-and-forward mode, all partial packets are dropped completely in Rx FIFO. |
| 20         | RE          | Receive Error<br>When this bit is set, it indicates that the gmii_rxer_i signal is asserted while the gmii_rxdv_i signal is asserted during packet reception. This error also includes carrier extension error in the GMII and half-duplex mode. Error can be of less or no extension, or error (rxd!= 0f) during extension.                                                           |
| 19         | DE          | Dribble Bit Error<br>When this bit is set, it indicates that the received packet has a non-integer multiple of bytes (odd nibbles). This bit is valid only in the MII Mode.                                                                                                                                                                                                            |
| 18:16      | LT          | Length/Type Field<br>This field indicates if the packet received is a length packet or a type packet. The encoding of the 3 bits is as follows:                                                                                                                                                                                                                                        |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | <ul style="list-style-type: none"> <li>■ 3'b000: The packet is a length packet</li> <li>■ 3'b001: The packet is a type packet.</li> <li>■ 3'b011: The packet is a ARP Request packet type</li> <li>■ 3'b100: The packet is a type packet with VLAN Tag</li> <li>■ 3'b101: The packet is a type packet with Double VLAN Tag</li> <li>■ 3'b110: The packet is a MAC Control packet type</li> <li>■ 3'b111: The packet is a OAM packet type</li> <li>■ 3'b010: Reserved</li> </ul>                                                                                                                                                               |
| 15  | ES   | <p>Error Summary<br/>When this bit is set, it indicates the logical OR of the following bits:</p> <ul style="list-style-type: none"> <li>■ RDES3[24]: CRC Error</li> <li>■ RDES3[19]: Dribble Error</li> <li>■ RDES3[20]: Receive Error</li> <li>■ RDES3[22]: Watchdog Timeout</li> <li>■ RDES3[21]: Overflow Error</li> <li>■ RDES3[23]: Giant Packet</li> <li>■ RDES2[17]: Destination Address Filter Fail, when Flexible RX Parser is enabled</li> <li>■ RDES2[16]: SA Address Filter Fail, when Flexible RX Parser is enabled</li> </ul> <p>This field is valid only when the LD bit of RDES3 is set.</p>                                 |
| 14  | PL   | <p>Packet Length<br/>These bits indicate the byte length of the received packet that was transferred to system memory (including CRC). This field is valid when the LD bit of RDES3 is set and Overflow Error bits are reset. The packet length also includes the two bytes appended to the Ethernet packet when IP checksum calculation is enabled and the received packet is not a MAC control packet.</p> <p>This field is valid when the LD bit of RDES3 is set. When the Last Descriptor and Error Summary bits are not set, this field indicates the accumulated number of bytes that have been transferred for the current packet.</p> |

### 19.5.10 Receive Context Descriptor

This descriptor is read-only for the application. Only the DMA can write to this descriptor. The context descriptor provides information about the extended status related to the last received packet. The Bit 30 of RDES3 indicates the context type descriptor.

Table 19-23 TDES0 Context Descriptor

| Bit  | Name | Description                                                                                                                                                                                                                                                                 |
|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RSTL | <p>Receive Packet Timestamp Low<br/>The DMA updates this field with least significant 32 bits of the timestamp captured for corresponding Receive packet. When this field and the RTSH field of RDES1 show all-ones value, the timestamp must be considered as corrupt.</p> |

Table 19-24 TDES1 Context Descriptor

| Bit  | Name | Description                                                                                                                                                                                                                                                                 |
|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RTSH | <p>Receive Packet Timestamp High<br/>The DMA updates this field with most significant 32 bits of the timestamp captured for corresponding receive packet. When this field and the RTSL field of RDES0 show all-ones value, the timestamp must be considered as corrupt.</p> |

Table 19-25 TDES2 Context Descriptor

| Bit  | Name     | Description |
|------|----------|-------------|
| 31:0 | Reserved | Reserved    |

Table 19-26 TDES3 Context Descriptor

| Bit  | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | OWN      | <p>Own Bit<br/>When this bit is set, it indicates that the DMA owns the descriptor. When this bit is reset, it indicates that the application owns the descriptor. The DMA clears this bit when either of the following conditions is true:</p> <ul style="list-style-type: none"> <li>■ The DMA completes the packet reception</li> <li>■ The buffers associated with the descriptor are full</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 30   | CTXT     | <p>Receive Context Descriptor<br/>When this bit is set, it indicates that the current descriptor is a context descriptor. The DMA writes 1'b1 to this bit for context descriptor. DMA writes 2'b11 to indicate a descriptor error due to all 1s.<br/>When CTXT and DE bits are used together, {CTXT, DE}</p> <ul style="list-style-type: none"> <li>■ 2'b00: Reserved</li> <li>■ 2'b01: Reserved</li> <li>■ 2'b10: Context Descriptor</li> <li>■ 2'b11: Descriptor Error</li> </ul> <p>Note: When Descriptor Error occurs, the Receive DMA closes the receive descriptor indicating Descriptor Error. This receive descriptor is skipped and the buffer addresses are not used to write the packet data. Receive DMA will set the CDE bit in DMA_CH#_Status register but not the RI bit even when IOC is set, as this is not marked as last receive descriptor for the packet. The subsequent valid receive descriptor is used to write the packet data.</p> |
| 29   | DE       | Descriptor Error<br>See the CTXT bit description for details of using the DE bit along with CTXT bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 28:0 | Reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### 19.5.11 Clock Architecture

In RMII mode, reference clock and TX/RX clock be from PHY as following figure. The mux selecting rmii\_speed is GRF\_GMAC\_CLK\_CON[2].



Fig. 19-11 RMII Clock Architecture When Clock Source From PHY

Rockchip Confidential

## Chapter 20 SAR-ADC

### 20.1 Overview

The ADC is a 2-channel single-ended 10-bit Successive Approximation Register (SAR) A/D Converter. It uses the supply and ground as its reference which avoids the use of any external reference. The input range is typically 0V to 1.8V.

SAR-ADC controller supports the following features:

- Support single mode and series conversion mode.
- In single mode, the conversion operates once each software is accessed.
- In series conversion, the controller samples each channel then loops until the software stops conversion.
- High/low threshold can be set, higher/lower/between high-low-threshold interrupt can be enabled

### 20.2 Block Diagram

SAR-ADC block shows in Fig.1-1. This includes:

- APB Interface
- Control FSM
- SAR-ADC PHY

The software can configure the SAR-ADC controller by APB interface, then the inter FSM will communicate with SAR-ADC PHY for limited timing requests.



Fig. 20-1 SAR-ADC Block Diagram

### 20.3 Function Description

SAR-ADC block includes controller and PHY, user cannot directly access SAR-ADC PHY. Software access the SAR-ADC through SAR-ADC controller by APB interface. SAR-ADC controller will sample the conversion result from SAR-ADC PHY.

### 20.4 Register Description

#### 20.4.1 Registers Summary

| Name            | Offset | Size | Reset Value | Description                   |
|-----------------|--------|------|-------------|-------------------------------|
| SARADC CONV CON | 0x0000 | W    | 0x00000000  | Conversion control            |
| SARADC T PD SOC | 0x0004 | W    | 0x00026000  | Timing control for PD to SOC  |
| SARADC T AS SOC | 0x0008 | W    | 0x00000000  | Timing control for assert SOC |

| Name              | Offset | Size | Reset Value | Description                                              |
|-------------------|--------|------|-------------|----------------------------------------------------------|
| SARADC T_DAS_SOC  | 0x000C | W    | 0x00000007  | Timing control from dis-assert SOC to change the channel |
| SARADC T_SEL_SOC  | 0x0010 | W    | 0x00000002  | Timing control from change channel to assert SOC         |
| SARADC HIGH COMP0 | 0x0014 | W    | 0x00000000  | High threshold for adc output data                       |
| SARADC HIGH COMP1 | 0x0018 | W    | 0x00000000  | High threshold for adc output data                       |
| SARADC LOW COMP0  | 0x0054 | W    | 0x00000000  | Low threshold for adc output data                        |
| SARADC LOW COMP1  | 0x0058 | W    | 0x00000000  | Low threshold for adc output data                        |
| SARADC DEBOUNCE   | 0x0094 | W    | 0x00000003  | Threshold debounce                                       |
| SARADC HT INT EN  | 0x0098 | W    | 0x00000000  | High threshold int enable                                |
| SARADC LT INT EN  | 0x009C | W    | 0x00000000  | Low threshold int enable                                 |
| SARADC MT INT EN  | 0x0100 | W    | 0x00000000  | Middle threshold int enable                              |
| SARADC END INT EN | 0x0104 | W    | 0x00000000  | End conversion int enable                                |
| SARADC STATUS     | 0x010C | W    | 0x00000002  | Adc status                                               |
| SARADC END INT ST | 0x0110 | W    | 0x00000000  | End conversion int state                                 |
| SARADC HT INT ST  | 0x0114 | W    | 0x00000000  | High threshold int state                                 |
| SARADC LT INT ST  | 0x0118 | W    | 0x00000000  | Low threshold int state                                  |
| SARADC MT INT ST  | 0x011C | W    | 0x00000000  | Middle threshold int state                               |
| SARADC DATA0      | 0x0120 | W    | 0x00000000  | ADC output data                                          |
| SARADC DATA1      | 0x0124 | W    | 0x00000000  | ADC output data                                          |
| SARADC AUTO CH EN | 0x0160 | W    | 0x00000000  | Channel enable in auto channel mode                      |

Notes: **Size:** **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 20.4.2 Detail Registers Description

### SARADC CONV CON

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                                                                      |
| 15:10 | RO   | 0x00        | reserved                                                                                                                                                                                               |
| 9     | RW   | 0x0         | int_lock<br>This is used to lock the sample data when an interrupt happened.<br>1'b1: Enable lock.<br>1'b0: Disable lock.                                                                              |
| 8     | RW   | 0x0         | as_pd_mode<br>If this bit is set to 1'b1, each time conversion ends, PD will be asserted. Then next time conversion starts, PD will be set to low auto automatically. This is not used in signal mode. |
| 7     | W1C  | 0x0         | end_conv<br>End conversion, this is not used when CONV_CON[5] is set to 1'b1. If this bit is set to 1'b1, PD will be set to 1'b1 after the last conversion and this bit will be cleared to 1'b0.       |
| 6     | RW   | 0x0         | auto_channel_mode<br>Auto channel mode.<br>If this is enabled, the channel will be round auto according to which is set in AUTO_CH_EN.                                                                 |
| 5     | RW   | 0x0         | single_pd_mode<br>Single conversion mode. If this bit is set to 1, the conversion only operates once, then PD single will be set to 1.                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | W1C         | 0x0                | start_adc<br>Enable ADC, if this bit is set to one, the conversion will start. Then this bit will be clear to 0.                                                      |
| 3:0        | RW          | 0x0                | channel_sel<br>Channel for SARADC, 2 channel is supported. This field is not used when CONV_CON[6] is set to 1.<br>4'd0: Select channel 0.<br>4'd1: Select channel 1. |

**SARADC T PD SOC**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:21      | RO          | 0x000              | reserved                                                            |
| 20:13      | RW          | 0x13               | t_pd_soc<br>Timing control between power up to start-of-conversion. |
| 12:0       | RO          | 0x0000             | reserved                                                            |

**SARADC T AS SOC**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:0       | RW          | 0x00000000         | t_as_soc<br>Timing control for assert SOC signal. |

**SARADC T DAS SOC**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RW          | 0x00000007         | t_das_soc<br>Timing from dis-assret SOC to channel change. |

**SARADC T SEL SOC**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                             |
| 15:0       | RW          | 0x0002             | t_sel_soc<br>Timing from channel load to SOC assert. |

**SARADC HIGH COMPO**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                        |
| 11:0       | RW          | 0x000              | high_comp0<br>High threshold for ADC output data for channel 0. |

**SARADC HIGH COMP1**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                        |
| 11:0       | RW          | 0x000              | high_comp1<br>High threshold for ADC output data for channel 1. |

**SARADC LOW COMPO**

Address: Operational Base + offset (0x0054)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 11:0       | RW          | 0x000              | low_comp0<br>Low threshold for ADC output data for channel 0. |

**SARADC LOW COMP1**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                      |
| 11:0       | RW          | 0x000              | low_comp1<br>Low threshold for ADC output data for channel 1. |

**SARADC DEBOUNCE**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                         |
| 7:0        | RW          | 0x03               | debounce<br>ADC controller will only generate interrupt data if higher/lower/between the setting threshold for "debounce" times. |

**SARADC HT INT EN**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                          |
| 1          | RW          | 0x0                | ht_int_en1<br>High threshold interrupt for channel1.<br>1'b1: Enable ht intr.<br>1'b0: Disable ht intr.                           |
| 0          | RW          | 0x0                | ht_int_en0<br>High threshold interrupt for channel0.<br>1'b1: Enable ht intr.<br>1'b0: Disable ht intr.                           |

**SARADC LT INT EN**

Address: Operational Base + offset (0x009C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                          |
| 1          | RW          | 0x0                | lt_int_en1<br>Low threshold interrupt for channel1.<br>1'b1: Enable lt intr.<br>1'b0: Disable lt intr.                            |
| 0          | RW          | 0x0                | lt_int_en0<br>Low threshold interrupt for channel0.<br>1'b1: Enable lt intr.<br>1'b0: Disable lt intr.                            |

**SARADC MT INT EN**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                          |
| 1          | RW          | 0x0                | mt_int_en1<br>Middle threshold interrupt for channel1.<br>1'b1: Enable ht intr.<br>1'b0: Disable ht intr.                         |
| 0          | RW          | 0x0                | mt_int_en0<br>Middle threshold interrupt for channel0.<br>1'b1: Enable ht intr.<br>1'b0: Disable ht intr.                         |

**SARADC END INT EN**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | WO          | 0x0000             | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                          |
| 0          | RW          | 0x0                | end_int_en<br>1'b1: Enable end conversion intr.<br>1'b0: Disable end conversion intr.                                             |

**SARADC STATUS**

Address: Operational Base + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                               |
| 5:2        | RO          | 0x0                | sel<br>ADC channel.                                                                                    |
| 1          | RO          | 0x1                | pd<br>1'b1: ADC is power down.<br>1'b0: ADC is power up and in conversion.                             |
| 0          | RO          | 0x0                | conv_st<br>Conversion status<br>1'b1: ADC controller FSM is busy.<br>1'b0: ADC controller FSM is idle. |

**SARADC END INT ST**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                         |
| 0          | W1 C        | 0x0                | end_int_st<br>ADC end conversion interrupt status.<br>1'b1: Interrupt happened.<br>1'b0: Interrupt not happened. |

**SARADC HT INT ST**

Address: Operational Base + offset (0x0114)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 1          | W1<br>C     | 0x0                | ht_int_st1<br>High threshold interrupt state for channel1.<br>1'b1: Interrupt happened.<br>1'b0: Interrupt not happened. |
| 0          | W1<br>C     | 0x0                | ht_int_st0<br>High threshold interrupt state for channel0.<br>1'b1: Interrupt happened.<br>1'b0: Interrupt not happened. |

**SARADC\_LT\_INT\_ST**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                |
| 1          | W1<br>C     | 0x0                | lt_int_st1<br>Low threshold interrupt state for channel1.<br>1'b1: Interrupt happened.<br>1'b0: Interrupt not happened. |
| 0          | W1<br>C     | 0x0                | lt_int_st0<br>Low threshold interrupt state for channel0.<br>1'b1: Interrupt happened.<br>1'b0: Interrupt not happened. |

**SARADC\_MT\_INT\_ST**

Address: Operational Base + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                 |
| 1          | W1<br>C     | 0x0                | mt_int_st1<br>Between high and low threshold interrupt state for channel1.<br>1'b1: Interrupt happened.<br>1'b0: Interrupt not happened. |
| 0          | W1<br>C     | 0x0                | mt_int_st0<br>Between high and low threshold interrupt state for channel0.<br>1'b1: Interrupt happened.<br>1'b0: Interrupt not happened. |

**SARADC\_DATA0**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:12      | RO          | 0x00000            | reserved                     |
| 11:0       | RO          | 0x000              | data0<br>ADC channel 0 data. |

**SARADC\_DATA1**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:12      | RO          | 0x00000            | reserved                     |
| 11:0       | RO          | 0x000              | data1<br>ADC channel 1 data. |

**SARADC\_AUTO\_CH\_EN**

Address: Operational Base + offset (0x0160)

| Bit   | Attr | Reset Value | Description                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | write_enable<br>Write enable for lower 16bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:2  | RO   | 0x0000      | reserved                                                                                                                          |
| 1     | RW   | 0x0         | auto_ch1_en<br>Enable channel 1 in auto channel mode.                                                                             |
| 0     | RW   | 0x0         | auto_ch0_en<br>Enable channel 0 in auto channel mode.                                                                             |

## 20.5 Application Notes

### Steps of ADC conversion in series conversion mode:

- Decide which channel should be used and whether auto\_channel mode should be set. In auto\_channel mode, the channel will be changed from 0-1 then to 0. Please refer to the SARADC\_CONV\_CON register.
- Set SARADC\_CONV\_CON[4] to 1'b1, then the conversion will start.
- If conversion wants to be ended, set SARADC\_CONV\_CON[7] to 1'b1.
- Conversion could be read from SARADC\_DATA $n$  ( $n$  is from 0-1).
- If threshold compare interrupt wants to be used, high/low threshold could be set, and interrupt should be set as an application.
- If auto\_channel mode is not set, you could set the channel as an application.

### Steps of ADC conversion in single mode:

- Decide which channel should be used and set SARADC\_CONV\_CON[3:0].
- Set SARADC\_CONV\_CON[5] to 1'b1.
- Set SARADC\_CONV\_CON[4] to 1'b1, then the conversion will start.
- The conversion only operates once then ends. PD will be asserted and PD status could be got by reading SARADC\_STATUS.
- Conversion could be read from SARADC\_DATA $n$  ( $n$  is from 0-1).

## Chapter 21 Audio Codec

### 21.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 90dB SNR
- Support 16~32Ω headphone out and line output
- Low power: 5mA for stereo playback
- 24 bits ADC with 90dB SNR
- Support differential and single-ended microphone or line input
- Low power: 5mA for stereo recording
- Automatic Level Control (ALC) for smooth audio recording
- Low power: 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/12kHz/16kHz/24kHz/32kHz/44.1kHz/48kHz/64kHz/96kHz
- 1.8V supply for analog and 0.8V supply for digital

### 21.2 Block Diagram



Fig. 21-1 Audio Codec Block Diagram

### 21.3 Function Description

#### 21.3.1 Digital Interface

Acodec Codec 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.

Table 21-1 Supported Data Formats in Different Modes

| Data Formats    | ADC    |       | DAC    |       |
|-----------------|--------|-------|--------|-------|
|                 | Master | Slave | Master | Slave |
| Left Justified  | ✓      | ✗     | ✓      | ✓     |
| Right Justified | ✓      | ✓     | ✓      | ✓     |
| I2S             | ✓      | ✓     | ✓      | ✓     |
| DSP/PCM mode A  | ✓      | ✓     | ✓      | ✓     |
| DSP/PCM mode B  | ✓      | ✗     | ✓      | ✓     |

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. 1-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. 21-2 Left Justified Mode (assuming n-bit word length)

For Right Justified mode, the data format is shown in Fig. 1-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. 21-3 Right Justified Mode (assuming n-bit word length)

For I2S mode, the data format is depicted in Fig. 1-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. 21-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. 1-5 and Fig.1-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. 21-5 DSP/PCM Mode A (assuming n-bit word length)



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

### 21.3.2 Analog Interface



Fig. 21-7 Microphone Input

There are two inputs channels named left ADC channel and right ADC channel. In each channel, there are two inputs which are configured as differential input by the microphone PGA (MICL and MICR).

In the left channel, microphone inputs are MICPL and MICNL. In the right channel, microphone inputs are MICPR and MICRL.

Microphone PGA has a gain range from 0dB to 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 PAG (ALC\_L and ALC\_R) gain according to the comparison result. The programmable gain range of ALC controlled PAG is from -18dB to +28.5dB. The tuning step is 1.5dB.

Audio Codec supports headphone output or line output configurations. The 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.7\text{uF}$  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\text{Hz}$$

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



Fig. 21-8 Output DC-blocking capacitor

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

The output of the Microphone bias is used for bias external microphones. The bias voltage can vary from  $0.5 * \text{AVDD}$  to  $0.85 * \text{AVDD}$  with a step of  $0.05 * \text{AVDD}$ .

### 21.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.



Fig. 21-9 ADC Channels Relationship



Fig. 21-10 DAC Channels Relationship

## 21.4 Register Description

### 21.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

### 21.4.2 Registers Summary

| Name         | Offset | Size | Reset Value | Description |
|--------------|--------|------|-------------|-------------|
| ACODEC REG0  | 0x0000 | W    | 0x00000003  |             |
| ACODEC REG1  | 0x0004 | W    | 0x00000007  |             |
| ACODEC REG2  | 0x0008 | W    | 0x00000050  |             |
| ACODEC REG3  | 0x000C | W    | 0x0000000E  |             |
| ACODEC REG4  | 0x0010 | W    | 0x00000050  |             |
| ACODEC REG5  | 0x0014 | W    | 0x0000000E  |             |
| ACODEC REG6  | 0x0018 | W    | 0x000000F1  |             |
| ACODEC REG7  | 0x001C | W    | 0x00000000  |             |
| ACODEC REG8  | 0x0020 | W    | 0x000000C3  |             |
| ACODEC REG9  | 0x0024 | W    | 0x000000C3  |             |
| ACODEC REG10 | 0x0028 | W    | 0x00000084  |             |
| ACODEC REG11 | 0x002C | W    | 0x000000F1  |             |
| ACODEC REG12 | 0x0030 | W    | 0x000000F1  |             |
| ACODEC REG13 | 0x0034 | W    | 0x00000003  |             |
| ACODEC REG14 | 0x0038 | W    | 0x000000C3  |             |
| ACODEC REG32 | 0x0050 | W    | 0x000000C7  |             |
| ACODEC REG33 | 0x0054 | W    | 0x00000000  |             |
| ACODEC REG34 | 0x0058 | W    | 0x00000000  |             |
| ACODEC REG35 | 0x005C | W    | 0x00000000  |             |
| ACODEC REG36 | 0x0060 | W    | 0x00000007  |             |
| ACODEC REG37 | 0x0064 | W    | 0x00000000  |             |
| ACODEC REG38 | 0x0068 | W    | 0x0000000A  |             |
| ACODEC REG39 | 0x006C | W    | 0x0000000A  |             |
| ACODEC REG40 | 0x0070 | W    | 0x00000000  |             |
| ACODEC REG41 | 0x0074 | W    | 0x00000010  |             |
| ACODEC REG42 | 0x0078 | W    | 0x00000002  |             |
| ACODEC REG43 | 0x007C | W    | 0x00000000  |             |

| Name         | Offset | Size | Reset Value | Description |
|--------------|--------|------|-------------|-------------|
| ACODEC REG47 | 0x0080 | W    | 0x000000021 |             |
| ACODEC REG64 | 0x00A0 | W    | 0x000000000 |             |
| ACODEC REG65 | 0x00A4 | W    | 0x000000046 |             |
| ACODEC REG66 | 0x00A8 | W    | 0x000000041 |             |
| ACODEC REG67 | 0x00AC | W    | 0x00000002C |             |
| ACODEC REG68 | 0x00B0 | W    | 0x000000000 |             |
| ACODEC REG69 | 0x00B4 | W    | 0x000000026 |             |
| ACODEC REG70 | 0x00B8 | W    | 0x000000040 |             |
| ACODEC REG71 | 0x00BC | W    | 0x000000036 |             |
| ACODEC REG72 | 0x00C0 | W    | 0x000000020 |             |
| ACODEC REG73 | 0x00C4 | W    | 0x000000038 |             |

Notes:**S**ize: **B**- Byte (8 bits) access, **H**W- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

#### 21.4.3 Detail Register Description

##### ACODEC REG0

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                                                                         |
| 1    | RW   | 0x1         | codec digital core reset<br>This reset only reset the codec data path.<br>0: Reset<br>1: Work                                    |
| 0    | RW   | 0x1         | codec system reset<br>This signal will reset the registers which control all the digital and analog part.<br>0: Reset<br>1: Work |

##### ACODEC REG1

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                            |
| 7    | RW   | 0x0         | dac_mute_en<br>The enable signal of mute dac<br>0:Disable<br>1:Enable               |
| 6:4  | RO   | 0x0         | reserved                                                                            |
| 3    | RW   | 0x0         | dither_level<br>Select dither data which has different high bits completion number. |
| 2    | RW   | 0x1         | da_enable<br>When the value is 1 activated DEM function.                            |
| 1    | RW   | 0x1         | dither_enable<br>When the value is 1 activated dither function.                     |
| 0    | RW   | 0x1         | dither_Sign<br>0:High bits add ~lfsr<br>1:High bits add 0                           |

##### ACODEC REG2

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                         |
| 7          | RW          | 0x0                | lrc polarity<br>0: Normal<br>1: Reversal                                                                                                                                                                                                                                                                         |
| 6:5        | RW          | 0x2                | frame_width<br>ADC I2S configuration register[6:5] valid word Length in one 1/2frame<br>11: 32 bits<br>10: 24 bits<br>01: 20 bits<br>00: 16 bits                                                                                                                                                                 |
| 4:3        | RW          | 0x2                | adc_ode<br>11: PCM mode<br>10: I2S mode<br>01: Left justified mode<br>00: Right justified mode<br>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          | RW          | 0x0                | adc_i2s output<br>ADC_I2S output mix selection<br>0: ADC IIS interface output ADC data<br>1:ADC IIS interface output ADC left data and DAC left data received from DAC IIS interface                                                                                                                             |
| 1:0        | RW          | 0x0                | adc_data_select<br>I2s adc data select                                                                                                                                                                                                                                                                           |

**ACODEC REG3**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                         |
| 7          | RW          | 0x0                | mode3<br>DAC I2S mode select for IO pin<br>1: Master mode<br>0: Slave mode       |
| 6          | RW          | 0x0                | mode2<br>DAC I2S mode select for inner module<br>1: Master mode<br>0: Slave mode |
| 5          | RW          | 0x0                | mode1<br>ADC I2S mode select for IO pin<br>1: Master mode<br>0: Slave mode       |
| 4          | RW          | 0x0                | mode0<br>ADC I2S mode select for inner module<br>1: Master mode<br>0: Slave mode |
| 3:2        | RW          | 0x3                | adc frame length<br>01: Length is 24<br>11: Length is 32                         |
| 1          | RW          | 0x1                | reset<br>ADC I2S configuration register[9] reset<br>0: Reset<br>1: Work          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 0          | RW          | 0x0                | bit clock polarity<br>0: Normal<br>1: Reversal |

**ACODEC REG4**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                                    |
| 7          | RW          | 0x0                | lrc polarity<br>DAC I2S Configuration Register[7] LRC Polarity<br>0: Normal<br>1: Reversal                                                                                                                                                                                                                                                                  |
| 6:5        | RW          | 0x2                | frame_width<br>DAC I2S Configuration Register[6:5] Valid Word Length in one 1/2Frame<br>11: 32 bits<br>10: 24 bits<br>01: 20 bits<br>00: 16 bits                                                                                                                                                                                                            |
| 4:3        | RW          | 0x2                | mode<br>DAC I2S configuration register[4:3] mode<br>11: PCM mode<br>10: I2S mode<br>01: Left justified mode<br>00: Right justified mode<br>Note-1: 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          | RW          | 0x0                | swap<br>DAC I2S configuration register[2] DAC left-right swap<br>0: Normal<br>1: Swap                                                                                                                                                                                                                                                                       |
| 1:0        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                    |

**ACODEC REG5**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0000000          | reserved                                                                                                                                                                                           |
| 5:4        | RW          | 0x0                | de_emphasis<br>DAC de-emphasis filter selection<br>00: No de-emphasis filter work<br>01: 32K sample de-emphasis filter<br>10: 44.1K sample de-emphasis filter<br>11: 48K sample de-emphasis filter |
| 3:2        | RW          | 0x3                | frame_width<br>DAC I2S configuration register[11:10] 1/2frame word length<br>11: 32 bits(See Note 1)<br>10: 24 bits<br>01: 20 bits<br>00: 16 bits                                                  |
| 1          | RW          | 0x1                | reset<br>DAC I2S configuration register[9] reset<br>0: Reset<br>1: Work                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | bit clock polarity<br>DAC I2S configuration register[8] bit clock polarity<br>0: Normal<br>1: Reversal |

**ACODEC REG6**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                   |
| 7:0        | RW          | 0xf1               | digital_gain<br>DAC digital gain selection every step 0.5dB<br>8hf1: 0dB<br>8hff: 7dB<br>8hfe: 6.5dB<br>8h01: -120dB<br>8h00: Digital mute |

**ACODEC REG7**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0000000          | reserved                                                                                                                                                                            |
| 5:4        | RW          | 0x0                | bist_mode<br>DAC left channel bist mode select<br>01: Sine wave to the PCM bist mode enable and need to set the 0x00[7] )<br>Other: Normal left channel data to the PCM normal mode |
| 3:0        | RO          | 0x0                | reserved                                                                                                                                                                            |

**ACODEC REG8**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                         |
| 7:0        | RW          | 0xc3               | digital_volume<br>Left ADC digital volume control<br>8'h0: Digital mute<br>8'h1: -97dB<br>8'h2: -96.5dB<br>... 0.5dB steps up to<br>8'hff: +30dB |

**ACODEC REG9**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                         |
| 7:0        | RW          | 0xc3               | digital_volume<br>Left ADC digital volume control<br>8'h0: Digital mute<br>8'h1: -97dB<br>8'h2: -96.5dB<br>... 0.5dB steps up to<br>8'hff: +30dB |

**ACODEC REG10**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                |
| 7          | RW          | 0x1                | filter enable<br>1: Enable<br>0: Disable                                                                                                |
| 6          | RW          | 0x0                | agc select<br>1: Filter output<br>0: Sinc output                                                                                        |
| 5          | RW          | 0x0                | gain1<br>0: Choose the register0x26[4:0] to control the gain of the PGA<br>1: Choose the ALCL module to control the gain of the PGA     |
| 4          | RW          | 0x0                | gain0<br>0: Choose the register0x27[4:0] to control the gain of the PGA<br>1: Choose the ALCR module to control the gain of the PGA     |
| 3:2        | RW          | 0x1                | hdc<br>ADC HPF disable control<br>1: Disable HPF<br>0: Enable HPF                                                                       |
| 1          | RW          | 0x0                | rcdpi<br>ADC right channel data polarity invert<br>1: Right channel data polarity invert<br>0: Right channel data polarity not inverted |
| 0          | RW          | 0x0                | lxdpi<br>ADC left channel data polarity invert<br>1: Left channel data polarity invert<br>0: Left channel data polarity not inverted    |

**ACODEC REG11**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:8       | RO          | 0x000000           | reserved                         |
| 7:0        | RW          | 0xf1               | delay_cnt1<br>Initial delay cnt1 |

**ACODEC REG12**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:8       | RO          | 0x000000           | reserved                         |
| 7:0        | RW          | 0xf1               | delay_cnt2<br>Initial delay cnt2 |

**ACODEC REG13**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                                    |
| 6:5        | RW          | 0x0                | cbms<br>ADC channel bist mode select<br>01: Sine wave to the PCM( bist mode enable and need to set the 0x00[7] ) Other: Normal left channel data to the PCM |
| 4:0        | RW          | 0x03               | dco<br>DAC config output[11:8]                                                                                                                              |

**ACODEC REG14**

Address: Operational Base + offset (0x0038)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 7:0        | RW          | 0xc3               | dco<br>DAC config output[7:0] |

**ACODEC REG32**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                    |
| 7:4        | RW          | 0xc                | eh<br>En_hpoutl[7] ini_hpoutl[6] en_hpoutr[5] ini_hpoutr[4] |
| 3:0        | RW          | 0x7                | diss<br>DAC ibias select signal                             |

**ACODEC REG33**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7:0        | RW          | 0x00               | sctp<br>The control signal to select current to precharge discharge.<br>7<br>0: Choose the Current I0<br>1: Dont choose the current I0<br>6<br>0: Choose the Current 2I0<br>1: Dont choose the current 2I0<br>5<br>0: Choose the Current 4I0<br>1: Dont choose the current 4I0<br>4<br>0: Choose the Current 8I0<br>1: Dont choose the current 8I0<br>3<br>0: Choose the Current 16I0<br>1: Dont choose the current 16I0<br>2<br>0: Choose the Current 32I0<br>1: Dont choose the current 32I0<br>1<br>0: Choose the Current 64 I0<br>1: Dont choose the current 64 I0<br>0<br>0: Choose the Current 128 I0<br>1: Dont choose the current 128 I0 |

**ACODEC REG34**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                          |
| 5          | RW          | 0x0                | srvm<br>The enable signal of reference voltage module:<br>0: Disable<br>1: Enable |
| 4          | RW          | 0x0                | scs<br>The enable signal of current source for ADC.<br>0: Disable<br>1: Enable    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | micbias<br>The enable signal of MIC bias voltage (MICBIAS) buffer<br>0: Stop working<br>1: Work                                                                                                            |
| 2:0        | RW          | 0x0                | mv<br>The level range control signal of MICBIAS voltage:<br>000: 0.8*AVDD<br>100: 0.9*AVDD<br>001: 0.825*AVDD<br>101: 0.925*AVDD<br>010: 0.85*AVDD<br>110: 0.95*AVDD<br>011: 0.875*AVDD<br>111: 0.975*AVDD |

**ACODEC REG35**

Address: Operational Base + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                |
| 7          | RW          | 0x0                | mmmal<br>The mute signal of MIC module in the ADCL.<br>0: Mute<br>1: Work                                                               |
| 6          | RW          | 0x0                | mmal<br>The initial signal of MIC module in the ADCL.<br>0: Initialization<br>1: Work                                                   |
| 5          | RW          | 0x0                | rbbad<br>The enable signal of reference voltage buffer of ADCL.<br>0: Disable<br>1: Enable                                              |
| 4          | RW          | 0x0                | aizcd<br>The enable signal of the ADCL input zero- crossing detection module:<br>0: Stop Working , output 0 electrical level<br>1: Work |
| 3          | RW          | 0x0                | mmia<br>The mute signal of MIC module in the ADCR.<br>0: Mute<br>1: Work                                                                |
| 2          | RW          | 0x0                | mma<br>The initial signal of MIC module in the ADCR.<br>0: Initialization<br>1: Work                                                    |
| 1          | RW          | 0x0                | rvba<br>The enable signal of reference voltage buffer of ADCR.<br>0: Disable<br>1: Enable                                               |
| 0          | RW          | 0x0                | aizc<br>The enable signal of the ADCR input zero- crossing detection module:<br>0: Stop Working , output 0 electrical level<br>1: Work  |

**ACODEC REG36**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                            |
| 7:6        | RW          | 0x0                | gsml<br>The gain signal of MIC module in the ADC left channel.<br>00: Reserved<br>10: 20dB<br>01: 0dB<br>11: 20dB   |
| 5:4        | RO          | 0x0                | gsmrr<br>The gain signal of MIC module in the ADC right channel.<br>00: Reserved<br>10: 20dB<br>01: 0dB<br>11: 20dB |
| 3:0        | RO          | 0x7                | adcis<br>ADC ibias select                                                                                           |

**ACODEC REG37**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0000000          | reserved                                                                                                                                   |
| 6          | RW          | 0x0                | ssadcl<br>The mode select signal in the ADC left channel<br>00: Full differential<br>01: Single-ended<br>10: Single-ended<br>11: Reserved  |
| 5          | RW          | 0x0                | alcle<br>ALCL enable<br>0: Disable<br>1: Enable                                                                                            |
| 4          | RW          | 0x0                | micle<br>MICL enable<br>0: Disable<br>1: Enable                                                                                            |
| 3:2        | RW          | 0x0                | ssadcr<br>The mode select signal in the ADC right channel<br>00: Full differential<br>01: Single-ended<br>10: Single-ended<br>11: Reserved |
| 1          | RW          | 0x0                | alcre<br>ALCR enable<br>0: Disable<br>1: Enable                                                                                            |
| 0          | RW          | 0x0                | micre<br>MICR enable<br>0: Disable<br>1: Enable                                                                                            |

**ACODEC REG38**

Address: Operational Base + offset (0x0068)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0 | RW   | 0x0a        | gsalcl<br>The gain signal of ALC module in the ADC left channel.<br>5'h00: -9dB<br>5'h0b: 7.5dB<br>5'h16: 24dB<br>5'h01: -7.5dB<br>5'h0c: 9dB<br>5'h17: 25.5dB<br>5'h02: -6dB<br>5'h0d: 10.5dB<br>5'h18: 27dB<br>5'h03: -4.5dB<br>5'h0e: 12dB<br>5'h19: 28.5dB<br>5'h04: -3dB<br>5'h0f: 13.5dB<br>5'h1a: 30dB<br>5'h05: -1.5dB<br>5'h10: 15dB<br>5'h1b: 31.5dB<br>5'h06: 0dB<br>5'h11: 16.5dB<br>5'h1c: 33dB<br>5'h07: 1.5dB<br>5'h12: 18dB<br>5'h1d: 34.5dB<br>5'h08: 3dB<br>5'h13: 19.5dB<br>5'h1e: 36dB<br>5'h09: 4.5dB<br>5'h14: 21dB<br>5'h1f: 37.5dB<br>5'h0a: 6dB<br>5'h15: 22.5dB |

**ACODEC REG39**

Address: Operational Base + offset (0x006C)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:4 | RO   | 0x00000000  | reserved    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | RW   | 0xa         | <p>gsalcr<br/>           The gain signal of ALC module in the ADC left channel.<br/>           5'h00: -9dB<br/>           5'h0b: 7.5dB<br/>           5'h16: 24dB<br/>           5'h01: -7.5dB<br/>           5'h0c: 9dB<br/>           5'h17: 25.5dB<br/>           5'h02: -6dB<br/>           5'h0d: 10.5dB<br/>           5'h18: 27dB<br/>           5'h03: -4.5dB<br/>           5'h0e: 12dB<br/>           5'h19: 28.5dB<br/>           5'h04: -3dB<br/>           5'h0f: 13.5dB<br/>           5'h1a: 30dB<br/>           5'h05: -1.5dB<br/>           5'h10: 15dB<br/>           5'h1b: 31.5dB<br/>           5'h06: 0dB<br/>           5'h11: 16.5dB<br/>           5'h1c: 33dB<br/>           5'h07: 1.5dB<br/>           5'h12: 18dB<br/>           5'h1d: 34.5dB<br/>           5'h08: 3dB<br/>           5'h13: 19.5dB<br/>           5'h1e: 36dB<br/>           5'h09: 4.5dB<br/>           5'h14: 21dB<br/>           5'h1f: 37.5dB<br/>           5'h0a: 6dB<br/>           5'h15: 22.5dB</p> |

**ACODEC REG40**

Address: Operational Base + offset (0x0070)

| Bit  | Attr | Reset Value | Description                                                                                                                        |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                                           |
| 7    | RW   | 0x0         | <p>isalcl<br/>           The initial signal of ALC module in the ADCL.<br/>           0: Initialization<br/>           1: Work</p> |
| 6    | RW   | 0x0         | <p>esckl<br/>           The enable signal of CLOCK for ADCL module<br/>           0: Set to logic 1<br/>           1: Work</p>     |
| 5    | RW   | 0x0         | <p>esadcl<br/>           The enable signal of ADC module in the ADCL.<br/>           0: Disable<br/>           1: Enable</p>       |
| 4    | RW   | 0x0         | <p>isadcl<br/>           The initial signal of ADC module in the ADCL.<br/>           0: Initialization<br/>           1: Work</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | isalcr<br>The initial signal of ALC module in the ADCR.<br>0: Initialization<br>1: Work |
| 2          | RW          | 0x0                | esckr<br>The enable signal of CLOCK for ADCR module<br>0: Set to logic 1<br>1: Work     |
| 1          | RW          | 0x0                | esadcr<br>The enable signal of ADC module in the ADCR.<br>0: Disable<br>1: Enable       |
| 0          | RW          | 0x0                | isadcr<br>The initial signal of ADC module in the ADCR.<br>0: Initialization<br>1: Work |

**ACODEC REG41**

Address: Operational Base + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                        |
| 7          | RW          | 0x0                | esibsdac<br>The enable signal of ibias for DAC channel.<br>0: Disable<br>1: Enable                              |
| 6          | RW          | 0x0                | esrvbdacr<br>The enable signal of reference voltage buffer in the right DAC channel.<br>0: Disable<br>1: Enable |
| 5:4        | RW          | 0x1                | cspdaci<br>The control signal of POP sound in the left DAC channel.<br>01: Initialization<br>10: Work           |
| 3          | RW          | 0x0                | esrvdacl<br>The enable signal of reference voltage of DACL module.<br>0: Disable<br>1: Enable                   |
| 2          | RW          | 0x0                | esclkdacl<br>The enable signal of clk in the right DAC channel.<br>0: Disable<br>1: Enable                      |
| 1          | RW          | 0x0                | esssdac<br>The enable signal of source signal for DAC channel.<br>0: Disable<br>1: Enable                       |
| 0          | RW          | 0x0                | isdaci<br>The initial signal of DAC module in the DACL.<br>0: Initialization<br>1: Work                         |

**ACODEC REG42**

Address: Operational Base + offset (0x0078)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | mshpdac1<br>The mute signal of HPOUTL module for DACL<br>0: Disable<br>1: Enable                                                                                  |
| 5          | RW          | 0x0                | ishpdac1<br>The Initial signal of HPOUTL for DACL module<br>0: Initialization<br>1: Work                                                                          |
| 4          | RW          | 0x0                | eshpdac1<br>The enable signal of HPOUTL for DACL module<br>0: Disable<br>1: Enable                                                                                |
| 3:0        | RW          | 0x2                | cdrv<br>Used to change DRV driver strength<br>0001: 100%<br>0101: 29.7%<br>0010: 60.1%<br>0110: 25.7%<br>0011: 44.2%<br>0111: 22.7%<br>0100: 35.5%<br>1000: 20.4% |

**ACODEC REG43**

Address: Operational Base + offset (0x007C)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0 | RW   | 0x00        | <p>gsdrvdac<br/>           The gain signal of DRV module in the DAC channel.<br/>           5'h00: -39dB<br/>           5'h0b: -22.5dB<br/>           5'h16: -6dB<br/>           5'h01: -37.5dB<br/>           5'h0c: -21dB<br/>           5'h17: -4.5dB<br/>           5'h02: -36dB<br/>           5'h0d: -19.5dB<br/>           5'h18: -3dB<br/>           5'h03: -34.5dB<br/>           5'h0e: -18dB<br/>           5'h19: -1.5dB<br/>           5'h04: -33dB<br/>           5'h0f: -16.5dB<br/>           5'h1a: 0dB<br/>           5'h05: -31.5dB<br/>           5'h10: -15dB<br/>           5'h1b: 1.5dB<br/>           5'h06: -30dB<br/>           5'h11: -13.5dB<br/>           5'h1c: 3dB<br/>           5'h07: -28.5dB<br/>           5'h12: -12dB<br/>           5'h1d: 4.5dB<br/>           5'h08: -27dB<br/>           5'h13: -10.5dB<br/>           5'h1e: 6dB<br/>           5'h09: -25.5dB<br/>           5'h14: -9dB<br/>           5'h1f: 6dB<br/>           5'h0a: -24dB<br/>           5'h15: -7.5dB</p> |

**ACODEC REG47**

Address: Operational Base + offset (0x0080)

| Bit  | Attr | Reset Value | Description                                                                                                                              |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                                                 |
| 7    | RW   | 0x0         | <p>esmdac<br/>           the enable signal of mix module in the DAC channel<br/>           0: Disable<br/>           1: Enable</p>       |
| 6:5  | RW   | 0x1         | <p>gsmdac<br/>           the gain signal of mix module in the DAC channel<br/>           01: 0db<br/>           10: 6db</p>              |
| 4    | RW   | 0x0         | <p>ismdac<br/>           the initial signal of mix module in the dac channel<br/>           0: Initialization<br/>           1: Work</p> |
| 3    | RW   | 0x0         | <p>msmdac<br/>           the mute signal of mix module in the dac channel<br/>           0: Mute<br/>           1:Work</p>               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0        | RW          | 0x1                | ssmdac<br>the select signal of mix module in the dac channel<br>001: Select input from i2s<br>010: Select line input from adcl<br>100: Select line input from adcr<br>Others reserved |

**ACODEC REG64**

Address: Operational Base + offset (0x00A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                 |
| 6          | RW          | 0x0                | cmcga<br>Choose the method to control the gain attack.<br>0 : Normal way<br>1 : Jack way                                                                                                                                                                 |
| 5:4        | RW          | 0x0                | fmgcs<br>There are four methods to generate the control signals<br>00: Normal way<br>01: Jack way 1<br>10: Jack way 2<br>11: Jack way 3<br>This register is used to choose the method to generate the control signals according to the actual situation. |
| 3:0        | RW          | 0x0                | agcht<br>AGC hold time before gain is increased in normal mode.<br>0000: 0ms<br>0110: 64ms<br>0001: 2ms<br>0111: 128ms<br>0010: 4ms<br>1000: 256ms<br>0011: 8ms<br>1001: 512ms<br>0100: 16ms<br>1010: 1s<br>0101: 32ms<br>1011~1111: 0ms                 |

**ACODEC REG65**

Address: Operational Base + offset (0x00A4)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RO          | 0x4                | <p>decay_time<br/>           Decay (gain ramp-up) time normal mode(reg_agc_mode =0)<br/>           0000: 500us<br/>           0110: 32ms<br/>           0001: 1ms<br/>           0111: 64ms<br/>           0010: 2ms<br/>           1000: 128ms<br/>           0011: 4ms<br/>           1001: 256ms<br/>           0100: 8ms<br/>           1010: 512ms<br/>           0101: 16ms<br/>           1011~1111: 512ms<br/>           Limter mode(reg_agc_mode =1)<br/>           0000: 125us<br/>           0110: 8ms<br/>           0001: 250us<br/>           0111: 16ms<br/>           0010: 500us<br/>           1000: 32ms<br/>           0011: 1ms<br/>           1001: 64ms<br/>           0100: 2ms<br/>           1010: 128ms<br/>           0101: 4ms<br/>           1011~1111: 128ms</p>   |
| 3:0        | RO          | 0x6                | <p>attack_time<br/>           Attack (gain ramp-down) time normal mode(reg_agc_mode =0)<br/>           0000: 125us<br/>           0110: 8ms<br/>           0001: 250us<br/>           0111: 16ms<br/>           0010: 500us<br/>           1000: 32ms<br/>           0011: 1ms<br/>           1001: 64ms<br/>           0100: 2ms<br/>           1010: 128ms<br/>           0101: 4ms<br/>           1011~1111: 125us<br/>           Limter mode(reg_agc_mode =1)<br/>           0000: 32us<br/>           0110: 2ms<br/>           0001: 64us<br/>           0111: 4ms<br/>           0010: 125us<br/>           1000: 8ms<br/>           0011: 250us<br/>           1001: 16ms<br/>           0100: 500us<br/>           1010: 32ms<br/>           0101: 1ms<br/>           1011~1111: 32us</p> |

**ACODEC REG66**

Address: Operational Base + offset (0x00A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                           |
| 7          | RW          | 0x0                | sagcm<br>Determines the AGC mode of operation<br>0: AGC mode(normal mode)<br>1: Limiter mode                                                                                                                                                       |
| 6          | RW          | 0x1                | agcuzc<br>AGC users zero cross enable<br>0: Disabled<br>1: Enabled, the AGC gain will update at zero cross enable                                                                                                                                  |
| 5          | RW          | 0x0                | las<br>When in the limiter mode, the low amplitude signal will recovery in two modes: 0: The gain will recovery to the value of the reg_pga_lvol<br>1: The gain will recovery to the gain at the moment when the mode changes from AGC to Limiter. |
| 4          | RW          | 0x0                | scfd<br>When the amplitude of the signal is more than 87.5% of the Full scale, use this signal to control the fast decrement:<br>0: Disabled<br>1: Enabled                                                                                         |
| 3          | RW          | 0x0                | agcnge<br>AGC noise gate function enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                              |
| 2:0        | RW          | 0x1                | agcng<br>AGC noise gate threshold<br>000: -39dB<br>100: -63dB<br>001: -45dB<br>101: -69dB<br>010: -51dB<br>110: -75dB<br>011: -57dB<br>111: -81dB                                                                                                  |

**ACODEC\_REG67**

Address: Operational Base + offset (0x00AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0000000          | reserved                                                                                                                                                           |
| 5          | RW          | 0x1                | lcipgazc<br>Left channel input PGA zero cross enable:<br>0: Update gain when gain register changes.<br>1: Update gain on 1st zero cross after gain register write. |
| 4:0        | RW          | 0x0c               | lcipgag<br>Left channel input PGA gain<br>5'h00: -18dB<br>5'h0d: +1.5dB<br>5'h01: -16.5dB<br>5'h0e: +3dB ... ....<br>5'h0c: 0dB<br>5'h1f: +28.5dB                  |

**ACODEC\_REG68**

Address: Operational Base + offset (0x00B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                        |
| 3          | RW          | 0x0                | sclken<br>Slow clock enabled, used for the zero cross timeout.                                                                                                                                                                  |
| 2:0        | RW          | 0x0                | asr<br>Approximate sample rate Sample Rate<br>96kHz: 000<br>24kHz: 100<br>48kHz: 001<br>16kHz: 101<br>44.1kHz: 010<br>12kHz: 110<br>32kHz: 011<br>8kHz: 111 Note According to the sample rate to choose the right configuration |

**ACODEC\_REG69**

Address: Operational Base + offset (0x00B4)

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

**ACODEC\_REG70**

Address: Operational Base + offset (0x00B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                |
| 7:0        | RW          | 0x40               | hagc_max<br>Integer clock divider to provide 6.144/5.644/4.096MHz sample clock for internal filters. Make sure that int_div_con is an odd number between 7(8 times division) and 15(16 times division). |

**ACODEC\_REG71**

Address: Operational Base + offset (0x00BC)

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

**ACODEC\_REG72**

Address: Operational Base + offset (0x00C0)

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

**ACODEC\_REG73**

Address: Operational Base + offset (0x00C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0000000          | reserved                                                                      |
| 6          | RW          | 0x0                | agcfs<br>AGC function select<br>0: AGC function off<br>1: AGC function enable |

| Bit | Attr | Reset Value | Description                                                                                                                                                             |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:3 | RW   | 0x7         | smaxg_pga<br>Set maximum gain of PGA<br>000: -13.5dB<br>100: +10.5dB<br>001: -7.5dB<br>101: +16.5dB<br>010: -1.5dB<br>110: +22.5dB<br>011: +4.5dB<br>111: +28.5dB       |
| 2:0 | RW   | 0x0         | sming_pga<br>Set minimum gain of PGA Configuration Min Gain<br>000: -18dB<br>100: +6dB<br>001: -12dB<br>101: +12dB<br>010: -6dB<br>110: +18dB<br>011: 0dB<br>111: +24dB |

## 21.5 Interface Description

N/A

## 21.6 Application Notes

### 21.6.1 Enable DAC I2S Interface Flow

0. Provide stable clock to the pin\_sys\_clk and pin\_mclk
1. Reset the IP by low the pin\_RST\_N.
2. Reset the IP by soft reset register as follow:  
Set REG0=0x0  
Set REG0=0x3
3. Configure the register related to the DAC I2S function to make the I2S RX work in different mode.
4. Begin to input the I2S data stream to the I2S interface of the DAC.

### 21.6.2 Enable DC I2S Interface Flow

0. Provide stable clock to the pin\_sys\_clk and pin\_mclk.
1. Reset the IP by low the pin\_RST\_N.
2. Reset the IP by soft reset register as follow:  
Set REG0=0x0  
Set REG0=0x3
3. Configure the register related to the ADC I2S function to make the I2S TX work in different mode.
4. Begin to use the I2S interface of ADC to output the parallel data.

### 21.6.3 Power Up

0. Supply the power of digital part and reset the Audio Codec.
1. Configure the register 0x29[5:4] to 2'b01, to setup dc voltage of the DAC channel output.
2. Configure the register reg0x21[7:0] to 8'b000\_0001.
3. Supply the power of the analog part .
4. Configure the register reg0x22[5] to 1 to setup reference voltage.
5. Change the register reg0x21[7:0] from the 8' b0000\_0001 to 8'b1111\_1111 step by step or configure the reg0x21[7:0] to 7'b1111\_1111 directly. The suggestion slot time of the step is 20ms.

6. Wait until the voltage of VCM keeps stable at the AVDD/2.
7. Configure the register reg0x21[7:0] to the appropriate value(except 7'b0000\_00000) for reducing power.

#### **21.6.4 Power Off**

0. Keep the power on and disable the DAC and ADC path according to the description of section 12.1.
1. Configure the register reg0x21[7:0] to 8'b0000\_0001.
2. Configure the register reg0x22[5] to 1'b0.
3. Change the register reg0x21[7:0] from the 8'b0000\_0001 to 8'b111\_1111 step by step or configure the reg0x21[7:0] to 8'b111\_1111 directly. The suggestion slot time of the step is 20ms.
4. Wait until the voltage of VCM keep stable at AGND.
5. Power off the analog power supply
6. Power off the digital power supply.

#### **21.6.5 Enable DAC**

0. Power up the Audio Codec and input the mute signal.
1. Set the register 0x20[3:0] to 1111, to enable the current source of DAC.
2. Set the register 0x29[6] to 1, to enable the reference voltage buffer of the DAC channel.
3. Set the register 0x29[5:4] to 2' b10, to enable POP sound in the DAC channel.
4. Set the register 0x2a[4] to 1, to enable the HPOUT module in the DAC channel.
5. Set the register 0x2a[5] to 1, to end the initialization of the HPOUT module in the DAC channel.
6. Set the register 0x29[3] to 1, to enable the reference voltage of DAC module.
7. Set the register 0x29[2] to 1, to enable the clock module of DAC module.
8. Set the register 0x29[1] to 1, to enable the DAC module.
9. Set the register 0x29[0] to 1, to end the initialization of the DAC module.
10. Set the register 0x2a[6] to 1, to end the mute station of the HPOUT module.
11. Set the register 0x2b[4:0], to select the gain of HPOUT module.
12. Play the music.

#### **21.6.6 Disable DAC**

0. Keep the DAC channel work and input the mute signal.
1. Set the register 0x2b[4:0] to 5' b0\_0000, to select the gain of the HPOUT.
2. Set the register 0x2a[6] to 0, to mute the HPOUT module.
3. Set the register 0x2a[5] to 0, to initialize the DAC module.
4. Set the register 0x2a[4] to 0, to disable the HPOUT module .
5. Set the register 0x29[1] to 0 to disable the DAC module.
6. Set the register 0x29[2] to 0, to disable the clock module of DAC module.
7. Set the register 0x29[3] to 0, to disable the reference voltage of DAC module.
8. Set the register 0x29[1:0] to 2' b01 to initialize the POP sound.
9. Set the register 0x29[6] to 0, to disable the reference voltage buffer.
10. Set the register 0x20[3:0] to 0000 to disable the current source of DAC.
11. Set the register 0x29[0] to 0, to begin the initialization of the HPOUT module.

#### **21.6.7 Enable ADC**

0. Power up the Audio Codec.
1. Configure the register 0x26[7:6], to select single-ended or difference as input of the ADC left channel.  
Configure the register 0x26[3:2], to select the single-ended or difference as input of the ADC right channel.
2. Configure the register 0x23[7] to 1, to end the mute station of the left ADC channel.  
Configure the register 0x23[3] to 1, to end the mute station of the ADC right channel.
3. Configure the register 0x22[4] to 1, to enable the current source of audio.
4. Configure the register 0x23[5] to 1, to enable the reference voltage buffer in ADC left channel.  
Configure the register 0x23[1] to 1, to enable the reference voltage buffer in ADC right channel.
5. Configure the register 0x25[4] to 1, to enable the MIC module in ADC left channel.  
Configure the register 0x25[0] to 1, to enable the MIC module in ADC right channel.

6. Configure the register 0x25[5] to 1, to enable the ALC module in ADC left channel.  
Configure the register 0x25[1] to 1, to enable the ALC module in ADC right channel.
  7. Configure the register 0x28[2] to 1, to enable the clock module in ADC right channel.  
Configure the register 0x28[6] to 1, to enable the clock module in ADC left channel.
  8. Configure the register 0x28[1] to 1, to enable the ADC module in ADC right channel.  
Configure the register 0x28[5] to 1, to enable the ADC module in ADC left channel.
  9. Configure the register 0x28[0] to 1, to end the initialization of the ADCR module.  
Configure the register 0x28[4] to 1, to end the initialization of the ADCL module.
  10. Configure the register 0x28[3] to 1, to end the initialization of the ALC right module.  
Configure the register 0x28[7] to 1, to end the initialization of the ALC left module.
  11. Configure the register 0x23[2] to 1, to end the initialization of the MIC right module.  
Configure the register 0x23[6] to 1, to end the initialization of the MIC right module.
  12. Configure the register 0x24[5:4], to select the gain of the MIC right module.  
Configure the register 0x24[7:6], to select the gain of the MIC left module.
  13. Configure the register 0x26[4:0], to select the gain of the ALC left module.  
Configure the register 0x27[4:0], to select the gain of the ALC right module.
  14. Configure the register 0x23[0] to 1, to enable the zero-crossing detection function in ADC right channel.  
Configure the register 0x23[4] to 1, to enable the zero-crossing detection function in ADC left channel.
- Begin recording.

### **21.6.8 Disable ADC**

0. Keep ADC channel work and stop recording.
1. Configure the register 0x23[0] to 0, to disable the zero-crossing detection function in ADC right channel  
Configure the register 0x23[4] to 0, to disable the zero-crossing detection function in ADC left channel
2. Configure the register 0x28[1] to 0, to disable the ADC module in ADC right channel.  
Configure the register 0x28[5] to 0, to disable the ADC module in ADC left channel.
3. Configure the register 0x28[2] to 0, to disable the clock module in ADC right channel.  
Configure the register 0x28[6] to 0, to disable the clock module in ADC left channel.
4. Configure the register 0x25[1] to 0, to disable the ALC module in ADC right channel.  
Configure the register 0x25[5] to 0, to disable the ALC module in ADC left channel.
5. Configure the register 0x25[0] to 0, to disable the MIC module in ADC right channel.  
Configure the register 0x25[4] to 0, to disable the MIC module in ADC left channel
6. Configure the register 0x23[1] to 0, to disable the reference voltage buffer in ADC right channel.  
Configure the register 0x23[5] to 0, to disable the reference voltage buffer in ADC left channel.
7. Configure the register 0x22[4] to 0, to disable the microphone bias voltage buffer.
8. Configure the register 0x28[0] to 0, to begin the initialization of the ADC right module.  
Configure the register 0x28[4] to 0, to begin the initialization of the ADC left module.
9. Configure the register 0x28[3] to 0, to begin the initialization of the ALC right module.  
Configure the register 0x28[7] to 0, to begin the initialization of the ALC left module.
10. Configure the register 0x23[2] to 0, to begin the initialization of the MIC right module.  
Configure the register 0x23[6] to 0, to begin the initialization of the MIC left module.

### **21.6.9 Enable ALC**

1. Set the Max level and Min level of the ALC need to control.  
The relationship between the max\_level and the signal amplitude (dB) is equal to:  
$$\text{amplitude (dB)} = 20\log(\text{max\_level}/16'h7fff)$$
, 16'h7fff means the full scale amplitude. The register 0x47 and 0x48 control the min level of the ALC.  $\text{min\_level} = \{\text{reg0x48}, \text{reg0x47}\}$ ; The relationship between the min\_level and the signal amplitude (dB) is equal to:  
$$\text{amplitude(dB)} = 20\log(\text{min\_level}/16'h7fff)$$
; 16'h7fff means the full scale amplitude.
2. According to the sample rate to choose the configuration.
3. Enable the ALC module. Set the reg0x49 [6] to 1 to enable the ALC module.
4. Choose the ALC module to control the gain of the PGA. Set the reg0x0a [5] to 1 to choose the ALCL module to control the gain of the PGA.

5. Observe the current ALC output gain.

### **21.6.10 Disable ALC**

1. Set the reg0x49[6] to 0 to disable the ALC module, then the ALC output gain will keep to the last value.

2. Choose to use the register to control the gain of the PGA. Set the reg0x0a[5] to 0 to choose to use the register to control the gain of the PGA, then we can use the register 0x27.

The ALC has two modes to control the gain of the PGA. If we use the register 0x49 to enable the automatically adjustment function of the ALC, the gain of the PGA will change automatically according to the amplitude of the input signal. If we don't use this function, we can use the register 0x43 to change the gain of the PGA manual. The prerequisite of these two modes is that we use the register 0x0a to choose to use the ALC module to control the gain of the PGA.

### **21.6.11 Inner-BIST FUNCTION**

The codec has the bist function which can generate the sine or square digital wave. So the DAC path can choose the bist wave as the source, then the analog output of the DAC can output the sine or square wave without caring the digital I2S interface of the DAC. In the normal mode, the bist wave generate model is in the reset mode to save the power, you can use the register to enable this model.

The suggested way to use the Inner-Bist function lists below.

1. Configure the register 0x00 to enable the Inner-Bist wave generated model.

2. Configure the register 0x0d to choose the source of the digital input.

Note: Before you use this function, please enable the DAC firstly.

## Chapter 22 Mobile Storage Host Controller

### 22.1 Overview

The Mobile Storage Host Controller is designed to support Secure Digital memory (SD-max version 3.01) with 1 bits or 4 bits data width, Multimedia Card(MMC-max version 4.51) with 1 bits or 4 bits or 8 bits data width.

The Host Controller is instantiated for SDMMC, SDIO and EMMC. The interface difference between these instances is shown in "Interface Description".

The Host Controller supports following features:

- Bus Interface Features:
  - Support AMBA AHB interface for master and slave
  - Supports internal DMA interface(IDMAC)
    - ◆ Supports 16/32-bit data transfers
    - ◆ Single engine used for Transmit and Receive, which are mutually exclusive
    - ◆ Dual-buffer and chained descriptor linked list
    - ◆ Each descriptor can transfer up to 4KB of data in chained mode and 8KB of data in dual-buffer mode
    - ◆ Programmable burst size for optimal host bus utilization
  - Support combined single FIFO for both transmit and receive operations
  - Support FIFO size of 256x32
  - Support FIFO over-run and under-run prevention by stopping card clock
- Card Interface Features:
  - Support Secure Digital memory protocol commands
  - Support Secure Digital I/O protocol commands
  - Support Multimedia Card protocol commands
  - Support Command Completion Signal and interrupts to host
  - Support CRC generation and error detection
  - Support programmable baud rate
  - Support power management and power switch
  - Support card detection
  - Support write protection
  - Support hardware reset
  - Support SDIO interrupts in 1-bit and 4-bit modes
  - Support 4-bit mode in SDIO3.0
  - Support SDIO suspend and resume operation
  - Support SDIO read wait
  - Support block size of 1 to 65,535 bytes
  - Support 1-bit, 4-bit and 8-bit SDR modes
  - Supports 4-bit and 8-bit DDR
  - Support boot in 1-bit, 4-bit and 8-bit SDR modes
- Clock Interface Features:
  - Support 0/90/180/270-degree phase shift operation for sample clock(cclk\_in\_sample) and drive clock(cclk\_in\_drv) relative to function clock(cclk\_in) respectively
  - Support phase tuning using delay line for sample clock(cclk\_in\_sample) and drive clock(cclk\_in\_drv) relative to function clock (cclk\_in) respectively. The max number of delay element number is 256.

### 22.2 Block Diagram

The Host Controller consists of the following main functional blocks.



Fig. 22-1 Mobile Storage Host Control Block Diagram

- **Clock Generate Unit (CLKGEN):** Generates card interface clock `cclk_in`/`cclk_sample`/`cclk_drv` based on `cclkin` and configuration information.
  - `cclkin`: original clock
  - `cclk_in`: functional clock
  - `cclk_sample`: sample clock
  - `cclk_drv`: driver clock
- **Asynchronous dual-port memory (BUFFER):** Use a two-clock synchronous read and synchronous write dual-port RAM. One of the ports is connected to the host clock, and the other port is connected to the card clock.
- **Bus Interface Unit (BIU):** Provides AMBA AHB interfaces for register and data read/write.
- **Card Interface Unit (CIU):** Takes care of the SD/MMC protocols and provides clock management.

## 22.3 Function Description

### 22.3.1 Bus Interface Unit

The Bus Interface Unit provides the following functions:

- Host interface
- Interrupt control
- Register access
- External FIFO access
- Card detection

#### 22.3.1.1 Host Interface Unit

The Host Interface Unit is an AHB slave interface, which provides the interface between the SD/MMC card and the host bus.

#### 22.3.1.2 Register Unit

The register unit is part of the bus interface unit; it provides read and write access to the registers.

All registers reside in the Bus Interface Unit clock domain. When a command is sent to a card by setting the start\_bit, which is bit[31] of the SDMMC\_CMD register, all relevant registers needed for the CIU operation are transferred to the CIU block. During this time, the registers that are transferred from the BIU to the CIU should not be written. The software should wait for the hardware to clear the start bit before writing to these registers again. The register unit has a hardware locking feature to prevent illegal writes to registers. The lock is necessary in order to avoid metastability violations, both because the host and card clock domains are different and to prevent illegal software operations.

Once a command start is issued by setting the start\_bit of the SDMMC\_CMD register, the following registers cannot be reprogrammed until the command is accepted by the card interface unit:

- SDMMC\_CMD
- SDMMC\_CMDARG
- SDMMC\_BYTCNT
- SDMMC\_BLKSIZ
- SDMMC\_CLKDIV
- SDMMC\_CLKENA
- SDMMC\_CLKSRC
- SDMMC\_TMOUT
- SDMMC\_CTYPE

The hardware resets the start\_bit once the CIU accepts the command. If a host write to any of these registers is attempted during this locked time, then the write is ignored and the hardware lock error bit is set in the raw interrupt status register. Additionally, if the interrupt is enabled and not masked for a hardware lock error, then an interrupt is sent to the host.

When the Card Interface Unit is in an idle state, it typically takes the following number of clocks for the command handshake, where clk is the BIU clock and cclk\_in is the CIU clock: 3 (clk) + 3 (cclk\_in)

Once a command is accepted, you can send another command to the CIU-which has a one-deep command queue-under the following conditions:

- If the previous command was not a data transfer command, the new command is sent to the SD/MMC card once the previous command completes.
- If the previous command is a data transfer command and if wait\_prvdata\_complete (bit[13]) of the SDMMC\_CMD register is set for the new command, the new command is sent to the SD/MMC card only when the data transfer completes.

If the wait\_prvdata\_complete is 0, then the new command is sent to the SD/MMC card as soon as the previous command is sent. Typically, you should use this only to stop or abort a previous data transfer or query the card status in the middle of a data transfer.

#### 22.3.1.3 Interrupt Controller Unit

The interrupt controller unit generates an interrupt that depends on the controller raw interrupt status, the interrupt-mask register, and the global interrupt-enable register bit.

Once an interrupt condition is detected, it sets the corresponding interrupt bit in the raw interrupt status register SDMMC\_RINTSTS. The raw interrupt status bit stays on until the software clears the bit by writing a 1 to the interrupt bit; a 0 leaves the bit untouched. The interrupt port is an active-high, level-sensitive interrupt. The interrupt port is active only when any bit in the raw interrupt status register is active, the corresponding interrupt mask bit is 1, and the global interrupt enable bit is 1. The interrupt port is registered in order to avoid any combinational glitches.

The int\_enable is reset to 0 on power-on, and the interrupt mask bits are set to 32'h0, which masks all the interrupts.

**Notes:**

*Before enabling the interrupt, it is always recommended that you write 32'hffff\_ffff to the raw interrupt status register in order to clear any pending unserviced interrupts. When clearing interrupts during normal operation, ensure that you clear only the interrupt bits that you serviced.*

*The SDIO Interrupts, Receive FIFO Data Request (RXDR), and Transmit FIFO Data Request (TXDR) are set by level-sensitive interrupt sources. Therefore, the interrupt source should be first cleared before you can clear the interrupt bit of the Raw Interrupt register. For example, on seeing the Receive FIFO Data Request (RXDR) interrupt, the FIFO should be emptied so that the "FIFO count greater than the RX-Watermark" condition, which triggers the interrupt, becomes inactive. The rest of the interrupts are triggered by a single clock-pulse-width source.*

Table 22-1 Bits in Interrupt Status Register

| Bits | Interrupt                                 | Description                                                                                                                                                                                                                                                                                                                                                                                |
|------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24   | sdio_interrupt                            | Interrupt from SDIO card. In MMC-Ver3.3-only mode, these bits are always 0.                                                                                                                                                                                                                                                                                                                |
| 16   | Card no-busy                              | If card exit busy status, the interrupt happened.                                                                                                                                                                                                                                                                                                                                          |
| 15   | End Bit Error (read) / Write no CRC (EBE) | Error in end-bit during read operation, or no data CRC received during write operation.<br>For MMC CMD19, there may be no CRC status returned by the card. Hence, EBE is set for CMD19. The application should not treat this as an error.                                                                                                                                                 |
| 14   | Auto Command Done (ACD)                   | Stop/abort commands automatically sent by card unit and not initiated by host; similar to Command Done (CD) interrupt.<br>Recommendation:<br>Software typically need not enable this for non CE-ATA accesses; Data Transfer Over (DTO) interrupt that comes after this interrupt determines whether data transfer has correctly completed.                                                 |
| 13   | Start Bit Error (SBE)                     | Error in data start bit when data is read from a card. In 4-bit mode, if DAT[0] line indicates start bit—that is, 0-and any of the other data bits do not have start bit, then this error is set.<br>Busy Complete Interrupt when data is written to the card. This interrupt is generated after completion of busy driven by the card after the last data block is written into the card. |
| 12   | Hardware Locked write Error (HLE)         | During hardware-lock period, write attempted to one of locked registers.<br>When software sets the start_cmd bit in the SDMMC_CMD register, the Host Controller tries to load the command. If the command buffer is already filled with a command, this error is raised. The software then has to reload the command.                                                                      |
| 11   | FIFO Underrun/ Overrun Error (FRUN)       | Host tried to push data when FIFO was full, or host tried to read data when FIFO was empty. Typically this should not happen, except due to error in software.<br>Card unit never pushes data into FIFO when FIFO is full, and pop data when FIFO is empty.<br>If IDMAC is enabled, FIFO under-run/over-run can                                                                            |

| <b>Bits</b> | <b>Interrupt</b>                      | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |                                       | occur due to a programming error on MSIZE and watermark values in SDMMC_FIFOTH register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10          | Data Starvation by Host Timeout (HTO) | <p>To avoid data loss, card clock out is stopped if FIFO is empty when writing to card, or FIFO is full when reading from card. Whenever card clock is stopped to avoid data loss, data-starvation timeout counter is started with data-timeout value. This interrupt is set if host does not fill data into FIFO during write to card, or does not read from FIFO during read from card before timeout period.</p> <p>Even after timeout, card clock stays in stopped state, with CIU state machines waiting. It is responsibility of host to push or pop data into FIFO upon interrupt, which automatically restarts cclk_out and card state machines.</p> <p>Even if host wants to send stop/abort command, it still needs to ensure it has to push or pop FIFO so that clock starts in order for stop/abort command to send on command signal along with data that is sent or received on data line.</p> |
| 9           | Data Read Timeout (DRTO)              | <p>In Normal functioning mode: Data read timeout (DRTO)</p> <p>Data timeout occurred. Data Transfer Over (DTO) also set if data timeout occurs.</p> <p>In Boot Mode: Boot Data Start (BDS)</p> <p>When set, indicates that Host Controller has started to receive boot data from the card. A write to this register with a value of 1 clears this interrupt.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 8           | Response Timeout (RTO)                | <p>In normal functioning mode: Response timeout (RTO)</p> <p>Response timeout occurred. Command Done (CD) also set if response timeout occurs. If command involves data transfer and when response times out, no data transfer is attempted by Host Controller.</p> <p>In Boot Mode: Boot Ack Received (BAR)</p> <p>When expect_boot_ack is set, on reception of a boot acknowledge pattern—0-1-0—this interrupt is asserted. A write to this register with a value of 1 clears this interrupt.</p>                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7           | Data CRC Error (DCRC)                 | <p>Received Data CRC does not match with locally-generated CRC in CIU.</p> <p>Can also occur if the Write CRC status is incorrectly sampled by the Host.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6           | Response CRC Error (RCRC)             | Response CRC does not match with locally-generated CRC in CIU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5           | Receive FIFO Data Request (RXDR)      | <p>Interrupt set during read operation from card when FIFO level is greater than Receive-Threshold level.</p> <p>Recommendation:</p> <p>In DMA modes, this interrupt should not be enabled.</p> <p>In non-DMA mode: pop RX_WMark + 1 data from FIFO.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4           | Transmit FIFO Data Request (TXDR)     | <p>Interrupt set during write operation to card when FIFO level reaches less than or equal to Transmit-Threshold level.</p> <p>Recommendation:</p> <p>In DMA modes, this interrupt should not be enabled.</p> <p>In non-DMA mode:</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Bits | Interrupt                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                          | <pre> if (pending_bytes &gt; (FIFO_DEPTH - TX_WMark))     push (FIFO_DEPTH - TX_WMark) data into FIFO else     push pending_bytes data into FIFO </pre>                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3    | Data Transfer Over (DTO) | <p>Indicates Data transfer completed. Though on detection of errors-Start Bit Error, Data CRC error, and so on, DTO may or may not be set; the application must issue CMD12, which ensures that DTO is set.</p> <p><b>Recommendation:</b><br/>In non-DMA mode, when data is read from card, on seeing interrupt, host should read any pending data from FIFO. In DMA mode, DMA controllers guarantee FIFO is flushed before interrupt.</p> <p>DTO bit is set at the end of the last data block, even if the device asserts MMC busy after the last data block.</p> |
| 2    | Command Done(CD)         | Command sent to card and got response from card, even if Response Error or CRC error occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1    | Response Error (RE)      | Error in received response set if one of following occurs: <ul style="list-style-type: none"> <li>● Transmission bit != 0</li> <li>● Command index mismatch</li> <li>● End-bit != 1</li> </ul>                                                                                                                                                                                                                                                                                                                                                                     |
| 0    | Card-Detect (CDT)        | <p>When one or more cards inserted or removed, this interrupt occurs.</p> <p>Software should read card-detect register to determine current card status.</p> <p><b>Recommendation:</b> After power-on and before enabling interrupts, software should read card detect register and store it in memory. When interrupt occurs, it should read card detect register and compare it with value stored in memory to determine which card(s) were removed/inserted. Before exiting ISR, software should update memory with new card-detect value.</p>                  |

### 22.3.1.4 FIFO Controller Unit

The FIFO controller interfaces the external FIFO to the host interface and the card controller unit. When FIFO overrun and under-run conditions occur, the card clock stops in order to avoid data loss.

The FIFO uses a two-clock synchronous read and synchronous write dual-port RAM. One of the ports is connected to the host clock(clk), and the second port is connected to the card clock(cclk\_in).

### 22.3.1.5 Card Detection Unit

The register unit has registers that control the power. Power to each card can be selectively turned on or off.

The card detection unit looks for any changes in the card-detect signals for card insertion or card removal. It filters out the debounce associated with mechanical insertion or removal, and generates one interrupt to the host. You can program the debounce filter value.



Fig. 22-2 SD/MMC Card-Detect Signal

### 22.3.2 Card Interface Unit

The Card Interface Unit (CIU) interfaces with the Bus Interface Unit (BIU) and the external devices. The host writes command parameters to the BIU control registers, and these parameters are then passed to the CIU. Depending on control register values, the CIU generates SD/MMC command and data traffic on a selected card bus according to SD/MMC protocol. The Host Controller accordingly controls the command and data path.

The following software restrictions should be met for proper CIU operation:

- Only one data transfer command can be issued at a time.
- During an open-ended card write operation, if the card clock is stopped because the FIFO is empty, the software must first fill the data into the FIFO and start the card clock. It can then issue only a stop/abort command to the card.
- When issuing card reset commands (CMD0, CMD15 or CMD52\_reset) while a card data transfer is in progress, the software must set the stop\_abort\_cmd bit in the SDMMC\_CMD register so that the Host Controller can stop the data transfer after issuing the card reset command.
- When the data end bit error is set in the SDMMC\_RINTSTS register, the Host Controller does not guarantee SDIO interrupts. The software should ignore the SDIO interrupts and issue the stop/abort command to the card, so that the card stops sending the read data.
- If the card clock is stopped because the FIFO is full during a card read, the software should read at least two FIFO locations to start the card clock.

The CIU block consists of the following primary functional blocks:

- Command path
- Data path
- SDIO interrupt control
- Clock control
- Error detection

#### 22.3.2.1 Command Path

The command path performs the following functions:

- Loads clock parameters
- Loads card command parameters
- Sends commands to card bus (ccmd\_out line)
- Receives responses from card bus (ccmd\_in line)
- Sends responses to BIU
- Drives the P-bit on command line

A new command is issued to the Host Controller by programming the BIU registers and setting the start\_cmd bit in the SDMMC\_CMD register. The BIU asserts start\_cmd, which indicates that a new command is issued to the SD/MMC device. The command path loads this new command (command, command argument, timeout) and sends acknowledge to the BIU by asserting cmd\_taken.

Once the new command is loaded, the command path state machine sends a command to the device bus-including the internally generated CRC7-and receives a response, if any. The state machine then sends the received response and signals to the BIU that the command is done, and then waits for eight clocks before loading a new command.

#### Load Command Parameters

One of the following commands or responses is loaded in the command path:

- New command from BIU – When start\_cmd is asserted, then the start\_cmd bit is set in the SDMMC\_CMD register.

- Internally generated auto-stop command – When the data path ends, the stop command request is loaded.
- IRQ response with RCA 0x000 – When the command path is waiting for an IRQ response from the MMC card and a “send irq response” request is signaled by the BIU, then the send\_irq\_response bit is set in the SDMMC\_CTRL register.

Loading a new command from the BIU in the command path depends on the following SDMMC\_CMD register bit settings:

- update\_clock\_registers\_only – If this bit is set in the SDMMC\_CMD register, the command path updates only the clock enable, clock divider, and clock source registers. If this bit is not set, the command path loads the command, command argument, and timeout registers; it then starts processing the new command.
- wait\_prvdata\_complete – If this bit is set, the command path loads the new command under one of the following conditions:
  - Immediately, if the data path is free (that is, there is no data transfer in progress), or if an open-ended data transfer is in progress (byte\_count = 0).
  - After completion of the current data transfer, if a predefined data transfer is in progress.

### Send Command and Receive Response

Once a new command is loaded in the command path, update\_clock\_registers\_only bit is unset – the command path state machine sends out a command on the device bus; the command path state machine is illustrated in following figure.



Fig. 22-3 Host Controller Command Path State Machine

The command path state machine performs the following functions, according to SDMMC\_CMD register bit values:

- send\_initialization – Initialization sequence of 80 clocks is sent before sending the command.
- response\_expected – Response is expected for the command. After the command is sent out, the command path state machine receives a 48-bit or 136-bit response and sends it to the BIU. If the start bit of the card response is not received within the number of clocks programmed in the timeout register, then the response timeout and command done bit is set in the Raw Interrupt Status register as a signal to the BIU. If the response-expected bit is not set, the command path sends out a command and signals a response done to the BIU; that is, the command done bit is set in the Raw Interrupt Status register.
- response\_length – If this bit is set, a 136-bit response is received; if it is not set, a 48-bit response is received.
- check\_response\_crc – If this bit is set, the command path compares CRC7 received in the response with the internally-generated CRC7. If the two do not match, the response CRC error is signaled to the BIU; that is, the response CRC error bit is set in

the Raw Interrupt Status register SDMMC\_RINTSTS.

### **Send Response to BIU**

If the response\_expected bit is set in the SDMMC\_CMD register, the received response is sent to the BIU. The Response0 register is updated for a short response, and the Response3, Response2, Response1, and Response0 registers are updated on a long response, after which the Command Done bit is set. If the response is for an auto\_stop command sent by the CIU, the response is saved in the Response1 register, after which the Auto Command Done bit is set.

Additionally, the command path checks for the following:

- Transmission bit = 0
- Command index matches command index of the sent command
- End bit = 1 in received card response

The command index is not checked for a 136-bit response or if the check\_response\_crc bit is unset. For a 136-bit response and reserved CRC 48-bit responses, the command index is reserved—that is, 111111.

### **Polling Command Completion Signal**

The device generates the Command Completion Signal in order to notify the host controller of the normal command completion or command termination.

### **Command Completion Signal Detection and Interrupt to Host Processor**

If the ccs\_expected bit is set in the SDMMC\_CMD register, the Command Completion Signal (CCS) from the device is indicated by setting the Data Transfer Over (DTO) bit in the SDMMC\_RINTSTS register. The Host Controller generates a Data Transfer Over (DTO) interrupt if this interrupt is not masked.

### **Command Completion Signal Timeout**

If the command expects a CCS from the device—if the ccs\_expected bit is set in the SDMMC\_CMD register—the command state machine waits for the CCS and remains in a wait\_CCS state. If the device fails to send out the CCS, the host software should implement a timeout mechanism to free the command and data path. The host controller does not implement a hardware timer; it is the responsibility of the host software to maintain a software timer.

In the event of a CCS timeout, the host should issue a CCSD by setting the send\_ccsd bit in the CTRL register. The host controller command state machine sends the CCSD to the device and exits to an idle state. After sending the CCSD, the host should also send a CMD12 to the device in order to abort the outstanding command.

### **Send Command Completion Signal Disable**

If the send\_ccsd bit is set in the SDMMC\_CTRL register, the host sends a Command Completion Signal Disable (CCSD) pattern on the CMD line. The host can send the CCSD while waiting for the CCS or after a CCS timeout happens.

After sending the CCSD pattern, the host sets the Command Done (CD) bit in SDMMC\_RINTSTS and also generates an interrupt to the host if the Command Done interrupt is not masked.

### **22.3.2.2 Data Path**

The data path block pops the data FIFO and transmits data on cdata\_out during a write data transfer, or it receives data on cdata\_in and pushes it into the FIFO during a read data transfer. The data path loads new data parameters—that is, data expected, read/write data transfer, stream/block transfer, block size, byte count, card type, timeout registers—whenever a data transfer command is not in progress.

If the data\_expected bit is set in the SDMMC\_CMD register, the new command is a data transfer command and the data path starts one of the following:

- Transmit data if the read/write bit = 1
- Data receive if read/write bit = 0

### **Data Transmit**

The data transmit state machine, illustrated in following figure, starts data transmission two clocks after a response for the data write command is received; this occurs even if the command path detects a response error or response CRC error. If a response is not received from the card because of a response timeout, data is not transmitted. Depending upon the value of the transfer\_mode bit in the SDMMC\_CMD register, the data transmit

state machine puts data on the card data bus in a stream or in block(s).



Fig. 22-4 Host Controller Data Transmit State Machine

### Stream Data Transmit

If the transfer\_mode bit in the SDMMC\_CMD register is set to 1, it is a stream-write data transfer. The data path pops the FIFO from the BIU and transmits in a stream to the card data bus. If the FIFO becomes empty, the card clock is stopped and restarted once data is available in the FIFO.

If the byte\_count register is programmed to 0, it is an open-ended stream-write data transfer. During this data transfer, the data path continuously transmits data in a stream until the host software issues a stop command. A stream data transfer is terminated when the end bit of the stop command and end bit of the data match over two clocks.

If the byte\_count register is programmed with a non-zero value and the send\_auto\_stop bit is set in the SDMMC\_CMD register, the stop command is internally generated and loaded in the command path when the end bit of the stop command occurs after the last byte of the stream write transfer matches.

This data transfer can also terminate if the host issues a stop command before all the data bytes are transferred to the card bus.

### Single Block Data

If the transfer\_mode bit in the SDMMC\_CMD register is set to 0 and the byte\_count register value is equal to the value of the block\_size register, a single-block write-data transfer occurs. The data transmit state machine sends data in a single block, where the number of bytes equals the block size, including the internally-generated CRC16.

If the SDMMC\_CTYPE register bit for the selected card – indicated by the card\_num value in the SDMMC\_CMD register – is set for a 1-bit, 4-bit, or 8-bit data transfer, the data is transmitted on 1, 4, or 8 data lines, respectively, and CRC16 is separately generated and transmitted for 1, 4, or 8 data lines, respectively.

After a single data block is transmitted, the data transmit state machine receives the CRC status from the card and signals a data transfer to the BIU; this happens when the data-transfer-over bit is set in the SDMMC\_RINTSTS register.

If a negative CRC status is received from the card, the data path signals a data CRC error to the BIU by setting the data CRC error bit in the SDMMC\_RINTSTS register.

Additionally, if the start bit of the CRC status is not received by two clocks after the end of the data block, a CRC status start bit error is signaled to the BIU by setting the write-no-

CRC bit in the SDMMC\_RINTSTS register.

### **Multiple Block Data**

A multiple-block write-data transfer occurs if the transfer\_mode bit in the SDMMC\_CMD register is set to 0 and the value in the byte\_count register is not equal to the value of the block\_size register. The data transmit state machine sends data in blocks, where the number of bytes in a block equals the block size, including the internally-generated CRC16. If the SDMMC\_CTYPE register bit for the selected card – indicated by the card\_num value in the SDMMC\_CMD register – is set to 1-bit, 4-bit, or 8-bit data transfer, the data is transmitted on 1, 4, or 8 data lines, respectively, and CRC16 is separately generated and transmitted on 1, 4, or 8 data lines, respectively.

After one data block is transmitted, the data transmit state machine receives the CRC status from the card. If the remaining byte\_count becomes 0, the data path signals to the BIU that the data transfer is done; this happens when the data-transfer-over bit is set in the SDMMC\_RINTSTS register.

If the remaining data bytes are greater than 0, the data path state machine starts to transmit another data block.

If a negative CRC status is received from the card, the data path signals a data CRC error to the BIU by setting the data CRC error bit in the SDMMC\_RINTSTS register, and continues further data transmission until all the bytes are transmitted.

Additionally, if the CRC status start bit is not received by two clocks after the end of a data block, a CRC status start bit error is signaled to the BIU by setting the write-no-CRC bit in the SDMMC\_RINTSTS register; further data transfer is terminated.

If the send\_auto\_stop bit is set in the SDMMC\_CMD register, the stop command is internally generated during the transfer of the last data block, where no extra bytes are transferred to the card. The end bit of the stop command may not exactly match the end bit of the CRC status in the last data block.

If the block size is less than 4, 16, or 32 for card data widths of 1 bit, 4 bits, or 8 bits, respectively, the data transmit state machine terminates the data transfer when all the data is transferred, at which time the internally generated stop command is loaded in the command path.

If the byte\_count is 0 – the block size must be greater than 0 – it is an open-ended block transfer. The data transmit state machine for this type of data transfer continues the block-write data transfer until the host software issues a stop or abort command.

### **Data Receive**

The data-receive state machine, illustrated in following figure, receives data two clock cycles after the end bit of a data read command, even if the command path detects a response error or response CRC error. If a response is not received from the card because a response timeout occurs, the BIU does not receive a signal that the data transfer is complete; this happens if the command sent by the Host Controller is an illegal operation for the card, which keeps the card from starting a read data transfer.

If data is not received before the data timeout, the data path signals a data timeout to the BIU and an end to the data transfer done. Based on the value of the transfer\_mode bit in the SDMMC\_CMD register, the data-receive state machine gets data from the card data bus in a stream or block(s).



Fig. 22-5 Host Controller Data Receive State Machine

### Stream Data Read

A stream-read data transfer occurs if the transfer\_mode bit in the SDMMC\_CMD register equals 1, at which time the data path receives data from the card and pushes it to the FIFO. If the FIFO becomes full, the card clock stops and restarts once the FIFO is no longer full.

An open-ended stream-read data transfer occurs if the byte\_count register equals 0. During this type of data transfer, the data path continuously receives data in a stream until the host software issues a stop command. A stream data transfer terminates two clock cycles after the end bit of the stop command.

If the byte\_count register contains a non-zero value and the send\_auto\_stop bit is set in the SDMMC\_CMD register, a stop command is internally generated and loaded into the command path, where the end bit of the stop command occurs after the last byte of the stream data transfer is received. This data transfer can terminate if the host issues a stop or abort command before all the data bytes are received from the card.

### Single-Block Data Read

A single-block read-data transfer occurs if the transfer\_mode bit in the SDMMC\_CMD register is set to 0 and the value of the byte\_count register is equal to the value of the block\_size register. When a start bit is received before the data times out, data bytes equal to the block size and CRC16 are received and checked with the internally-generated CRC16. If the SDMMC\_CTYPE register bit for the selected card – indicated by the card\_num value in the SDMMC\_CMD register – is set to a 1-bit, 4-bit, or 8-bit data transfer, data is received from 1, 4, or 8 data lines, respectively, and CRC16 is separately generated and checked for 1, 4, or 8 data lines, respectively. If there is a CRC16 mismatch, the data path signals a data CRC error to the BIU. If the received end bit is not 1, the BIU receives an end-bit error.

### Multiple-Block Data Read

If the transfer\_mode bit in the SDMMC\_CMD register is set to 0 and the value of the byte\_count register is not equal to the value of the block\_size register, it is a multiple-block read-data transfer. The data-receive state machine receives data in blocks, where the number of bytes in a block is equal to the block size, including the internally-generated CRC16.

If the SDMMC\_CTYPE register bit for the selected card – indicated by the card\_num value in the SDMMC\_CMD register – is set to a 1-bit, 4-bit, or 8-bit data transfer, data is received from 1, 4, or 8 data lines, respectively, and CRC16 is separately generated and checked for 1, 4, or 8 data lines, respectively.

After a data block is received, if the remaining byte\_count becomes 0, the data path signals

a data transfer to the BIU.

If the remaining data bytes are greater than 0, the data path state machine causes another data block to be received. If CRC16 of a received data block does not match the internally-generated CRC16, a data CRC error to the BIU and data reception continue further data transmission until all bytes are transmitted.

Additionally, if the end of a received data block is not 1, data on the data path signals terminate the bit error to the CIU and the data-receive state machine terminates data reception, waits for data timeout, and signals to the BIU that the data transfer is complete. If the send\_auto\_stop bit is set in the SDMMC\_CMD register, the stop command is internally generated when the last data block is transferred, where no extra bytes are transferred from the card; the end bit of the stop command may not exactly match the end bit of the last data block.

If the requested block size for data transfers to cards is less than 4, 16, or 32 bytes for 1-bit, 4-bit, or 8-bit data transfer modes, respectively, the data-transmit state machine terminates the data transfer when all data is transferred, at which point the internally-generated stop command is loaded in the command path. Data received from the card after that are then ignored by the data path.

If the byte\_count is 0—the block size must be greater than 0—it is an open-ended block transfer. For this type of data transfer, the data-receive state machine continues the block-read data transfer until the host software issues a stop or abort command.

### Auto-Stop

The Host Controller internally generates a stop command and is loaded in the command path when the send\_auto\_stop bit is set in the SDMMC\_CMD register.

The software should set the send\_auto\_stop bit according to details listed in following table.

Table 22-2 Auto-Stop Generation

| Card type | Transfer type        | Byte Count | send_auto_stop bit set | Comments                           |
|-----------|----------------------|------------|------------------------|------------------------------------|
| MMC       | Stream read          | 0          | No                     | Open-ended stream                  |
| MMC       | Stream read          | >0         | Yes                    | Auto-stop after all bytes transfer |
| MMC       | Stream write         | 0          | No                     | Open-ended stream                  |
| MMC       | Stream write         | >0         | Yes                    | Auto-stop after all bytes transfer |
| MMC       | Single-block read    | >0         | No                     | Byte count =0 is illegal           |
| MMC       | Single-block write   | >0         | No                     | Byte count =0 is illegal           |
| MMC       | Multiple-block read  | 0          | No                     | Open-ended multiple block          |
| MMC       | Multiple-block read  | >0         | Yes <sup>①</sup>       | Pre-defined multiple block         |
| MMC       | Multiple-block write | 0          | No                     | Open-ended multiple block          |
| MMC       | Multiple-block write | >0         | Yes <sup>①</sup>       | Pre-defined multiple block         |
| SDMEM     | Single-block read    | >0         | No                     | Byte count =0 is illegal           |
| SDMEM     | Single-block write   | >0         | No                     | Byte count =0 illegal              |
| SDMEM     | Multiple-block read  | 0          | No                     | Open-ended multiple block          |
| SDMEM     | Multiple-block read  | >0         | Yes                    | Auto-stop after all bytes transfer |
| SDMEM     | Multiple-block write | 0          | No                     | Open-ended multiple block          |
| SDMEM     | Multiple-block write | >0         | Yes                    | Auto-stop after all bytes transfer |
| SDIO      | Single-block read    | >0         | No                     | Byte count =0 is illegal           |
| SDIO      | Single-block write   | >0         | No                     | Byte count =0 illegal              |
| SDIO      | Multiple-block       | 0          | No                     | Open-ended multiple block          |

| Card type | Transfer type        | Byte Count | send_auto_stop bit set | Comments                   |
|-----------|----------------------|------------|------------------------|----------------------------|
|           | read                 |            |                        |                            |
| SDIO      | Multiple-block read  | >0         | No                     | Pre-defined multiple block |
| SDIO      | Multiple-block write | 0          | No                     | Open-ended multiple block  |
| SDIO      | Multiple-block write | >0         | No                     | Pre-defined multiple block |

*D: The condition under which the transfer mode is set to block transfer and byte\_count is equal to block size is treated as a single-block data transfer command for both MMC and SD cards. If byte\_count = n\*block\_size (n = 2, 3, ...), the condition is treated as a predefined multiple-block data transfer command. In the case of an MMC card, the host software can perform a predefined data transfer in two ways: 1) Issue the CMD23 command before issuing CMD18/CMD25 commands to the card – in this case, issue MD18/CMD25 commands without setting the send\_auto\_stop bit. 2) Issue CMD18/CMD25 commands without issuing CMD23 command to the card, with the send\_auto\_stop bit set. In this case, the multiple-block data transfer is terminated by an internally-generated auto-stop command after the programmed byte count.*

The following list conditions for the auto-stop command.

- Stream read for MMC card with byte count greater than 0 – The Host Controller generates an internal stop command and loads it into the command path so that the end bit of the stop command is sent out when the last byte of data is read from the card and no extra data byte is received. If the byte count is less than 6 (48 bits), a few extra data bytes are received from the card before the end bit of the stop command is sent.
- Stream write for MMC card with byte count greater than 0 - The Host Controller generates an internal stop command and loads it into the command path so that the end bit of the stop command is sent when the last byte of data is transmitted on the card bus and no extra data byte is transmitted. If the byte count is less than 6 (48 bits), the data path transmits the data last in order to meet the above condition.
- Multiple-block read memory for SD card with byte count greater than 0 – If the block size is less than 4 (single-bit data bus), 16 (4-bit data bus), or 32 (8-bit data bus), the auto-stop command is loaded in the command path after all the bytes are read. Otherwise, the stop command is loaded in the command path so that the end bit of the stop command is sent after the last data block is received.
- Multiple-block write memory for SD card with byte count greater than 0 – If the block size is less than 3 (single-bit data bus), 12 (4-bit data bus), or 24 (8-bit data bus), the auto-stop command is loaded in the command path after all data blocks are transmitted. Otherwise, the stop command is loaded in the command path so that the end bit of the stop command is sent after the end bit of the CRC status is received.

Precaution for host software during auto-stop – Whenever an auto-stop command is issued, the host software should not issue a new command to the SD/MMC device until the auto-stop is sent by the Host Controller and the data transfer is complete. If the host issues a new command during a data transfer with the auto-stop in progress, an auto-stop command may be sent after the new command is sent and its response is received; this can delay sending the stop command, which transfers extra data bytes. For a stream write, extra data bytes are erroneous data that can corrupt the card data. If the host wants to terminate the data transfer before the data transfer is complete, it can issue a stop or abort command, in which case the Host Controller does not generate an auto-stop command.

### 22.3.2.3 Non-Data Transfer Commands that Use Data Path

Some non-data transfer commands (non-read/write commands) also use the data path. Following table lists the commands and register programming requirements for them.

Table 22-3 Non-data Transfer Commands and Requirements

| Base Address [12:8]                   | CMD 27 | CMD 30 | CMD 42 | ACMD 13 | ACMD 22 | ACMD 51 |
|---------------------------------------|--------|--------|--------|---------|---------|---------|
| <b>SDMMC_CMD register programming</b> |        |        |        |         |         |         |
| cmd_index                             | 6'h1B  | 6'h1E  | 6'h2A  | 6'h0D   | 6'h16   | 6'h33   |
| response_expect                       | 1      | 1      | 1      | 1       | 1       | 1       |

| Base Address<br>[12:8] | CMD<br>27 | CMD<br>30 | CMD<br>42 | ACMD<br>13 | ACMD<br>22 | ACMD<br>51 |
|------------------------|-----------|-----------|-----------|------------|------------|------------|
| rResponse_length       | 0         | 0         | 0         | 0          | 0          | 0          |
| check_response_crc     | 1         | 1         | 1         | 1          | 1          | 1          |
| data_expected          | 1         | 1         | 1         | 1          | 1          | 1          |
| read/write             | 1         | 0         | 1         | 0          | 0          | 0          |
| transfer_mode          | 0         | 0         | 0         | 0          | 0          | 0          |
| send_auto_stop         | 0         | 0         | 0         | 0          | 0          | 0          |
| wait_prevdata_complete | 0         | 0         | 0         | 0          | 0          | 0          |
| stop_abort_cmd         | 0         | 0         | 0         | 0          | 0          | 0          |

**Command Argument register programming**

|  |               |                                               |            |               |            |               |
|--|---------------|-----------------------------------------------|------------|---------------|------------|---------------|
|  | stuff<br>bits | 32-bit<br>write<br>protect<br>data<br>address | stuff bits | stuff<br>bits | stuff bits | stuff<br>bits |
|--|---------------|-----------------------------------------------|------------|---------------|------------|---------------|

**Block Size register programming**

|    |   |                        |    |   |   |
|----|---|------------------------|----|---|---|
| 16 | 4 | Num_bytes <sup>①</sup> | 64 | 4 | 8 |
|----|---|------------------------|----|---|---|

**Byte Count register programming**

|    |   |                        |    |   |   |
|----|---|------------------------|----|---|---|
| 16 | 4 | Num_bytes <sup>①</sup> | 64 | 4 | 8 |
|----|---|------------------------|----|---|---|

<sup>①</sup>: Num\_bytes = No. of bytes specified as per the lock card data structure (Refer to the SD specification and the MMC specification)

**22.3.2.4 SDIO Interrupt Control**

Interrupts for SD cards are reported to the BIU by asserting an interrupt signal for two clock cycles. SDIO cards signal an interrupt by asserting cdata\_in low during the interrupt period; an interrupt period for the selected card is determined by the interrupt control state machine. An interrupt period is always valid for non-active or non-selected cards, and 1-bit data mode for the selected card. An interrupt period for a wide-bus active or selected card is valid for the following conditions:

- Card is idle
  - Non-data transfer command in progress
  - Third clock after end bit of data block between two data blocks
  - From two clocks after end bit of last data until end bit of next data transfer command
- Bear in mind that, in the following situations, the controller does not sample the SDIO interrupt of the selected card when the card data width is 4 bits. Since the SDIO interrupt is level-triggered, it is sampled in a further interrupt period and the host does not lose any SDIO interrupt from the card.
- Read/Write Resume – The CIU treats the resume command as a normal data transfer command. SDIO interrupts during the resume command are handled similarly to other data commands. According to the SDIO specification, for the normal data command the interrupt period ends after the command end bit of the data command; for the resume command, it ends after the response end bit. In the case of the resume command, the Controller stops the interrupt sampling period after the resume command end bit, instead of stopping after the response end bit of the resume command.

Suspend during read transfer – If the read data transfer is suspended by the host, the host sets the abort\_read\_data bit in the controller to reset the data state machine. In the CIU, the SDIO interrupts are handled such that the interrupt sampling starts after the abort\_read\_data bit is set by the host. In this case the controller does not sample SDIO interrupts between the period from response of the suspend command to setting the abort\_read\_data bit, and starts sampling after setting the abort\_read\_data bit.

**22.3.2.5 Clock Control**

The clock control block provides different clock frequencies required for SD/MMC cards. The cclk\_in signal is the source clock ( $cclk\_in \geq$  card max operating frequency) for clock divider of the clock control block. This source clock (cclk\_in) is used to generate different card clock frequencies (cclk\_out). The card clock can have different clock frequencies, since the card can be a low-speed card or a full-speed card. The Host Controller provides one clock signal (cclk\_out).

The clock frequency of a card depends on the following clock control registers:

- Clock Divider register – Internal clock dividers are used to generate different clock frequencies required for card. The division factor for each clock divider can be programmed by writing to the Clock Divider register. A value of 0 represents a clock-divider bypass, a value of 1 represents a divide by 2.
- Clock Control register – cclk\_out can be enabled or disabled for each card under the following conditions:
  - clk\_enable – cclk\_out for a card is enabled if the clk\_enable bit for a card in the Clock Control register is programmed (set to 1) or disabled (set to 0).
  - Low-power mode – Low-power mode of a card can be enabled by setting the low-power mode bit of the Clock Control register to 1. If low-power mode is enabled to save card power, the cclk\_out is disabled when the card is idle for at least 8 card clock cycles. It is enabled when a new command is loaded and the command path goes to a non-idle state.

Additionally, cclk\_out is disabled when an internal FIFO is full – card read (no more data can be received from card) – or when the FIFO is empty – card write (no data is available for transmission). This helps to avoid FIFO overrun and underrun conditions. It is used by the command and data path to qualify cclk\_in for driving outputs and sampling inputs at the programmed clock frequency for the selected card, according to the Clock Divider and Clock Source register values.

Under the following conditions, the card clock is stopped or disabled, along with the active clk\_en, for the selected card:

- Clock can be disabled by writing to Clock Enable register (clk\_en bit = 1).
- If low-power mode is selected and card is idle, or not selected for 8 clocks.
- FIFO is full and data path cannot accept more data from the card and data transfer is incomplete –to avoid FIFO overrun.

FIFO is empty and data path cannot transmit more data to the card and data transfer is incomplete – to avoid FIFO underrun.

### **22.3.2.6 Error Detection**

- Response
  - Response timeout – Response expected with response start bit is not received within programmed number of clocks in timeout register.
  - Response CRC error – Response is expected and check response CRC requested; response CRC7 does not match with the internally-generated CRC7.
  - Response error – Response transmission bit is not 0, command index does not match with the command index of the send command, or response end bit is not 1.
- Data transmit
  - No CRC status – During a write data transfer, if the CRC status start bit is not received two clocks after the end bit of the data block is sent out, the data path does the following:
    - ◆ Signals no CRC status error to the BIU
    - ◆ Terminates further data transfer
    - ◆ Signals data transfer done to the BIU
  - Negative CRC – If the CRC status received after the write data block is negative (that is, not 010), a data CRC error is signaled to the BIU and further data transfer is continued.
  - Data starvation due to empty FIFO – If the FIFO becomes empty during a write data transmission, or if the card clock is stopped and the FIFO remains empty for data timeout clocks, then a data-starvation error is signaled to the BIU and the data path continues to wait for data in the FIFO.
- Data receive
  - Data timeout – During a read-data transfer, if the data start bit is not received before the number of clocks that were programmed in the timeout register, the data path does the following:
    - ◆ Signals data-timeout error to the BIU
    - ◆ Terminates further data transfer
    - ◆ Signals data transfer done to BIU

- Data start bit error – During a 4-bit or 8-bit read-data transfer, if the all-bit data line does not have a start bit, the data path signals a data start bit error to the BIU and waits for a data timeout, after which it signals that the data transfer is done.
- Data CRC error – During a read-data-block transfer, if the CRC16 received does not match with the internally generated CRC16, the data path signals a data CRC error to the BIU and continues further data transfer.
- Data end-bit error – During a read-data transfer, if the end bit of the received data is not 1, the data path signals an end-bit error to the BIU, terminates further data transfer, and signals to the BIU that the data transfer is done.

Data starvation due to FIFO full – During a read data transmission and when the FIFO becomes full, the card clock is stopped. If the FIFO remains full for data timeout clocks, a data starvation error is signaled to the BIU (Data Starvation by Host Timeout bit is set in SDMMC\_RINTSTS register) and the data path continues to wait for the FIFO to start to empty.

### **22.3.3 Internal Direct Memory Access Controller (IDMAC)**

The Internal Direct Memory Access Controller (IDMAC) has a Control and Status Register (CSR) and a single Transmit/Receive engine, which transfers data from host memory to the device port and vice versa. The controller utilizes a descriptor to efficiently move data from source to destination with minimal Host CPU intervention. You can program the controller to interrupt the Host CPU in situations such as data Transmit and Receive transfer completion from the card, as well as other normal or error conditions.

The IDMAC and the Host driver communicate through a single data structure. CSR addresses 0x80 to 0x98 are reserved for host programming.

The IDMAC transfers the data received from the card to the Data Buffer in the Host memory, and it transfers Transmit data from the Data Buffer in the Host memory to the FIFO. Descriptors that reside in the Host memory act as pointers to these buffers.

A data buffer resides in physical memory space of the Host and consists of complete data or partial data. Buffers contain only data, while buffer status is maintained in the descriptor. Data chaining refers to data that spans multiple data buffers. However, a single descriptor cannot span multiple data.

A single descriptor is used for both reception and transmission. The base address of the list is written into Descriptor List Base Address Register (SDMMC\_DBADDR @0x88). A descriptor list is forward linked. The Last Descriptor can point back to the first entry in order to create a ring structure. The descriptor list resides in the physical memory address space of the Host. Each descriptor can point to a maximum of two data buffers.

#### **22.3.3.1 IDMAC CSR Access**

When an IDMAC is introduced, an additional CSR space resides in the IDMAC that controls the IDMAC functionality. The host accesses the new CSR space in addition to the existing control register set in the BIU. The IDMAC CSR primarily contains descriptor information. For a write operation to the CSR, the respective CSR logic of the IDMAC and BIU decodes the address before accepting. For a read operation from the CSR, the appropriate CSR read path is enabled.

You can enable or disable the IDMAC operation by programming bit[25] in the SDMMC\_CTRL register of the BIU. This allows the data transfer by accessing the slave interface on the AMBA bus if the IDMAC is present but disabled. When IDMAC is enabled, the FIFO cannot be accessed through the slave interface.

#### **22.3.3.2 Descriptors**

- Descriptor structures

The IDMAC uses these types of descriptor structures:

- Dual-Buffer Structure – The distance between two descriptors is determined by the Skip Length value programmed in the Descriptor Skip Length (DSL) field of the Bus Mode Register (SDMMC\_BMOD @0x80).



Fig. 22-6 Dual-Buffer Descriptor Structure

- Chain Structure – Each descriptor points to a unique buffer and the next descriptor.



Fig. 22-7 Chain Descriptor Structure

- Descriptor formats

Following figure illustrates the internal formats of a descriptor. The descriptor addresses must be aligned to the bus width used for 32-bit AHB data buses. Each descriptor contains 16 bytes of control and status information. DES0 is a notation used to denote the [31:0] bits, DES1 to denote [63:32] bits, DES2 to denote [95:64] bits, DES3 to denote [127:96] bits.



Fig. 22-8 Descriptor Formats for 32-bit AHB Address Bus Width

- The DES0 element in the IDMAC contains control and status information.

Table 22-4 Bits in IDMAC DES0 Element

| Bit | Name                     | Description                                                                                                                                                                                                                                                     |
|-----|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | OWN                      | <p>When set, this bit indicates that the descriptor is owned by the IDMAC.</p> <p>When this bit is reset, it indicates that the descriptor is owned by the Host.</p> <p>The IDMAC clears this bit when it completes the data transfer.</p>                      |
| 30  | Card Error Summary (CES) | <p>These error bits indicate the status of the transaction to or from the card.</p> <p>These bits are also present in SDMMC_RINTSTS. Indicates the logical OR of the following bits:</p> <ul style="list-style-type: none"> <li>• EBE: End Bit Error</li> </ul> |

| Bit  | Name                                  | Description                                                                                                                                                                                                                                                                                                                                                |
|------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                                       | <ul style="list-style-type: none"> <li>● RTO: Response Time out</li> <li>● RCRC: Response CRC</li> <li>● SBE: Start Bit Error</li> <li>● DRTO: Data Read Timeout</li> <li>● DCRC: Data CRC for Receive</li> <li>● RE: Response Error</li> </ul>                                                                                                            |
| 29:6 | Reserved                              | -                                                                                                                                                                                                                                                                                                                                                          |
| 5    | End of Ring (ER)                      | When set, this bit indicates that the descriptor list reached its final descriptor. The IDMAC returns to the base address of the list, creating a Descriptor Ring. This is meaningful for only a dual-buffer descriptor structure.                                                                                                                         |
| 4    | Second Address Chained (CH)           | When set, this bit indicates that the second address in the descriptor is the Next Descriptor address rather than the second buffer address. When this bit is set, BS2 (DES1[25:13]) should be all zeros.                                                                                                                                                  |
| 3    | First Descriptor (FS)                 | When set, this bit indicates that this descriptor contains the first buffer of the data. If the size of the first buffer is 0, next Descriptor contains the beginning of the data.                                                                                                                                                                         |
| 2    | Last Descriptor (LD)                  | This bit is associated with the last block of a DMA transfer. When set, the bit indicates that the buffers pointed to by this descriptor are the last buffers of the data. After this descriptor is completed, the remaining byte count is 0. In other words, after the descriptor with the LD bit set is completed, the remaining byte count should be 0. |
| 1    | Disable Interrupt on Completion (DIC) | When set, this bit will prevent the setting of the TI/RI bit of the IDMAC Status Register (IDSTS) for the data that ends in the buffer pointed to by this descriptor.                                                                                                                                                                                      |
| 0    | Reserved                              | -                                                                                                                                                                                                                                                                                                                                                          |

- The DES1 element contains the buffer size.

Table 22-5 Bits in IDMAC DES1 Element

| Bit   | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | Reserved            | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 25:13 | Buffer 2 Size (BS2) | These bits indicate the second data buffer byte size. The buffer size must be a multiple of 2, 4, or 8, depending upon the bus widths—16, 32, and 64 respectively. In the case where the buffer size is not a multiple of 2, 4, or 8, the resulting behavior is undefined. If this field is 0, the DMA ignores this buffer and proceeds to the next buffer in case of a dual-buffer structure. This field is not valid for chain structure; that is, if DES0[4] is set. |
| 12:0  | Buffer 1 Size (BS1) | Indicates the data buffer byte size, which must be a multiple of 2, 4, or 8 bytes, depending upon the bus widths—16, 32, and 64, respectively. In the case where the buffer size is not a multiple of 2, 4, or 8, the resulting behavior is undefined. This field should not be zero.<br>Note: If there is only one buffer to be programmed, you need to use only the Buffer 1, and not Buffer 2.                                                                       |

- The DES2 element contains the address pointer to the data buffer.

Table 22-6 Bits in IDMAC DES2 Element

| Bit   | Name                | Description                                                                                                                                                                                                                                                  |
|-------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | Reserved            |                                                                                                                                                                                                                                                              |
| 25:13 | Buffer 2 Size (BS2) | These bits indicate the second data buffer byte size. The buffer size must be a multiple of 2, 4, or 8, depending upon the bus widths—16, 32, and 64 respectively. In the case where the buffer size is not a multiple of 2, 4, or 8, the resulting behavior |

| Bit  | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                     | is undefined. If this field is 0, the DMA ignores this buffer and proceeds to the next buffer in case of a dual-buffer structure. This field is not valid for chain structure; that is, if DES0[4] is set.                                                                                                                                                                                        |
| 12:0 | Buffer 1 Size (BS1) | Indicates the data buffer byte size, which must be a multiple of 2, 4, or 8 bytes, depending upon the bus widths—16, 32, and 64, respectively. In the case where the buffer size is not a multiple of 2, 4, or 8, the resulting behavior is undefined. This field should not be zero.<br>Note: If there is only one buffer to be programmed, you need to use only the Buffer 1, and not Buffer 2. |

- The DES3 element contains the address pointer to the next descriptor if the present descriptor is not the last descriptor in a chained descriptor structure or the second buffer address for a dual-buffer structure.

Table 22-7 Bits in IDMAC DES3 Element

| Bit  | Name                                                     | Description                                                                                                                                                                                                                                                                                                                                                              |
|------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Buffer Address Pointer 2/ Next Descriptor Address (BAP2) | These bits indicate the physical address of the second buffer when the dual-buffer structure is used. If the Second Address Chained (DES0[4]) bit is set, then this address contains the pointer to the physical memory where the Next Descriptor is present.<br>If this is not the last descriptor, then the Next Descriptor address pointer must be bus-width aligned. |

### 22.3.3.3 Initialization

IDMAC initialization occurs as follows:

- Write to IDMAC Bus Mode Register—SDMMC\_BMOD to set Host bus access parameters.
- Write to IDMAC Interrupt Enable Register—SDMMC\_IDINTEN to mask unnecessary interrupt causes.
- The software driver creates either the Transmit or the Receive descriptor list. Then it writes to IDMAC Descriptor List Base Address Register (SDMMC\_DBADDR), providing the IDMAC with the starting address of the list.
- The IDMAC engine attempts to acquire descriptors from the descriptor lists.

- Host Bus Burst Access

The IDMAC attempts to execute fixed-length burst transfers on the AHB Master interface if configured using the FB bit of the IDMAC Bus Mode register. The maximum burst length is indicated and limited by the PBL field. The descriptors are always accessed in the maximum possible burst-size for the 16-bytes to be read— 16\*8/bus-width.

The IDMAC initiates a data transfer only when sufficient space to accommodate the configured burst is available in the FIFO or the number of bytes to the end of data, when less than the configured burst-length.

The IDMAC indicates the start address and the number of transfers required to the AHB Master Interface. When the AHB Interface is configured for fixed-length bursts, then it transfers data using the best combination of INCR4/8/16 and SINGLE transactions.

Otherwise, in no fixed-length bursts, it transfers data using INCR (undefined length) and SINGLE transactions.

- Host Data Buffer Alignment

The Transmit and Receive data buffers in host memory must be aligned, depending on the data width.

- Buffer Size Calculations

The driver knows the amount of data to transmit or receive. For transmitting to the card, the IDMAC transfers the exact number of bytes to the FIFO, indicated by the buffer size field of DES1.

If a descriptor is not marked as last-LS bit of DES0-then the corresponding buffer(s) of the descriptor are full, and the amount of valid data in a buffer is accurately indicated by its buffer size field. If a descriptor is marked as last, then the buffer cannot be full, as indicated by the buffer size in DES1. The driver is aware of the number of locations that are

valid in this case.

- Transmission

IDMAC transmission occurs as follows:

- 1) The Host sets up the elements (DES0-DES3) for transmission and sets the OWN bit (DES0[31]). The Host also prepares the data buffer.
- 2) The Host programs the write data command in the SDMMC\_CMD register in BIU.
- 3) The Host will also program the required transmit threshold level (TX\_WMark field in SDMMC\_FIFOTH register).
- 4) The IDMAC determines that a write data transfer needs to be done as a consequence of step 2.
- 5) The IDMAC engine fetches the descriptor and checks the OWN bit. If the OWN bit is not set, it means that the host owns the descriptor. In this case the IDMAC enters suspend state and asserts the Descriptor Unable interrupt in the SDMMC\_IDSTS register. In such a case, the host needs to release the IDMAC by writing any value to the poll demand register.
- 6) It will then wait for Command Done (CD) bit and no errors from BIU which indicates that a transfer can be done.
- 7) The IDMAC engine will now wait for a DMA interface request from BIU. This request will be generated based on the programmed transmit threshold value. For the last bytes of data which can't be accessed using a burst, SINGLE transfers are performed on AHB Master Interface.
- 8) The IDMAC fetches the Transmit data from the data buffer in the Host memory and transfers to the FIFO for transmission to card.
- 9) When data spans across multiple descriptors, the IDMAC will fetch the next descriptor and continue with its operation with the next descriptor. The Last Descriptor bit in the descriptor indicates whether the data spans multiple descriptors or not.
- 10) When data transmission is complete, status information is updated in SDMMC\_IDSTS register by setting Transmit Interrupt, if enabled. Also, the OWN bit is cleared by the IDMAC by performing a write transaction to DES0.

- Reception

IDMAC reception occurs as follows:

- 1) The Host sets up the element (DES0-DES3) for reception, sets the OWN (DES0[31]).
- 2) The Host programs the read data command in the SDMMC\_CMD register in BIU.
- 3) The Host will program the required receive threshold level (RX\_WMark field in FIFOTH register).
- 4) The IDMAC determines that a read data transfer needs to be done as a consequence of step 2.
- 5) The IDMAC engine fetches the descriptor and checks the OWN bit. If the OWN bit is not set, it means that the host owns the descriptor. In this case the DMA enters suspend state and asserts the Descriptor Unable interrupt in the SDMMC\_IDSTS register. In such a case, the host needs to release the IDMAC by writing any value to the poll demand register.
- 6) It will then wait for Command Done (CD) bit and no errors from BIU which indicates that a transfer can be done.
- 7) The IDMAC engine will now wait for a DMA interface request from BIU. This request will be generated based on the programmed receive threshold value. For the last bytes of data which can't be accessed using a burst, SINGLE transfers are performed on AHB.
- 8) The IDMAC fetches the data from the FIFO and transfer to Host memory.
- 9) When data spans across multiple descriptors, the IDMAC will fetch the next descriptor and continue with its operation with the next descriptor. The Last Descriptor bit in the descriptor indicates whether the data spans multiple descriptors or not.
- 10) When data reception is complete, status information is updated in SDMMC\_IDSTS register by setting Receive Interrupt, if enabled. Also, the OWN bit is cleared by the IDMAC by performing a write transaction to DES0.

- Interrupts

Interrupts can be generated as a result of various events. SDMMC\_IDSTS register contains all the bits that might cause an interrupt. SDMMC\_IDINTEN register contains an Enable bit

for each of the events that can cause an interrupt.

There are two groups of summary interrupts-Normal and Abnormal-as outlined in SDMMC\_IDSTS register. Interrupts are cleared by writing a 1 to the corresponding bit position. When all the enabled interrupts within a group are cleared, the corresponding summary bit is cleared. When both the summary bits are cleared, the interrupt signal dmac\_intr\_o is de-asserted.

Interrupts are not queued and if the interrupt event occurs before the driver has responded to it, no additional interrupts are generated. For example, Receive Interrupt—

SDMMC\_IDSTS[1] indicates that one or more data was transferred to the Host buffer.

An interrupt is generated only once for simultaneous, multiple events. The driver must scan SDMMC\_IDSTS register for the interrupt cause.

### 22.3.3.4 Variable Delay/Clock Generation Unit

Variable delay mechanism for the cclk\_in\_drv is useful in order to meet a range of hold-time requirements across modes. Variable delay mechanism for the cclk\_in\_sample is mandatory and is required to achieve the correct sampling point for data.

The Clock Generation Unit (CLKGEN) includes Phase Shift Unit and Delay Line Unit.

The Phase Shift Unit can shift cclk\_in\_sample/cclk\_in\_drv by 0/90/180/270-degree relative to cclk\_in. The Delay Line Unit can shift cclk\_in\_sample/cclk\_in\_drv step by step in the unit of delay element. The delay value range is 25ps~56ps for every delay element; the max delay element number is 256.

The architecture is as follows.



Fig. 22-9 Clock Generation Unit

## 22.4 Register Description

### 22.4.1 Registers Summary

| Name                 | Offset | Size | Reset Value | Description                      |
|----------------------|--------|------|-------------|----------------------------------|
| <u>SDMMC_CTRL</u>    | 0x0000 | W    | 0x00000000  | Control register                 |
| <u>SDMMC_PWREN</u>   | 0x0004 | W    | 0x00000000  | Power enable register            |
| <u>SDMMC_CLKDIV</u>  | 0x0008 | W    | 0x00000000  | Clock divider register           |
| <u>SDMMC_CLKSRC</u>  | 0x000C | W    | 0x00000000  | SD clock source register         |
| <u>SDMMC_CLKENA</u>  | 0x0010 | W    | 0x00000000  | Clock enable register            |
| <u>SDMMC_TMOOUT</u>  | 0x0014 | W    | 0xFFFFFFF40 | Timeout register                 |
| <u>SDMMC_CTYPE</u>   | 0x0018 | W    | 0x00000000  | Card type register               |
| <u>SDMMC_BLKSIZ</u>  | 0x001C | W    | 0x00000200  | Block size register              |
| <u>SDMMC_BYTCNT</u>  | 0x0020 | W    | 0x00000200  | Byte count register              |
| <u>SDMMC_INTMASK</u> | 0x0024 | W    | 0x00000000  | Interrupt mask register          |
| <u>SDMMC_CMDARG</u>  | 0x0028 | W    | 0x00000000  | Command argument register        |
| <u>SDMMC_CMD</u>     | 0x002C | W    | 0x20000000  | Command register                 |
| <u>SDMMC_RESP0</u>   | 0x0030 | W    | 0x00000000  | Response register 0              |
| <u>SDMMC_RESP1</u>   | 0x0034 | W    | 0x00000000  | Response register 1              |
| <u>SDMMC_RESP2</u>   | 0x0038 | W    | 0x00000000  | Response register 2              |
| <u>SDMMC_RESP3</u>   | 0x003C | W    | 0x00000000  | Response register 3              |
| <u>SDMMC_MINTSTS</u> | 0x0040 | W    | 0x00000000  | Masked interrupt status register |
| <u>SDMMC_RINTSTS</u> | 0x0044 | W    | 0x00000000  | Raw interrupt status register    |
| <u>SDMMC_STATUS</u>  | 0x0048 | W    | 0x00000106  | Status register                  |

| Name                       | Offset | Size | Reset Value | Description                                      |
|----------------------------|--------|------|-------------|--------------------------------------------------|
| <u>SDMMC FIFO TH</u>       | 0x004C | W    | 0x00FF0000  | FIFO threshold register                          |
| <u>SDMMC CDETECT</u>       | 0x0050 | W    | 0x00000001  | Card detect register                             |
| <u>SDMMC WRPRT</u>         | 0x0054 | W    | 0x00000000  | Write protect register                           |
| <u>SDMMC TCBCNT</u>        | 0x005C | W    | 0x00000000  | Transferred card byte count register             |
| <u>SDMMC TBBCNT</u>        | 0x0060 | W    | 0x00000000  | Transferred host to FIFO byte count register     |
| <u>SDMMC DEBNCE</u>        | 0x0064 | W    | 0x00FFFFFF  | Debounce count register                          |
| <u>SDMMC USRID</u>         | 0x0068 | W    | 0x00000000  | User ID register                                 |
| <u>SDMMC VERID</u>         | 0x006C | W    | 0x5342270A  | Version ID register                              |
| <u>SDMMC HCON</u>          | 0x0070 | W    | 0x04C434C1  | Hardware configuration register                  |
| <u>SDMMC UHSREG</u>        | 0x0074 | W    | 0x00000000  | UHS-1 control register                           |
| <u>SDMMC RSTN</u>          | 0x0078 | W    | 0x00000001  | Hardware reset register                          |
| <u>SDMMC BMOD</u>          | 0x0080 | W    | 0x00000000  | Bus mode register                                |
| <u>SDMMC PLDMND</u>        | 0x0084 | W    | 0x00000000  | Poll demand register                             |
| <u>SDMMC DBADDR</u>        | 0x0088 | W    | 0x00000000  | Descriptor list base address register            |
| <u>SDMMC IDSTS</u>         | 0x008C | W    | 0x00000000  | Internal DMAC status register                    |
| <u>SDMMC IDINTEN</u>       | 0x0090 | W    | 0x00000000  | Internal DMAC interrupt enable register          |
| <u>SDMMC DSCADDR</u>       | 0x0094 | W    | 0x00000000  | Current host descriptor address register         |
| <u>SDMMC BUFADDR</u>       | 0x0098 | W    | 0x00000000  | Current buffer descriptor address register       |
| <u>SDMMC CARDTHRCTL</u>    | 0x0100 | W    | 0x00000000  | Card threshold control register                  |
| <u>SDMMC BACKEND POWER</u> | 0x0104 | W    | 0x00000000  | Back-end power register                          |
| <u>SDMMC EMMCDDR REG</u>   | 0x010C | W    | 0x00000000  | eMMC4.5 DDR start bit detection control register |
| <u>SDMMC RDYINT GEN</u>    | 0x0120 | W    | 0x00FF0000  | Card ready interrupt generation control register |
| <u>SDMMC FIFO BASE</u>     | 0x0200 | W    | 0x00000000  | FIFO base address register                       |

Notes:  
Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 22.4.2 Detail Register Description

### SDMMC CTRL

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                               |
| 25    | RW   | 0x0         | use_internal_dmac<br>Present only for the Internal DMAC configuration; else, it is reserved.<br>1'b0: The host performs data transfers through the slave interface<br>1'b1: Internal DMAC used for data transfer                                                                                                                                                                       |
| 24:12 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                                                                               |
| 11    | RW   | 0x0         | ceata_device_interrupt_status<br>1'b0: Interrupts not enabled in CE-ATA device<br>1'b1: Interrupts are enabled in CE-ATA device<br>Software should appropriately write to this bit after power-on reset or any other reset to CE-ATA device. After reset, usually CE-ATA device interrupt is disabled. If the host enables CE-ATA device interrupt, then software should set this bit. |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10  | RW   | 0x0         | <p>send_auto_stop_ccsd<br/>           1'b0: Clear bit if Host Controller does not reset the bit<br/>           1'b1: Send internally generated STOP after sending CCSD to CE-ATA device<br/>           NOTE: Always set send_auto_stop_ccsd and send_ccsd bits together send_auto_stop_ccsd should not be set independent of send_ccsd.<br/>           When set, the Host Controller automatically sends internally-generated STOP command (CMD12) to CE-ATA device. After sending internally-generated STOP command, Auto Command Done (ACD) bit in SDMMC_RINTSTS is set and generates interrupt to host if Auto Command Done interrupt is not masked. After sending the CCSD, the Host Controller automatically clears send_auto_stop_ccsd bit.</p>                                                                                                                               |
| 9   | RW   | 0x0         | <p>send_ccsd<br/>           1'b0: Clear bit if Host Controller does not reset the bit<br/>           1'b1: Send Command Completion Signal Disable (CCSD) to CE-ATA device<br/>           When set, the Host Controller sends CCSD to CE-ATA device. Software sets this bit only if current command is expecting CCS (that is, RW_BLK) and interrupts are enabled in CE-ATA device. Once the CCSD pattern is sent to device, the Host Controller automatically clears send_ccsd bit. It also sets Command Done (CD) bit in SDMMC_RINTSTS register and generates interrupt to host if Command Done interrupt is not masked.<br/>           NOTE: Once send_ccsd bit is set, it takes two card clock cycles to drive the CCSD on the CMD line. Due to this, during the boundary conditions it may happen that CCSD is sent to the CE-ATA device, even if the device signalled CCS.</p> |
| 8   | RW   | 0x0         | <p>abort_read_data<br/>           1'b0: No change<br/>           1'b1: After suspend command is issued during read-transfer, software polls card to find when suspend happened. Once suspend occurs, software sets bit to reset data state-machine, which is waiting for next block of data. Bit automatically clears once data state machine resets to idle.<br/>           Used in SDIO card suspend sequence.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7   | RW   | 0x0         | <p>send_irq_response<br/>           1'b0: No change<br/>           1'b1: Send auto IRQ response<br/>           Bit automatically clears once response is sent.<br/>           To wait for MMC card interrupts, software issues CMD40, and the Host Controller waits for interrupt response from MMC card. In meantime, if software wants the Controller to exit waiting for interrupt state, it can set this bit, at which time the Host Controller command state-machine sends CMD40 response on bus and returns to idle state.</p>                                                                                                                                                                                                                                                                                                                                                |
| 6   | RW   | 0x0         | <p>read_wait<br/>           1'b0: Clear read wait<br/>           1'b1: Assert read wait<br/>           For sending read-wait to SDIO cards.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0x0         | dma_enable<br>1'b0: Disable DMA transfer mode<br>1'b1: Enable DMA transfer mode<br>Even when DMA mode is enabled, host can still push/pop data into or from FIFO; this should not happen during the normal operation. If there is simultaneous FIFO access from host/DMA, the data coherency is lost. Also, there is no arbitration inside the controller to prioritize simultaneous host/DMA access.                                                                                      |
| 4   | RW   | 0x0         | int_enable<br>Global interrupt enable/disable bit<br>1'b0: Disable interrupts<br>1'b1: Enable interrupts<br>The int port is 1 only when this bit is 1 and one or more unmasked interrupts are set.                                                                                                                                                                                                                                                                                         |
| 3   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2   | W1C  | 0x0         | dma_reset<br>1'b0: No change<br>1'b1: Reset internal DMA interface control logic<br>To reset DMA interface, firmware should set bit to 1.<br>This bit is auto-cleared after two AHB clocks.                                                                                                                                                                                                                                                                                                |
| 1   | W1C  | 0x0         | fifo_reset<br>1'b0: No change<br>1'b1: Reset to data FIFO to reset FIFO pointers<br>To reset FIFO, firmware should set bit to 1.<br>This bit is auto-cleared after completion of reset operation.                                                                                                                                                                                                                                                                                          |
| 0   | W1C  | 0x0         | controller_reset<br>1'b0: No change<br>1'b1: Reset Host Controller<br>To reset Host Controller, firmware should set bit to 1. This bit is auto-cleared after two AHB and two cclk_in clock cycles.<br>This resets:<br>a. BIU/CIU interface<br>b. CIU and state machines<br>c. abort_read_data, send_irq_response, and read_wait bits of SDMMC_CTRL register<br>d. start_cmd bit of SDMMC_CMD register<br>Does not affect any registers or DMA interface, or FIFO or controller interrupts. |

**SDMMC PWREN**

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                |
| 0    | RW   | 0x0         | power_enable<br>Power on/off switch for the card.<br>Once power is turned on, firmware should wait for regulator/switch ramp-up time before trying to initialize card.<br>1'b0: Power off<br>1'b1: Power on<br>Bit values output to card_power_en port. |

**SDMMC CLKDIV**

Address: Operational Base + offset (0x0008)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:8 | RO   | 0x0000000   | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | RW          | 0x00               | clk_divider0<br>Clock divider-0 value. Clock division is $2^n$ .<br>For example, value of 0 means divide by $2^0 = 0$ (no division, bypass), value of 1 means divide by $2^1 = 2$ , and so on.<br>The recommended value is 0 or 1. |

**SDMMC CLKSRC**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                            |
| 1:0        | RW          | 0x0                | clk_source<br>Clock divider source.<br>2'b00: Clock divider 0<br>The cclk_out is always from clock divider 0, and this register is not implemented. |

**SDMMC CLKENA**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                     |
| 16         | RW          | 0x0                | cclk_low_power<br>Low-power control for SD card clock and MMC card clock supported.<br>1'b0: Non-low-power mode<br>1'b1: Low-power mode. Stop clock when card in IDLE (should be normally set to only MMC and SD memory cards; for SDIO cards, if interrupts must be detected, clock should not be stopped). |
| 15:1       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                     |
| 0          | RW          | 0x0                | cclk_enable<br>Clock-enable control for SD card clock and MMC card clock supported.<br>1'b0: Clock disabled<br>1'b1: Clock enabled                                                                                                                                                                           |

**SDMMC TMOUT**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RW          | 0xffffffff         | data_timeout<br>Value for card data read timeout; same value also used for data starvation by host timeout.<br>Value is in number of card output clock.<br>Note: The software timer should be used if the timeout value is in the order of 100 ms. In this case, read data timeout interrupt needs to be disabled. |
| 7:0        | RW          | 0x40               | response_timeout<br>Response timeout value.<br>Value is in number of card output clock cclk_out.                                                                                                                                                                                                                   |

**SDMMC CTYPE**

Address: Operational Base + offset (0x0018)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | card_width_8<br>Indicates if card is 8-bit.<br>1'b0: Non 8-bit mode<br>1'b1: 8-bit mode    |
| 15:1       | RO          | 0x0000             | reserved                                                                                   |
| 0          | RW          | 0x0                | card_width<br>Indicates if card is 1-bit or 4-bit.<br>1'b0: 1-bit mode<br>1'b1: 4-bit mode |

**SDMMC\_BLKSIZ**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>       |
|------------|-------------|--------------------|--------------------------|
| 31:16      | RO          | 0x0000             | reserved                 |
| 15:0       | RW          | 0x0200             | block_size<br>Block size |

**SDMMC\_BYTCNT**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x000000200        | byte_count<br>Number of bytes to be transferred; should be integer multiple of block size for block transfers.<br>For undefined number of byte transfers, byte count should be set to 0. When byte count is set to 0, it is responsibility of host to explicitly send stop/abort command to terminate data transfer. |

**SDMMC\_INTMASK**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                               |
| 24         | RW          | 0x0                | sdio_int_mask<br>1'b0: SDIO interrupt not masked<br>1'b1: SDIO interrupt masked                        |
| 23:17      | RO          | 0x00               | reserved                                                                                               |
| 16         | RW          | 0x0                | data_nobusy_int_mask<br>1'b0: Data no busy interrupt not masked<br>1'b1: Data no busy interrupt masked |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>int_mask<br/>           Bits used to mask unwanted interrupts. Value of 0 masks interrupt; value of 1 enables interrupt.</p> <p>bit 15: End-bit error (read)/Write no CRC (EBE)<br/>           bit 14: Auto command done (ACD)<br/>           bit 13: Start-bit error (SBE)<br/>           bit 12: Hardware locked write error (HLE)<br/>           bit 11: FIFO underrun/overrun error (FRUN)<br/>           bit 10: Data starvation-by-host timeout (HTO) /Volt_switch_int<br/>           bit 9: Data read timeout (DRTO)<br/>           bit 8: Response timeout (RTO)<br/>           bit 7: Data CRC error (DCRC)<br/>           bit 6: Response CRC error (RCRC)<br/>           bit 5: Receive FIFO data request (RXDR)<br/>           bit 4: Transmit FIFO data request (TXDR)<br/>           bit 3: Data transfer over (DTO)<br/>           bit 2: Command done (CD)<br/>           bit 1: Response error (RE)<br/>           bit 0: Card detect (CD)</p> |

**SDMMC\_CMDARG**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>cmd_arg<br/>           Value indicates command argument to be passed to card</p> |

**SDMMC\_CMD**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>start_cmd<br/>           Start command.<br/>           Once command is taken by CIU, bit is cleared.<br/>           When bit is set, host should not attempt to write to any command registers. If write is attempted, hardware lock error is set in raw interrupt register.<br/>           Once command is sent and response is received from SD/MMC cards, Command Done bit is set in raw interrupt register.</p> |
| 30         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                               |
| 29         | RW          | 0x1                | <p>use_hold_reg<br/>           Use hold register.<br/>           1'b0: CMD and DATA sent to card bypassing hold register<br/>           1'b1: CMD and DATA sent to card through the hold register</p>                                                                                                                                                                                                                  |
| 28         | RW          | 0x0                | <p>volt_switch<br/>           Voltage switch bit.<br/>           1'b0: No voltage switching<br/>           1'b1: Voltage switching enabled; must be set for CMD11 only.</p>                                                                                                                                                                                                                                            |
| 27         | RW          | 0x0                | <p>boot_mode<br/>           Boot mode selection.<br/>           1'b0: Mandatory boot operation<br/>           1'b1: Alternate boot operation</p>                                                                                                                                                                                                                                                                       |
| 26         | RW          | 0x0                | <p>disable_boot<br/>           Disable boot.<br/>           When software sets this bit along with start_cmd, CIU terminates the boot operation. Do not set disable_boot and enable_boot together.</p>                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25         | RW          | 0x0                | expect_boot_ack<br>Expect boot acknowledge.<br>When software sets this bit along with enable_boot, CIU expects a boot acknowledge start pattern of 0-1-0 from the selected card.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 24         | RW          | 0x0                | enable_boot<br>Enable boot.<br>This bit should be set only for mandatory boot mode. When Software sets this bit along with start_cmd, CIU starts the boot sequence for the corresponding card by asserting the CMD line low. Do not set disable_boot and enable_boot together.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 23         | RW          | 0x0                | ccs_expected<br>1'b0: Interrupts are not enabled in CE-ATA device or command does not expect CCS from device<br>1'b1: Interrupts are enabled in CE-ATA device and RW_BLK command expects command completion signal from CE-ATA device<br>If the command expects command completion signal (CCS) from the CE-ATA device, the software should set this control bit.<br>The Host Controller sets data transfer over (DTO) bit in SDMMC_RINTSTS register and generates interrupt to host if data transfer over interrupt is not masked.                                                                                                                                                                                                                                                                                                                |
| 22         | RW          | 0x0                | read_ceata_device<br>1'b0: Host is not performing read access towards CE-ATA device<br>1'b1: Host is performing read access towards CE-ATA device<br>Software should set this bit to indicate that CE-ATA device is being accessed for read transfer. This bit is used to disable read data timeout indication while performing CE-ATA read transfers. Maximum value of I/O transmission delay can be no less than 10 seconds. The Host Controller should not indicate read data timeout while waiting for data from CE-ATA device.                                                                                                                                                                                                                                                                                                                |
| 21         | RW          | 0x0                | update_clock_regs_only<br>1'b0: Normal command sequence<br>1'b1: Do not send commands, just update clock register value into card clock domain.<br>Following register values transferred into card clock domain: SDMMC_CLKDIV, SDMMC_CLRSRC, SDMMC_CLKENA.<br>Changes card clocks (change frequency, truncate off or on, and set low-frequency mode); provided in order to change clock frequency or stop clock without having to send command to cards.<br>During normal command sequence, when update_clock_regs_only = 0, following control registers are transferred from BIU to CIU: SDMMC_CMD, SDMMC_CMDARG, SDMMC_TMOUT, SDMMC_CTYPE, SDMMC_BLKSIZ, SDMMC_BYTCNT. CIU uses new register values for new command sequence to card.<br>When bit is set, there are no Command Done interrupts because no command is sent to SD_MMC_CEATA cards. |
| 20:16      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | <p>send_initialization<br/>           1'b0: Do not send initialization sequence (80 clocks of 1) before sending this command<br/>           1'b1: Send initialization sequence before sending this command<br/>           After power on, 80 clocks must be sent to card for initialization before sending any commands to card. Bit should be set while sending first command to card so that controller will initialize clocks before sending command to card. This bit should not be set for either of the boot modes (alternate or mandatory).</p>                                                                                                                                                                 |
| 14         | RW          | 0x0                | <p>stop_abort_cmd<br/>           1'b0: Neither stop nor abort command to stop current data transfer in progress. If abort is sent to function-number currently selected or not in data-transfer mode, then bit should be set to 0.<br/>           1'b1: Stop or abort command intended to stop current data transfer in progress.<br/>           When open-ended or predefined data transfer is in progress, and host issues stop or abort command to stop data transfer, bit should be set so that command/data state-machines of CIU can return correctly to idle state. This is also applicable for Boot mode transfers. To Abort boot mode, this bit should be set along with SDMMC_CMD[26]=disable_boot.</p>      |
| 13         | RW          | 0x0                | <p>wait_prvdata_complete<br/>           1'b0: Send command at once, even if previous data transfer has not completed<br/>           1'b1: Wait for previous data transfer completion before sending command<br/>           The wait_prvdata_complete=0 option typically used to query status of card during data transfer or to stop current data transfer; card_number should be same as in previous command.</p>                                                                                                                                                                                                                                                                                                     |
| 12         | RW          | 0x0                | <p>send_auto_stop<br/>           1'b0: No stop command sent at end of data transfer<br/>           1'b1: Send stop command at end of data transfer<br/>           When set, the Host Controller sends stop command to card at end of data transfer.<br/>           a. When send_auto_stop bit should be set, since some data transfers do not need explicit stop commands<br/>           b. Open-ended transfers that software should explicitly send to stop command<br/>           Additionally, when "resume" is sent to resume-suspended memory access of SD-Combo card, bit should be set correctly if suspended data transfer needs send_auto_stop.<br/>           Don't care if no data expected from card.</p> |
| 11         | RW          | 0x0                | <p>transfer_mode<br/>           1'b0: Block data transfer command<br/>           1'b1: Stream data transfer command<br/>           Don't care if no data expected.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 10         | RW          | 0x0                | <p>wr<br/>           1'b0: Read from card<br/>           1'b1: Write to card<br/>           Don't care if no data expected from card.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 9          | RW          | 0x0                | <p>data_expected<br/>           1'b0: No data transfer expected (read/write)<br/>           1'b1: Data transfer expected (read/write)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | check_response_crc<br>1'b0: Do not check response CRC<br>1'b1: Check response CRC<br>Some of command responses do not return valid CRC bits.<br>Software should disable CRC checks for those commands in order to disable CRC checking by controller. |
| 7          | RW          | 0x0                | response_length<br>1'b0: Short response expected from card<br>1'b1: Long response expected from card                                                                                                                                                  |
| 6          | RW          | 0x0                | response_expect<br>1'b0: No response expected from card<br>1'b1: Response expected from card                                                                                                                                                          |
| 5:0        | RW          | 0x00               | cmd_index<br>Command index                                                                                                                                                                                                                            |

**SDMMC RESP0**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RO          | 0x00000000         | response0<br>Bit[31:0] of response |

**SDMMC RESP1**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | response1<br>Register represents bit[63:32] of long response.<br>When CIU sends auto-stop command, then response is saved in register. Response for previous command sent by host is still preserved in response 0 register. Additional auto-stop issued only for data transfer commands, and response type is always "short" for them. |

**SDMMC RESP2**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:0       | RO          | 0x00000000         | response2<br>Bit[95:64] of long response |

**SDMMC RESP3**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:0       | RO          | 0x00000000         | response3<br>Bit[127:96] of long response |

**SDMMC MINTSTS**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                 |
| 24         | RO          | 0x0                | sdio_interrupt<br>SDIO interrupt status when sdio_int_mask is set                        |
| 23:17      | RO          | 0x00               | reserved                                                                                 |
| 16         | RW          | 0x0                | data_nobusy_int_status<br>Data no busy interrupt status when data_nobusy_int_mask is set |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RO          | 0x0000             | <p>int_status</p> <p>Interrupt enabled only if corresponding bit in interrupt mask register is set.</p> <p>bit 15: End-bit error (read)/Write no CRC (EBE)</p> <p>bit 14: Auto command done (ACD)</p> <p>bit 13: Start-bit error (SBE)</p> <p>bit 12: Hardware locked write error (HLE)</p> <p>bit 11: FIFO underrun/overrun error (FRUN)</p> <p>bit 10: Data starvation-by-host timeout (HTO) /Volt_switch_int</p> <p>bit 9: Data read timeout (DRTO)</p> <p>bit 8: Response timeout (RTO)</p> <p>bit 7: Data CRC error (DCRC)</p> <p>bit 6: Response CRC error (RCRC)</p> <p>bit 5: Receive FIFO data request (RXDR)</p> <p>bit 4: Transmit FIFO data request (TXDR)</p> <p>bit 3: Data transfer over (DTO)</p> <p>bit 2: Command done (CD)</p> <p>bit 1: Response error (RE)</p> <p>bit 0: Card detect (CD)</p> |

**SDMMC\_RINTSTS**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 24         | R/W SC      | 0x0                | <p>sdio_interrupt</p> <p>Raw SDIO interrupt status.</p> <p>Write value of 1 clears this bit, and value of 0 leaves bit intact.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 23:17      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 16         | R/W SC      | 0x0                | <p>data_nobusy_int_status</p> <p>Raw data no busy interrupt status.</p> <p>Write value of 1 clears this bit, and value of 0 leaves bit intact.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:0       | R/W SC      | 0x0000             | <p>int_status</p> <p>Raw interrupt status.</p> <p>Writes to bits clear status bit. Write value of 1 clears status bit, and value of 0 leaves bit intact.</p> <p>bit 15: End-bit error (read)/Write no CRC (EBE)</p> <p>bit 14: Auto command done (ACD)</p> <p>bit 13: Start-bit error (SBE)</p> <p>bit 12: Hardware locked write error (HLE)</p> <p>bit 11: FIFO underrun/overrun error (FRUN)</p> <p>bit 10: Data starvation-by-host timeout (HTO) /Volt_switch_int</p> <p>bit 9: Data read timeout (DRTO)</p> <p>bit 8: Response timeout (RTO)</p> <p>bit 7: Data CRC error (DCRC)</p> <p>bit 6: Response CRC error (RCRC)</p> <p>bit 5: Receive FIFO data request (RXDR)</p> <p>bit 4: Transmit FIFO data request (TXDR)</p> <p>bit 3: Data transfer over (DTO)</p> <p>bit 2: Command done (CD)</p> <p>bit 1: Response error (RE)</p> <p>bit 0: Card detect (CD)</p> |

**SDMMC\_STATUS**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | dma_req<br>DMA request signal state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 30         | RO          | 0x0                | dma_ack<br>DMA acknowledge signal state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 29:17      | RO          | 0x0000             | fifo_count<br>Number of filled locations in FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16:11      | RO          | 0x00               | response_index<br>Index of previous response, including any auto-stop sent by core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 10         | RO          | 0x0                | data_state_mc_busy<br>Data transmit or receive state-machine is busy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 9          | RO          | 0x0                | data_busy<br>Inverted version of raw selected card_data[0].<br>1'b0: Card data not busy<br>1'b1: Card data busy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8          | RO          | 0x1                | data_3_status<br>Raw selected card_data[3]; checks whether card is present.<br>1'b0: Card not present<br>1'b1: Card present                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7:4        | RO          | 0x0                | command_fsm_states<br>Command FSM states:<br>4'h0: Idle<br>4'h1: Send init sequence<br>4'h2: Tx cmd start bit<br>4'h3: Tx cmd tx bit<br>4'h4: Tx cmd index + arg<br>4'h5: Tx cmd crc7<br>4'h6: Tx cmd end bit<br>4'h7: Tx resp start bit<br>4'h8: Rx resp IRQ response<br>4'h9: Rx resp tx bit<br>4'ha: Rx resp cmd idx<br>4'hb: Rx resp data<br>4'hc: Rx resp crc7<br>4'hd: Rx resp end bit<br>4'he: Cmd path wait NCC<br>4'hf: Wait; CMD-to-response turnaround<br>The command FSM state is represented using 19 bits.<br>The SDMMC_STATUS register[7:4] has 4 bits to represent the command FSM states. Using these 4 bits, only 16 states can be represented. Thus three states cannot be represented in the SDMMC_STATUS[7:4] register. The three states that are not represented in the SDMMC_STATUS register[7:4] are:<br>Bit 16: Wait for CCS<br>Bit 17: Send CCSD<br>Bit 18: Boot Mode<br>Due to this, while command FSM is in "Wait for CCS state" or "Send CCSD" or "Boot Mode", the SDMMC_STATUS register indicates status as 0 for the bit field [7:4]. |
| 3          | RO          | 0x0                | fifo_full<br>FIFO is full status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2          | RO          | 0x1                | fifo_empty<br>FIFO is empty status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1          | RO          | 0x1                | fifo_tx_watermark<br>FIFO reached Transmit watermark level; not qualified with data transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | fifo_rx_watermark<br>FIFO reached Receive watermark level; not qualified with data transfer. |

**SDMMC FIFO TH**

Address: Operational Base + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 30:28      | RW          | 0x0                | dma_multiple_transaction_size<br>Burst size of multiple transaction; should be programmed same as DMA controller multiple-transaction-size SRC/DEST_MSIZE.<br>3'b000: 1 transfers<br>3'b001: 4 transfers<br>3'b010: 8 transfers<br>3'b011: 16 transfers<br>3'b100: 32 transfers<br>3'b101: 64 transfers<br>3'b110: 128 transfers<br>3'b111: 256 transfers<br>The unit for transfer is 32bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 27:16      | RW          | 0x0ff              | rx_wmark<br>FIFO threshold watermark level when receiving data to card. When FIFO data count reaches greater than this number, DMA/FIFO request is raised. During end of packet, request is generated regardless of threshold programming in order to complete any remaining data.<br>In non-DMA mode, when receiver FIFO threshold (RXDR) interrupt is enabled, then interrupt is generated instead of DMA request. During end of packet, interrupt is not generated if threshold programming is larger than any remaining data. It is responsibility of host to read remaining bytes on seeing Data Transfer Done interrupt.<br>In DMA mode, at end of packet, even if remaining bytes are less than threshold, DMA request does single transfers to flush out any remaining bytes before Data Transfer Done interrupt is set. 12 bits-1 bit less than FIFO-count of status register, which is 13 bits.<br>Limitation: rx_wmark <= FIFO_DEPTH-2<br>Recommended: (FIFO_DEPTH/2) - 1; (means greater than (FIFO_DEPTH/2) - 1)<br>NOTE: In DMA mode during CCS time-out, the DMA does not generate the request at the end of packet, even if remaining bytes are less than threshold. In this case, there will be some data left in the FIFO. It is the responsibility of the application to reset the FIFO after the CCS timeout. |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0       | RW          | 0x000              | <p>tx_wmark<br/>FIFO threshold watermark level when transmitting data to card. When FIFO data count is less than or equal to this number, DMA/FIFO request is raised. If Interrupt is enabled, then interrupt occurs. During end of packet, request or interrupt is generated, regardless of threshold programming.</p> <p>In non-DMA mode, when transmit FIFO threshold (TXDR) interrupt is enabled, then interrupt is generated instead of DMA request. During end of packet, on last interrupt, host is responsible for filling FIFO with only required remaining bytes (not before FIFO is full or after CIU completes data transfers, because FIFO may not be empty).</p> <p>In DMA mode, at end of packet, if last transfer is less than burst size, DMA controller does single cycles until required bytes are transferred.</p> <p>12 bits -1 bit less than FIFO-count of status register, which is 13 bits.</p> <p>Limitation: tx_wmark &gt;= 1;<br/>Recommended: FIFO_DEPTH/2; (means less than or equal to FIFO_DEPTH/2)</p> |

**SDMMC\_CDETECT**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                               |
| 0          | RO          | 0x1                | <p>card_detect_n<br/>Value on card_detect_n input port.<br/>1'b0: Represents presence of card<br/>1'b1: Represents absence of card</p> |

**SDMMC\_WRTPRT**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                    |
| 0          | RW          | 0x0                | <p>write_protect<br/>Value on card_write_prt input port. 1 represents write protection.</p> |

**SDMMC\_TCBCNT**

Address: Operational Base + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>trans_card_byte_count<br/>Number of bytes transferred by CIU unit to card</p> |

**SDMMC\_TBBCNT**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>trans_fifo_byte_count<br/>Number of bytes transferred between host/DMA memory and BIU FIFO</p> |

**SDMMC\_DEBNCE**

Address: Operational Base + offset (0x0064)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 23:0       | RW          | 0xffffffff         | debounce_count<br>Number of host clock used by debounce filter logic; typical debounce time is 5-25 ms. |

**SDMMC USRID**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:0       | RW          | 0x00000000         | usrid<br>User identification register |

**SDMMC VERID**

Address: Operational Base + offset (0x006C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:0       | RO          | 0x5342270a         | verid<br>Version identification register |

**SDMMC HCON**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                                                                       |
| 26         | RO          | 0x1                | area_optimized<br>1'b0: No area optimization<br>1'b1: Area optimization                        |
| 25:24      | RO          | 0x0                | num_clk_div<br>divider number-1.                                                               |
| 23         | RO          | 0x1                | set_clk_false_path<br>1'b0: No false path<br>1'b1: False path set                              |
| 22         | RO          | 0x1                | impl_hold_reg<br>1'b0: No hold register<br>1'b1: Hold register                                 |
| 21         | RO          | 0x0                | fifo_ram_inside<br>1'b0: Outside<br>1'b1: Inside                                               |
| 20:18      | RO          | 0x1                | ge_dma_data_width<br>3'b000: 16 bits<br>3'b001: 32 bits<br>3'b010: 64 bits<br>Others: Reserved |
| 17:16      | RO          | 0x0                | dma_interface<br>2'b00: None<br>2'b01: INT_DMA<br>2'b10: GENERIC_DMA<br>2'b11: NON_INT_DMA     |
| 15:10      | RO          | 0x0d               | h_addr_width<br>6'h8: 9 bits<br>6'h9: 10 bits<br>.....<br>6'h1f: 32 bits<br>Others: Reserved   |
| 9:7        | RO          | 0x1                | h_data_width<br>3'b000: 16 bits<br>3'b001: 32 bits<br>3'b010: 64 bits<br>Others: Reserved      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 6          | RO          | 0x1                | h_bus_type<br>1'b0: APB<br>1'b1: AHB                      |
| 5:1        | RO          | 0x00               | card_num<br>Card number -1.                               |
| 0          | RO          | 0x1                | card_type<br>Card type.<br>1'b0: MMC_ONLY<br>1'b1: SD_MMC |

**SDMMC\_UHSREG**

Address: Operational Base + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                                  |
| 16         | RW          | 0x0                | ddr_reg<br>DDR mode. These bits indicate DDR mode of operation to the core for the data transfer.<br>1'b0: Non-DDR mode<br>1'b1: DDR mode |
| 15:0       | RO          | 0x0000             | reserved                                                                                                                                  |

**SDMMC\_RSTN**

Address: Operational Base + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                           |
| 0          | RW          | 0x1                | card_reset<br>Hardware reset.<br>1'b0: Active mode<br>1'b1: Reset<br>These bits cause the cards to enter pre-idle state, which requires them to be re-initialized. |

**SDMMC\_BMOD**

Address: Operational Base + offset (0x0080)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RO          | 0x0                | <p>pbl<br/>Programmable burst length. These bits indicate the maximum number of beats to be performed in one IDMAC transaction. The IDMAC will always attempt to burst as specified in PBL each time it starts a Burst transfer on the host bus. The permissible values are 1, 4, 8, 16, 32, 64, 128 and 256. This value is the mirror of MSIZE of SDMMC_FIFOTH register. In order to change this value, write the required value to SDMMC_FIFOTH register. This is an encode value as follows.</p> <p>3'b000: 1 transfers<br/>3'b001: 4 transfers<br/>3'b010: 8 transfers<br/>3'b011: 16 transfers<br/>3'b100: 32 transfers<br/>3'b101: 64 transfers<br/>3'b110: 128 transfers<br/>3'b111: 256 transfers<br/>Transfer unit is 32 bits.<br/>PBL is a read-only value and is applicable only for data access; it does not apply to descriptor accesses.</p> |
| 7          | RW          | 0x0                | <p>de<br/>IDMAC enable.<br/>When set, the IDMAC is enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6:2        | RW          | 0x00               | <p>dsl<br/>Descriptor skip length.<br/>Specifies the number of word to skip between two unchained descriptors. This is applicable only for dual buffer structure.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1          | RW          | 0x0                | <p>fb<br/>Fixed burst.<br/>Controls whether the AHB Master interface performs fixed burst transfers or not. When set, the AHB will use only SINGLE, INCR4, INCR8 or INCR16 during start of normal burst transfers. When reset, the AHB will use SINGLE and INCR burst transfer operations.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0          | RW          | 0x0                | <p>swr<br/>Software reset.<br/>When set, the DMA Controller resets all its internal registers.<br/>It is automatically cleared after 1 clock cycle.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**SDMMC PLDMND**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | <p>pd<br/>Poll demand. If the OWN bit of a descriptor is not set, the FSM goes to the suspend state. The host needs to write any value into this register for the IDMAC FSM to resume normal descriptor fetch operation.</p> |

**SDMMC DBADDR**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>sbl<br/>Start of descriptor list. Contains the base address of the first descriptor.<br/>The LSB bits[1:0] are ignored and taken as all-zero by the IDMAC internally. Hence these LSB bits are read-only.</p> |

**SDMMC\_IDSTS**

Address: Operational Base + offset (0x008C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16:13      | RO          | 0x0                | fsm<br>DMAC FSM present state.<br>4'h0: DMA_IDLE<br>4'h1: DMA_SUSPEND<br>4'h2: DESC_RD<br>4'h3: DESC_CHK<br>4'h4: DMA_RD_REQ_WAI<br>4'h5: DMA_WR_REQ_WAI<br>4'h6: DMA_RD<br>4'h7: DMA_WR<br>4'h8: DESC_CLOSE<br>Others: Reserved                                                                                                                                                                                                                                                                                                                                                                                       |
| 12:10      | RO          | 0x0                | eb<br>Error bits. Indicates the type of error that caused a bus error.<br>Valid only with fatal bus.<br>3'h1: Host abort received during transmission<br>3'h2: Host abort received during reception<br>Others: Reserved                                                                                                                                                                                                                                                                                                                                                                                                |
| 9          | RW          | 0x0                | ais<br>Abnormal interrupt summary. Logical OR of the following:<br>SDMMC_IDSTS[2] fatal bus interrupt<br>SDMMC_IDSTS[4] du bit interrupt<br>Only unmasked bits affect this bit.<br>This is a sticky bit and must be cleared each time a corresponding bit that causes ais to be set is cleared.<br>Writing a 1 clears this bit.                                                                                                                                                                                                                                                                                        |
| 8          | RW          | 0x0                | nis<br>Normal interrupt summary. Logical OR of the following:<br>SDMMC_IDSTS[0] transmit interrupt<br>SDMMC_IDSTS[1] receive interrupt<br>Only unmasked bits affect this bit.<br>This is a sticky bit and must be cleared each time a corresponding bit that causes nis to be set is cleared.<br>Writing a 1 clears this bit.                                                                                                                                                                                                                                                                                          |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5          | RW          | 0x0                | ces<br>Card error summary. Indicates the status of the transaction to/from the card; also present in SDMMC_RINTSTS. Indicates the logical OR of the following bits:<br>EBE: End Bit Error<br>RTO: Response Timeout/Boot Ack Timeout<br>RCRC: Response CRC<br>SBE: Start Bit Error<br>DRTO: Data Read Timeout/BDS timeout<br>DCRC: Data CRC for Receive<br>RE: Response Error<br>Writing a 1 clears this bit.<br>The abort condition of the IDMAC depends on the setting of this CES bit. If the CES bit is enabled, then the IDMAC aborts on a "response error"; however, it will not abort if the CES bit is cleared. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | dui<br>Descriptor unavailable interrupt. This bit is set when the descriptor is unavailable due to OWN bit = 0 (DESO[31] =0). Writing a 1 clears this bit.                            |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                              |
| 2          | RW          | 0x0                | fbe<br>Fatal bus error interrupt. Indicates that a bus error occurred (SDMMC_IDSTS[12:10]). When this bit is set, the DMA disables all its bus accesses. Writing a 1 clears this bit. |
| 1          | RW          | 0x0                | ri<br>Receive interrupt.<br>Indicates the completion of data reception for a descriptor. Writing a 1 clears this bit.                                                                 |
| 0          | RW          | 0x0                | ti<br>Transmit interrupt.<br>Indicates that data transmission is finished for a descriptor. Writing 1 clears this bit.                                                                |

**SDMMC\_IDINTEN**

Address: Operational Base + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                                                            |
| 9          | RW          | 0x0                | ai<br>Abnormal interrupt summary enable.<br>When set, an abnormal interrupt is enabled.<br>This bit enables the following bits:<br>SDMMC_IDINTEN[2] fatal bus error interrupt<br>SDMMC_IDINTEN[4] du interrupt                                      |
| 8          | RW          | 0x0                | ni<br>Normal interrupt summary enable.<br>When set, a normal interrupt is enabled. When reset, a normal interrupt is disabled.<br>This bit enables the following bits:<br>SDMMC_IDINTEN[0] transmit interrupt<br>SDMMC_IDINTEN[1] receive interrupt |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                            |
| 5          | RW          | 0x0                | ces<br>Card error summary interrupt enable.<br>When set, it enables the card interrupt summary.                                                                                                                                                     |
| 4          | RW          | 0x0                | du<br>Descriptor unavailable interrupt.<br>When set along with abnormal interrupt summary enable, the du interrupt is enabled.                                                                                                                      |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                            |
| 2          | RW          | 0x0                | fbe<br>Fatal bus error enable.<br>When set with abnormal interrupt summary enable, the fatal bus error interrupt is enabled.<br>When reset, fatal bus error enable interrupt is disabled.                                                           |
| 1          | RW          | 0x0                | ri<br>Receive interrupt enable.<br>When set with normal interrupt summary enable, receive interrupt is enabled.<br>When reset, receive interrupt is disabled.                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>ti<br/>Transmit interrupt enable.<br/>When set with normal interrupt summary enable, transmit interrupt is enabled.<br/>When reset, transmit interrupt is disabled.</p> |

**SDMMC\_DSCADDR**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>hda<br/>Host descriptor address pointer.<br/>This register points to the start address of the current descriptor read by the IDMAC. Cleared on reset. Pointer updated by IDMAC during operation.</p> |

**SDMMC\_BUFAADDR**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>hba<br/>Host buffer address pointer.<br/>This register points to the current data buffer address being accessed by the IDMAC. Cleared on Reset. Pointer updated by IDMAC during operation.</p> |

**SDMMC\_CARDTHRCTL**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 27:16      | RW          | 0x000              | card_rd_thres<br>Card read threshold size                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1          | RW          | 0x0                | <p>busy_clr_int_en<br/>Busy clear interrupt.<br/>1'b0: Busy clear interrupt disabled<br/>1'b1: Busy clear interrupt enabled<br/>Note: The application can disable this feature if it does not want to wait for a busy clear interrupt. For example, in a multi-card scenario, the application can switch to the other card without waiting for a busy to be completed. In such cases, the application can use the polling method to determine the status of busy. By default this feature is disabled and backward-compatible to the legacy drivers where polling is used.</p> |
| 0          | RW          | 0x0                | <p>card_rd_thres_en<br/>Card read threshold enable.<br/>1'b0: Card read threshold disabled<br/>1'b1: Card read threshold enabled. The host initiates read transfer only if card_rd_thres amount of space is available in receive FIFO.</p>                                                                                                                                                                                                                                                                                                                                     |

**SDMMC\_BACKEND\_POWER**

Address: Operational Base + offset (0x0104)

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

| Bit | Attr | Reset Value | Description                                                                                                |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------|
| 0   | RW   | 0x0         | back_end_power<br>Back end power.<br>1'b0: Off; Reset<br>1'b1: Back-end power supplied to card application |

**SDMMC\_EMMCDDR\_REG**

Address: Operational Base + offset (0x010C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                     |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                        |
| 0    | RW   | 0x0         | half_start_bit<br>Control for start bit detection mechanism inside Host Controller based on duration of start bit.<br>For eMMC 4.5, start bit can be:<br>1'b0: Full cycle (half_start_bit=0)<br>1'b1: Less than one full cycle (half_start_bit=1)<br>Set half_start_bit=1 for eMMC 4.5 and above; set to 0 for SD applications. |

**SDMMC\_RDYINT\_GEN**

Address: Operational Base + offset (0x0120)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                          |
| 24    | RO   | 0x0         | rdyint_cnt_finish<br>Counter finish indication.<br>When high, it indicates that the rdyint counter is finished.                                                                                                                                                                                   |
| 23:16 | RO   | 0xff        | rdyint_cnt_status<br>Counter status, reflect internal counter value.                                                                                                                                                                                                                              |
| 15:9  | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                          |
| 8     | RW   | 0x0         | rdyint_gen_working<br>Working indication for rdyint generator.<br>When high, Host Controller start to count and generate one rdyint trigger. After the rdyint trigger is generated, this bit will be set to 0 by Host Controller. So software should set it to 1 before detecting next interrupt. |
| 7:0   | RW   | 0x00        | rdyint_gen_maxval<br>Max counter value to detect cdata_in0 high value for generating rdyint, based on internal clock frequency.                                                                                                                                                                   |

**SDMMC\_FIFO\_BASE**

Address: Operational Base + offset (0x0200)

| Bit  | Attr | Reset Value | Description                         |
|------|------|-------------|-------------------------------------|
| 31:0 | RW   | 0x00000000  | fifo_base_addr<br>FIFO base address |

**22.5 Interface Description****22.5.1 SDMMC Interface Description**

Table 22-8 SDMMC Interface Description

| Module Pin   | Dir. | PAD Name                                                                      | IOMUX Setting                         |
|--------------|------|-------------------------------------------------------------------------------|---------------------------------------|
| sdmmc_cclk   | O    | PWM10_M0/LPMCU_JTAG_TCK_M1/I2C0_SCL_M2/UAR_T5_RTSN_M0/SDMMC0_CLK/GPIO3_A4_d   | VIIOC_GPIO3A_IOMUX_SEL_H[3:0] =4'h1   |
| sdmmc_ccmd   | I/O  | PWM11_IR_M0/LPMCU_JTAG_TMS_M1/I2C0_SDA_M2/UART5_CTSN_M0/SDMMC0_CMD/GPIO3_A5_u | VIIOC_GPIO3A_IOMUX_SEL_H[11:8] =4'h1  |
| sdmmc_cdata0 | I/O  | PWM8_M0/TEST_CLK1_OUT/UART2_RX_M0/SDMMC0_D0/GPIO3_A3_u                        | VIIOC_GPIO3A_IOMUX_SEL_L[15:12] =4'h1 |
| sdmmc_cdata1 | I/O  | PWM9_M0/TEST_CLK0_OUT/UART2_TX_M0/SDMMC0_                                     | VIIOC_GPIO3A_IOMUX_SEL_L[11:8]        |

| <b>Module Pin</b> | <b>Dir.</b> | <b>PAD Name</b>                                                   | <b>IOMUX Setting</b>                     |
|-------------------|-------------|-------------------------------------------------------------------|------------------------------------------|
|                   |             | D1/GPIO3_A2_u                                                     | =4'h1                                    |
| sdmmc_cdata2      | I/O         | HPMCU_JTAG_TCK_M1/A7_JTAG_TCK_M0/UART5_RX_M0/SDMMC0_D2/GPIO3_A7_u | VIIOC_GPIO3A_IOMUX_SEL_H[15:12]<br>=4'h1 |
| sdmmc_cdata3      | I/O         | HPMCU_JTAG_TMS_M1/A7_JTAG_TMS_M0/UART5_TX_M0/SDMMC0_D3/GPIO3_A6_u | VIIOC_GPIO3A_IOMUX_SEL_H[11:8]<br>=4'h1  |
| sdmmc_cdetn       | I           | SDMMC0_DET/GPIO3_A1_u                                             | VIIOC_GPIO3A_IOMUX_SEL_L[7:4]<br>=4'h1   |

Notes: I=input, O=output, I/O=input/output, bidirectional

## 22.5.2 SDIO Interface Description

Table 22-9 SDIO M0 Interface Description

| <b>Module Pin</b> | <b>Dir.</b> | <b>PAD Name</b>                                                    | <b>IOMUX Setting</b>                     |
|-------------------|-------------|--------------------------------------------------------------------|------------------------------------------|
| sdio_cclk         | O           | LCD_D10/I2S0_MCLK/SDMMC1_CLK_M0/GPIO2_A2_d                         | VOIOC_GPIO2A_IOMUX_SEL_L[11:8]<br>=4'h1  |
| sdio_ccmd         | I/O         | LCD_D11/I2S0_SDO3_SD1I/SDMMC1_CMD_M0/GPIO2_A3_d                    | VOIOC_GPIO2A_IOMUX_SEL_L[15:12]<br>=4'h1 |
| sdio_cdata0       | I/O         | I2C4_SCL_M0/UART1_RTSN_M1/LCD_D9/I2S0_LRCK/SDMMC1_D0_M0/GPIO2_A1_d | VOIOC_GPIO2A_IOMUX_SEL_L[7:4]<br>=4'h1   |
| sdio_cdata1       | I/O         | I2C4_SDA_M0/UART1_CTSN_M1/LCD_D8/I2S0_SCLK/SDMMC1_D1_M0/GPIO2_A0_d | VOIOC_GPIO2A_IOMUX_SEL_L[3:0]<br>=4'h1   |
| sdio_cdata2       | I/O         | UART1_RX_M1/LCD_D13/I2S0_SDIO/SDMMC1_D2_M0/GPIO2_A5_d              | VOIOC_GPIO2A_IOMUX_SEL_H[7:4]<br>=4'h1   |
| sdio_cdata3       | I/O         | UART1_TX_M1/LCD_D12/I2S0_SD00/SDMMC1_D3_M0/GPIO2_A4_d              | VOIOC_GPIO2A_IOMUX_SEL_H[3:0]<br>=4'h1   |

Notes: I=input, O=output, I/O=input/output, bidirectional

Table 22-10 SDIO M1 Interface Description

| <b>Module Pin</b> | <b>Dir.</b> | <b>PAD Name</b>                                                              | <b>IOMUX Setting</b>                       |
|-------------------|-------------|------------------------------------------------------------------------------|--------------------------------------------|
| sdio_cclk         | O           | SPI0_MOSI_M0/SDMMC1_CLK_M1/I2C4_SCL_M1/PWM5_M2/VICAP_D4_M1/LCD_D5/GPIO1_C2_d | VENCIOC_GPIO1C_IOMUX_SEL_L[11:8]<br>=4'h5  |
| sdio_ccmd         | I/O         | SPI0_MISO_M0/SDMMC1_CMD_M1/I2C4_SDA_M1/PWM6_M2/VICAP_D5_M1/LCD_D4/GPIO1_C3_d | VENCIOC_GPIO1C_IOMUX_SEL_L[15:12]<br>=4'h5 |
| sdio_cdata0       | I/O         | SDMMC1_D0_M1/SPI0_CLK_M0/PWM4_M2/VICAP_D3_M1/LCD_D6/GPIO1_C1_d               | VENCIOC_GPIO1C_IOMUX_SEL_L[7:4]<br>=4'h5   |
| sdio_cdata1       | I/O         | SDMMC1_D1_M1/SPI0_CS0n_M0/PWM2_M2/VICAP_D2_M1/LCD_D7/GPIO1_C0_d              | VENCIOC_GPIO1C_IOMUX_SEL_L[3:0]<br>=4'h5   |
| sdio_cdata2       | I/O         | SDMMC1_D2_M1/UART4_TX_M1/PWM9_M1/VICAP_D7_M1/LCD_D2/GPIO1_C5_d               | VENCIOC_GPIO1C_IOMUX_SEL_H[7:4]<br>=4'h5   |
| sdio_cdata3       | I/O         | SDMMC1_D3_M1/UART4_RX_M1/PWM8_M1/VICAP_D6_M1/LCD_D3/GPIO1_C4_d               | VENCIOC_GPIO1C_IOMUX_SEL_H[3:0]<br>=4'h5   |

Notes: I=input, O=output, I/O=input/output, bidirectional

## 22.5.3 EMMC Interface Description

Table 22-11 EMMC Interface Description

| <b>Module Pin</b> | <b>Dir.</b> | <b>PAD Name</b>                                                       | <b>IOMUX Setting</b>                       |
|-------------------|-------------|-----------------------------------------------------------------------|--------------------------------------------|
| emmc_cclk         | O           | FSPI_CLK/EMMC_CLK/GPIO4_B1_d                                          | PERIIOC_GPIO4B_IOMUX_SEL_L[7:4]<br>=4'h1   |
| emmc_ccmd         | I/O         | FSPI_CS0n/EMMC_CMD/GPIO4_B0_u                                         | PERIIOC_GPIO4B_IOMUX_SEL_L[3:0]<br>=4'h1   |
| emmc_cdata0       | I/O         | FSPI_D0/EMMC_D0/GPIO4_A4_u                                            | PERIIOC_GPIO4A_IOMUX_SEL_H[3:0]<br>=4'h1   |
| emmc_cdata1       | I/O         | FSPI_D1/EMMC_D1/GPIO4_A3_u                                            | PERIIOC_GPIO4A_IOMUX_SEL_L[15:12]<br>=4'h1 |
| emmc_cdata2       | I/O         | FSPI_D2/EMMC_D2/GPIO4_A2_u                                            | PERIIOC_GPIO4A_IOMUX_SEL_L[11:8]<br>=4'h1  |
| emmc_cdata3       | I/O         | FSPI_D3/EMMC_D3/GPIO4_A6_u                                            | PERIIOC_GPIO4A_IOMUX_SEL_H[11:8]<br>=4'h1  |
| emmc_cdata4       | I/O         | I2C2_SDA_M1/UART1_RX_M2/SPI1_CS0n_M0/EMMC_D4/GPIO4_A5_u               | PERIIOC_GPIO4A_IOMUX_SEL_H[7:4]<br>=4'h1   |
| emmc_cdata5       | I/O         | I2C2_SCL_M1/UART1_RX_M2/SPI1_CLK_M0/EMMC_D5/GPIO4_A7_u                | PERIIOC_GPIO4A_IOMUX_SEL_H[15:12]<br>=4'h1 |
| emmc_cdata6       | I/O         | TEST_CLK3_OUT/I2C0_SCL_M1/UART0_TX_M2/SPI1_MOSI_M0/EMMC_D6/GPIO4_A1_u | PERIIOC_GPIO4A_IOMUX_SEL_L[7:4]<br>=4'h1   |
| emmc_cdata7       | I/O         | TEST_CLK2_OUT/I2C0_SDA_M1/UART0_RX_M2/SPI1_MISO_M0/EMMC_D7/GPIO4_A0_u | PERIIOC_GPIO4A_IOMUX_SEL_L[3:0]<br>=4'h1   |

Notes: I=input, O=output, I/O=input/output, bidirectional

## 22.6 Application Notes

### 22.6.1 Software/Hardware Restriction

Before issuing a new data transfer command, the software should ensure that the card is not busy due to any previous data transfer command. Before changing the card clock frequency, the software must ensure that there are no data or command transfers in progress.

To avoid glitches in the card clock outputs, the software should use the following steps when changing the card clock frequency:

- 1) Before disable the clocks, ensure that the card is not busy due to any previous data command. To determine this, check for 0 in bit9 of SDMMC\_STATUS register.
- 2) Update the Clock Enable register to disable clock. To ensure completion of any previous command before this update, send a command to the CIU to update the clock registers by setting:
  - start\_cmd bit
  - “update clock registers only” bits
  - “wait\_previous data complete” bit
 Wait for the CIU to take the command by polling for 0 on the start\_cmd bit.
- 3) Set the start\_cmd bit to update the Clock Divider and/or Clock Source register, and send a command to the CIU in order to update the clock registers; wait for the CIU to take the command.
- 4) Set start\_cmd to update the Clock Enable register in order to enable the required clocks and send a command to the CIU to update the clock registers; wait for the CIU to take the command.

In non-DMA mode, while reading from a card, the Data Transfer Over (SDMMC\_RINTSTS[3]) interrupt occurs as soon as the data transfer from the card is over. There still could be some data left in the FIFO, and the RX\_WMark interrupt may or may not occur, depending on the remaining bytes in the FIFO. Software should read any remaining bytes upon seeing the Data Transfer Over (DTO) interrupt. While using the external DMA interface for reading from a card, the DTO interrupt occurs only after all the data is flushed to memory by the DMA interface unit.

While writing to a card in external DMA mode, if an undefined-length transfer is selected by setting the Byte Count Register to 0, the DMA logic will likely request more data than it will send to the card, since it has no way of knowing at which point the software will stop the transfer. The DMA request stops as soon as the DTO is set by the CIU.

If the software issues a controller\_reset command by setting control register bit[0] to 1, all the CIU state machines are reset; the FIFO is not cleared. The DMA sends all remaining bytes to the host. In addition to a card-reset, if a FIFO reset is also issued, then:

- Any pending DMA transfer on the bus completes correctly
- DMA data read is ignored
- Write data is unknown(x)

Additionally, if dma\_reset is also issued, any pending DMA transfer is abruptly terminated. When the DMA is used, the DMA controller channel should also be reset and reprogrammed.

If any of the previous data commands do not properly terminate, then the software should issue the FIFO reset in order to remove any residual data, if any, in the FIFO. After asserting the FIFO reset, you should wait until this bit is cleared.

One data-transfer requirement between the FIFO and host is that the number of transfers should be a multiple of the FIFO data width (32bits). For example, you want to write only 15 bytes to an SD/MMC card (SDMMC\_BYTCNT), the host should write 16 bytes to the FIFO or program the DMA to do 16-byte transfers. The software can still program the Byte Count register to only 15, at which point only 15 bytes will be transferred to the card. Similarly, when 15 bytes are read from a card, the host should still read all 16 bytes from the FIFO. It is recommended that you not change the FIFO threshold register in the middle of data transfers.

## 22.6.2 Programming Sequence

### 22.6.2.1 Initialization

Following figure illustrates the initialization flow.



Fig. 22-10 Host Controller Initialization Sequence

Once the power and clocks are stable, `reset_n` should be asserted(active-low) for at least two cycles of `clk` or `cclk_in`, whichever is slower. The reset initializes the registers, ports, FIFO-pointers, DMA interface controls, and state-machines in the design. After power-on reset, the software should do the following:

- 1) Configure control register – For MMC mode, enable the open-drain pullup by setting `enable_OD_pullup`(bit24) in the `SDMMC_CTRL` register.
- 2) Enable power to cards – Before enabling the power, confirm that the voltage setting to the voltage regulators is correct. Enable power to the connected cards by setting the corresponding bit to 1 in the Power Enable register. Wait for the power ramp-up time.
- 3) Set masks for interrupts by clearing appropriate bits in the Interrupt Mask register. Set the global `int_enable` bit of the `SDMMC_CTRL` register. It is recommended that you write `0xffff_ffff` to the Raw Interrupt register in order to clear any pending interrupts before setting the `int_enable` bit.
- 4) Enumerate card stack – Each card is enumerated according to card type; for details, refer to “Enumerated Card Stack”. For enumeration, you should restrict the clock frequency to 400KHz.
- 5) Changing clock source assignment – set the card frequency using the clock-divider and clock-source registers; for details, refer to “Clock Programming”. MMC cards operate at a maximum of 20MHz (at maximum of 52MHz in high-speed mode). SD mode operates at a maximum of 25MHz (at maximum of 50MHz in high-speed mode).
- 6) Set other parameters, which normally do not need to be changed with every command, with a typical value such as timeout values in `cclk_out` according to SD/MMC specifications.
  - `ResponseTimeOut` = `0x64`
  - `DataTimeOut` = highest of one of the following:  
 ●  $(10 * ((TAAC * Fop) + (100 * NSAC)))$
  - Host FIFO read/write latency from FIFO empty/full
  - Set the debounce value to 25ms(default:`0xffff`) in host clock cycle units in the `SDMMC_DEBNCE` register.

FIFO threshold value in bytes in the `SDMMC_FIFOTH` register.

### 22.6.2.2 Enumerated Card Stack

The card stack does the following:

- Enumerates all connected cards
- Sets the RCA for the connected cards
- Reads card-specific information
- Stores card-specific information locally

Enumeration depends on the operating mode of the SD/MMC card; the card type is first identified and the appropriate card enumeration routine is called.

- 1) Check if the card is connected.
- 2) Clear the card type register to set the card width as a single bit. For the given card

- number, clear the corresponding bits in the card\_type register. Clear the register bit for a 1-bit, 4-bit bus width. For example, for card number=1, clear bit 0 and bit 16 of the card\_type register.
- 3) Set clock frequency to FOD=400KHz, maximum – Program clock divider0 (bits 0-7 in the SDMMC\_CLKDIV register) value to one-half of the cclk\_in frequency divided by 400KHz. For example, if cclk\_in is 20MHz, then the value is  $20,000/(2*400)=25$ .
  - 4) Identify the card type; that is, SD, MMC, or SDIO.
    - a. Send CMD5 first. If a response is received, then the card is SDIO
    - b. If not, send CMD8 with the following Argument
      - Bit[31:12] = 20'h0 //reserved bits
      - Bit[11:8] = 4'b0001 //VHS value
      - Bit[7:0] = 8'b10101010 //Preferred Check Pattern by SD2.0
    - c. If Response is received the card supports High Capacity SD2.0 then send ACMD41 with the following Argument
      - Bit[31] = 1'b0; //Reserved bits
      - Bit[30] = 1'b1; //High Capacity Status
      - Bit[29:24] = 6'h0; //Reserved bits
      - Bit[23:0] = Supported Voltage Range
    - d. If Response is received for ACMD41 then the card is SD. Otherwise the card is MMC.
    - e. If response is not received for initial CMD8 then card does not support High Capacity SD2.0, then issue CMD0 followed by ACMD41 with the following Argument
      - Bit[31] = 1'b0; //Reserved bits
      - Bit[30] = 1'b0; //High Capacity Status
      - Bit[29:24] = 6'h0; //Reserved bits
      - Bit[23:0] = Supported Voltage Range
  - 5) Enumerate the card according to the card type.
  - 6) Use a clock source with a frequency = Fod (that is, 400KHz) and use the following enumeration command sequence:
    - SD card – Send CMD0, CMD8, ACMD41, CMD2, CMD3.
    - MMC – Send CMD0, CMD1, CMD2, CMD3.

### **22.6.2.3 Clock Programming**

The Host Controller supports one clock source. The clock to an individual card can be enabled or disabled. Registers that support this are:

- SDMMC\_CLKDIV – Programs individual clock source frequency. SDMMC\_CLKDIV limited to 0 or 1 is recommended.
- SDMMC\_CLKSRC – Assign clock source for each card.
- SDMMC\_CLKENA – Enables or disables clock for individual card and enables low-power mode, which automatically stops the clock to a card when the card is idle for more than 8 clocks.

The Host Controller loads each of these registers only when the start\_cmd bit and the update\_clk\_regs\_only bit in the SDMMC\_CMD register are set. When a command is successfully loaded, the Host Controller clears this bit, unless the Host Controller already has another command in the queue, at which point it gives an HLE(Hardware Locked Error). Software should look for the start\_cmd and the update\_clk\_regs\_only bits, and should also set the wait\_prvdata\_complete bit to ensure that clock parameters do not change during data transfer. Note that even though start\_cmd is set for updating clock registers, the Host Controller does not raise a command\_done signal upon command completion.

The following shows how to program these registers:

- 1) Confirm that no card is engaged in any transaction; if there is a transaction, wait until it finishes.
- 2) Stop all clocks by writing 0 to the SDMMC\_CLKENA register. Set the start\_cmd, Update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the SDMMC\_CMD register. Wait until start\_cmd is cleared or an HLE is set; in case of an HLE, repeat the command.
- 3) Program the SDMMC\_CLKDIV and SDMMC\_CLKSRC registers, as required. Set the start\_cmd, Update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the SDMMC\_CMD register. Wait until start\_cmd is cleared or an HLE is set; in case of an HLE, repeat the

command.

Re-enable all clocks by programming the SDMMC\_CLKENA register. Set the start\_cmd, update\_clk\_regs\_only, and wait\_prvdata\_complete bits in the SDMMC\_CMD register. Wait until start\_cmd is cleared or an HLE is set; in case of an HLE, repeat the command.

#### 22.6.2.4 No-Data Command With or Without Response Sequence

To send any non-data command, the software needs to program the SDMMC\_CMD register @0x2C and the SDMMC\_CMDARG register @0x28 with appropriate parameters. Using these two registers, the Host Controller forms the command and sends it to the command bus. The Host Controller reflects the errors in the command response through the error bits of the SDMMC\_RINTSTS register.

When a response is received – either erroneous or valid – the Host Controller sets the command\_done bit in the SDMMC\_RINTSTS register. A short response is copied in Response Register0, while along response is copied to all four response registers @0x30, 0x34, 0x38, and 0x3C. The Response3 register bit 31 represents the MSB, and the Response0 register bit 0 represents the LSB of a long response.

For basic commands or non-data commands, follow these steps:

- 1) Program the Command register @0x28 with the appropriate command argument parameter.
- 2) Program the Command register @0x2C with the settings in following table.

Table 22-12 Command Settings for No-Data Command

| Parameter              | Value         | Description                                                                                                                                                                                                                                           |
|------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Default</b>         |               |                                                                                                                                                                                                                                                       |
| start_cmd              | 1             | -                                                                                                                                                                                                                                                     |
| use_hold_reg           | 1             | Choose value based on speed mode being used; ref to "use_hold_reg" on SDMMC_CMD register                                                                                                                                                              |
| update_clk_regs_only   | 0             | No clock parameters update command                                                                                                                                                                                                                    |
| data_expected          | 0             | No data command                                                                                                                                                                                                                                       |
| card number            | 0             | Actual card number (one controller only connect one card, the num is No. 0)                                                                                                                                                                           |
| cmd_index              | command-index | -                                                                                                                                                                                                                                                     |
| send_initialization    | 0             | Can be 1, but only for card reset commands, such as CMD0                                                                                                                                                                                              |
| stop_abort_cmd         | 0             | Can be 1 for commands to stop data transfer, such as CMD12                                                                                                                                                                                            |
| response_length        | 0             | Can be 1 for R2(long) response                                                                                                                                                                                                                        |
| response_expect        | 1             | Can be 0 for commands with no response; for example, CMD0, CMD4, CMD15, and so on                                                                                                                                                                     |
| <b>User-selectable</b> |               |                                                                                                                                                                                                                                                       |
| wait_prvdata_complete  | 1             | Before sending command on command line, host should wait for completion of any data command in process, if any (recommended to always set this bit, unless the current command is to query status or stop data transfer when transfer is in progress) |
| check_response_crc     | 1             | If host should crosscheck CRC                                                                                                                                                                                                                         |

| Parameter | Value | Description          |
|-----------|-------|----------------------|
|           |       | of response received |

- 3) Wait for command acceptance by host. The following happens when the command is loaded into the Host Controller:
- Host Controller accepts the command for execution and clears the start\_cmd bit in the SDMMC\_CMD register, unless one command is in process, at which point the Host Controller can load and keep the second command in the buffer.
  - If the Host Controller is unable to load the command – that is, a command is already in progress, a second command is in the buffer, and a third command is attempted – then it generates an HLE (hardware-locked error).
- 4) Check if there is an HLE.
- 5) Wait for command execution to complete. After receiving either a response from a card or response timeout, the Host Controller sets the command\_done bit in the SDMMC\_RINTSTS register. Software can either poll for this bit or respond to a generated interrupt.
- 6) Check if response\_timeout error, response\_CRC error, or response error is set. This can be done either by responding to an interrupt raised by these errors or by polling bits 1, 6, and 8 from the SDMMC\_RINTSTS register @0x44. If no response error is received, then the response is valid. If required, the software can copy the response from the response registers @0x30-0x3C.

Software should not modify clock parameters while a command is being executed.

### 22.6.2.5 Data Transfer Commands

Data transfer commands transfer data between the memory card and the Host Controller. To send a data command, the Host Controller needs a command argument, total data size, and block size. Software can receive or send data through the FIFO.

Before a data transfer command, software should confirm that the card is not busy and is in a transfer state, which can be done using the CMD13 and CMD7 commands, respectively. For the data transfer commands, it is important that the same bus width that is programmed in the card should be set in the card type register @0x18.

The Host Controller generates an interrupt for different conditions during data transfer, which are reflected in the SDMMC\_RINTSTS register @0x44 as:

- 1) Data\_Transfer\_Over (bit 3) – When data transfer is over or terminated. If there is a response timeout error, then the Host Controller does not attempt any data transfer and the "Data Transfer Over" bit is never set.
- 2) Transmit\_FIFO\_Data\_request (bit 4) – FIFO threshold for transmitting data was reached; software is expected to write data, if available, in FIFO.
- 3) Receive\_FIFO\_Data\_request (bit 5) – FIFO threshold for receiving data was reached; software is expected to read data from FIFO.
- 4) Data starvation by Host timeout (bit 10) – FIFO is empty during transmission or is full during reception. Unless software writes data for empty condition or reads data for full condition, the Host Controller cannot continue with data transfer. The clock to the card has been stopped.
- 5) Data read timeout error (bit 9) – Card has not sent data within the timeout period.
- 6) Data CRC error (bit 7) – CRC error occurred during data reception.
- 7) Start bit error (bit 13) – Start bit was not received during data reception.
- 8) End bit error (bit 15) – End bit was not received during data reception or for a write operation; a CRC error is indicated by the card.

Conditions 6), 7), and 8) indicate that the received data may have errors. If there was a response timeout, then no data transfer occurred.

### 22.6.2.6 Single-Block or Multiple-Block Read

Steps involved in a single-block or multiple-block read are:

- 1) Write the data size in bytes in the SDMMC\_BYTCNT register @0x20.
- 2) Write the block size in bytes in the SDMMC\_BLKSIZ register @0x1C. The Host Controller expects data from the card in blocks of size SDMMC\_BLKSIZ each.
- 3) Program the SDMMC\_CMDARG register @0x28 with the data address of the beginning of a data read.
- 4) Program the Command register with the parameters listed in following table. For SD

and MMC cards, use CMD17 for a single-block read and CMD18 for a multiple-block read. For SDIO cards, use CMD53 for both single-block and multiple-block transfers.

Table 22-13 Command Setting for Single or Multiple-Block Read

| Parameter              | Value         | Description                                                                                      |
|------------------------|---------------|--------------------------------------------------------------------------------------------------|
| <b>Default</b>         |               |                                                                                                  |
| start_cmd              | 1             | -                                                                                                |
| use_hold_reg           | 1             | Choose value based on speed mode being used; ref to "use_hold_reg" on SDMMC_CMD register         |
| update_clk_regs_only   | 0             | No clock parameters update command                                                               |
| card number            | 0             | Actual card number (one controller only connect one card, the num is No.0)                       |
| send_initialization    | 0             | Can be 1, but only for card reset commands, such as CMD0                                         |
| stop_abort_cmd         | 0             | Can be 1 for commands to stop data transfer, such as CMD12                                       |
| send_auto_stop         | 0/1           | -                                                                                                |
| transfer_mode          | 0             | Block transfer                                                                                   |
| read_write             | 0             | Read from card                                                                                   |
| data_expected          | 1             | Data command                                                                                     |
| response_length        | 0             | Can be 1 for R2(long) response                                                                   |
| response_expect        | 1             | Can be 0 for commands with no response; for example, CMD0, CMD4, CMD15, and so on                |
| <b>User-selectable</b> |               |                                                                                                  |
| cmd_index              | command-index | -                                                                                                |
| wait_prvdata_complete  | 1             | 0: Sends command immediately<br>1: Sends command after previous data transfer ends               |
| check_response_crc     | 1             | 0: Host Controller should not check response CRC<br>1: Host Controller should check response CRC |

After writing to the SDMMC\_CMD register, the Host Controller starts executing the command; when the command is sent to the bus, the command\_done interrupt is generated.

- Software should look for data error interrupts; that is, bits 7, 9, 13, and 15 of the SDMMC\_RINTSTS register. If required, software can terminate the data transfer by sending a STOP command.
- Software should look for Receive\_FIFO\_Data\_request and/or data starvation by host timeout conditions. In both cases, the software should read data from the FIFO and make space in the FIFO for receiving more data.

When a Data\_Transfer\_Over interrupt is received, the software should read the remaining data from the FIFO.

### 22.6.2.7 Single-Block or Multiple-Block Write

Steps involved in a single-block or multiple-block write are:

- 1) Write the data size in bytes in the SDMMC\_BYTCNT register @0x20.
- 2) Write the block size in bytes in the SDMMC\_BLKSIZ register @0x1C; the Host Controller sends data in blocks of size SDMMC\_BLKSIZ each.

- 3) Program SDMMC\_CMDARG register @0x28 with the data address to which data should be written.
- 4) Write data in the FIFO; it is usually best to start filling data the full depth of the FIFO.
- 5) Program the Command register with the parameters listed in following table.

Table 22-14 Command Settings for Single or Multiple-Block Write

| Parameter              | Value         | Description                                                                                      |
|------------------------|---------------|--------------------------------------------------------------------------------------------------|
| <b>Default</b>         |               |                                                                                                  |
| start_cmd              | 1             | -                                                                                                |
| use_hold_reg           | 1             | Choose value based on speed mode being used; ref to "use_hold_reg" on SDMMC_CMD register         |
| update_clk_regs_only   | 0             | No clock parameters update command                                                               |
| card number            | 0             | Actual card number (one controller only connect one card, the num is No. 0)                      |
| send_initialization    | 0             | Can be 1, but only for card reset commands, such as CMD0                                         |
| stop_abort_cmd         | 0             | Can be 1 for commands to stop data transfer, such as CMD12                                       |
| send_auto_stop         | 0/1           | -                                                                                                |
| transfer_mode          | 0             | Block transfer                                                                                   |
| read_write             | 1             | Write to card                                                                                    |
| data_expected          | 1             | Data command                                                                                     |
| response_length        | 0             | Can be 1 for R2(long) response                                                                   |
| response_expect        | 1             | Can be 0 for commands with no response; for example, CMD0, CMD4, CMD15, and so on                |
| <b>User-selectable</b> |               |                                                                                                  |
| cmd_index              | command-index | -                                                                                                |
| wait_prvdata_complete  | 1             | 0: Sends command immediately<br>1: Sends command after previous data transfer ends               |
| check_response_crc     | 1             | 0: Host Controller should not check response CRC<br>1: Host Controller should check response CRC |

After writing to the SDMMC\_CMD register, Host Controller starts executing a command; when the command is sent to the bus, a command\_done interrupt is generated.

- Software should look for data error interrupts; that is, for bits 7, 9, and 15 of the SDMMC\_RINTSTS register. If required, software can terminate the data transfer by sending the STOP command.
- Software should look for Transmit\_FIFO\_Data\_Request and/or timeout conditions from data starvation by the host. In both cases, the software should write data into the FIFO.

When a Data\_Transfer\_Over interrupt is received, the data command is over. For an open-ended block transfer, if the byte count is 0, the software must send the STOP command. If the byte count is not 0, then upon completion of a transfer of a given number of bytes, the Host Controller should send the STOP command, if necessary. Completion of the AUTO-STOP command is reflected by the Auto\_command\_done interrupt – bit 14 of the SDMMC\_RINTSTS register. A response to AUTO\_STOP is stored in SDMMC\_RESP1 @0x34.

### 22.6.2.8 Sending Stop or Abort in Middle of Transfer

The STOP command can terminate a data transfer between a memory card and the Controller, while the ABORT command can terminate an I/O data transfer for only the SDIO\_IOONLY and SDIO\_COMBO cards.

- Send STOP command – Can be sent on the command line while a data transfer is in progress; this command can be sent at any time during a data transfer.

You can also use an additional setting for this command in order to set the Command register bits (5-0) to CMD12 and set bit 14 (stop\_abort\_cmd) to 1. If stop\_abort\_cmd is not set to 1, the Controller does not know that the user stopped a data transfer. Reset bit 13 of the Command register (wait\_prvdata\_complete) to 0 in order to make the Controller send the command at once, even though there is a data transfer in progress.

Send ABORT command – Can be used with only an SDIO\_IOONLY or SDIO\_COMBO card. To abort the function that is transferring data, program the function number in ASx bits (CCCR register of card, address 0x06, bits (0-2) using CMD52.

### 22.6.2.9 Read\_Wait Sequence

Read\_wait is used with only the SDIO card and can temporarily stall the data transfer—either from function or memory—and allow the host to send commands to any function within the SDIO device. The host can stall this transfer for as long as required. The Host Controller provides the facility to signal this stall transfer to the card. The steps for doing this are:

- 1) Check if the card supports the read\_wait facility; read SRW (bit 2) of the CCCR register @0x08. If this bit is 1, then all functions in the card support the read\_wait facility. Use CMD52 to read this bit.
- 2) If the card supports the read\_wait signal, then assert it by setting the read\_wait (bit 6) in the SDMMC\_CTRL register @0x00.

Clear the read\_wait bit in the SDMMC\_CTRL register.

### 22.6.2.10 Controller/DMA/FIFO Reset Usage

- Controller reset – Resets the controller by setting the controller\_reset bit (bit 0) in the SDMMC\_CTRL register; this resets the CIU and state machines, and also resets the BIU-to-CIU interface. Since this reset bit is self-clearing, after issuing the reset, wait until this bit is cleared.
- FIFO reset - Resets the FIFO by setting the fifo\_reset bit (bit 1) in the SDMMC\_CTRL register; this resets the FIFO pointers and counters of the FIFO. Since this reset bit is self-clearing, after issuing the reset, wait until this bit is cleared.

In external DMA transfer mode, even when the FIFO pointers are reset, if there is a DMA transfer in progress, it could push or pop data to or from the FIFO; the DMA itself completes correctly. In order to clear the FIFO, the software should issue an additional FIFO reset and clear any FIFO under-run or overrun errors in the SDMMC\_RAWINTS register caused by the DMA transfers after the FIFO was reset.

### 22.6.2.11 Card Read Threshold

When an application needs to perform a Single or Multiple Block Read command, the application must program the SDMMC\_CARDTHRCTL register with the appropriate Card Read Threshold size (CardRdThreshold) and set the Card Read Threshold Enable (CardRdThrEnable) bit to 1'b1. This additional programming ensures that the Host controller sends a Read Command only if there is space equal to the Card Read Threshold available in the Rx FIFO. This in turn ensures that the card clock is not stopped in the middle of a block of data being transmitted from the card. The Card Read Threshold can be set to the block size of the transfer, which guarantees that there is a minimum of one block size of space in the RxFIFO before the controller enables the card clock. The Card Read Threshold is required when the Round Trip Delay is greater than 0.5cclk\_in period.

### 22.6.2.12 Error Handling

The Host Controller implements error checking; errors are reflected in the SDMMC\_RAWINTS register@0x44 and can be communicated to the software through an interrupt, or the software can poll for these bits. Upon power-on, interrupts are disabled (int\_enable in the SDMMC\_CTRL register is 0), and all the interrupts are masked (bits 0-31 of the SDMMC\_INTMASK register; default is 0).

Error handling:

- Response and data timeout errors – For response timeout, software can retry the command. For data timeout, the Host Controller has not received the data start bit – either for the first block or the intermediate block – within the timeout period, so software can either retry the whole data transfer again or retry from a specified block onwards. By reading the contents of the SDMMC\_TCBCNT later, the software can decide how many bytes remain to be copied.
- Response errors – Set when an error is received during response reception. In this case, the response that copied in the response registers is invalid. Software can retry the command.
- Data errors – Set when error in data reception are observed; for example, data CRC, start bit not found, end bit not found, and so on. These errors could be set for any block-first block, intermediate block, or last block. On receipt of an error, the software can issue a STOP or ABORT command and retry the command for either whole data or partial data.
- Hardware locked error – Set when the Host Controller cannot load a command issued by software. When software sets the start\_cmd bit in the SDMMC\_CMD register, the Host Controller tries to load the command. If the command buffer is already filled with a command, this error is raised. The software then has to reload the command.
- FIFO under-run/overrun error – If the FIFO is full and software tries to write data in the FIFO, then an overrun error is set. Conversely, if the FIFO is empty and the software tries to read data from the FIFO, an under-run error is set. Before reading or writing data in the FIFO, the software should read the fifo\_empty or fifo\_full bits in the Status register.
- Data starvation by host timeout – Raised when the Host Controller is waiting for software intervention to transfer the data to or from the FIFO, but the software does not transfer within the stipulated timeout period. Under this condition and when a read transfer is in process, the software should read data from the FIFO and create space for further data reception. When a transmit operation is in process, the software should fill data in the FIFO in order to start transferring data to the card.
- CRC Error on Command – If a CRC error is detected for a command, the CE-ATA device does not send a response, and a response timeout is expected from the Host Controller. The ATA layer is notified that an MMC transport layer error occurred.

*Notes: During a multiple-block data transfer, if a negative CRC status is received from the device, the data path signals a data CRC error to the BIU by setting the data CRC error bit in the SDMMC\_RINTSTS register. It then continues further data transmission until all the bytes are transmitted.*

### **22.6.2.13 Voltage Switching**

The Host Controller supports SD 3.0 Ultra High Speed (UHS-1) and is capable of voltage switching in SD-mode, which can be applied to SD High-Capacity (SDHC) and SD Extended Capacity (SDXC) cards. UHS-1 supports only 4-bit mode.

However, whether the IO voltage of 1.8v supported or not is depended on the SoC design. SD 3.0 UHS-1 supports the following transfer speed modes for UHS-50 and/or UHS-104 cards:

- DS – default-speed up to 25MHz, 3.3V signaling
- HS – high-speed up to 50MHz, 3.3V signaling
- SDR12 – SDR up to SDR 25MHz, 1.8V signaling
- SDR25 – SDR up to 50MHz, 1.8V signaling
- SDR50 – SDR up to 100MHz, 1.8V signaling
- DDR50 – DDR up to 50MHz, 1.8V signaling

Voltage selection can be done in only SD mode. The first CMD0 selects the bus mode-either SD mode or SPI mode. The card must be in SD mode in order for 1.8V signaling mode to apply, during which time the card cannot be switched to SPI mode or 3.3V signaling without a power cycle.

If the System BIOS in an embedded system already knows that it is connected to an SD 3.0 card, then the driver programs the Controller to initiate ACMD41. The software knows from the response of ACMD41 whether or not the card supports voltage switching to 1.8V.

- If bit 32 of ACMD41 response is 1'b1: card supports voltage switching and next command-CMD11-invokes voltage switching sequence. After CMD11 is started, the software must program the IO voltage selection register based on the soc architecture.

- If bit 32 of ACMD41 response is 1'b0: card does not support voltage switching and CMD11 should not be started.

If the card and host controller accept voltage switching, then they support UHS-1 modes of data transfer. After the voltage switch to 1.8V, SDR12 is the default speed.

Since the UHS-1 can be used in only 4-bit mode, the software must start ACMD6 and change the card data width to 4-bit mode; ACMD6 is driven in any of the UHS-1 speeds. If the host wants to select the DDR mode of data transfer, then the software must program the SDMMC\_DDR\_REG register in the CSR space with the appropriate card number.

To choose from any of the SDR or DDR modes, appropriate values should be programmed in the SDMMC\_CLKDIV register.

### 22.6.2.14 Voltage Switch Operation

The Voltage Switch operation must be performed in SD mode only.



Fig. 22-11 Voltage Switching Command Flow Diagram

The following outlines the steps for the voltage switch programming sequence

- Software Driver starts CMD0, which selects the bus mode as SD.
- After the bus is in SD card mode, CMD8 is started in order to verify if the card is compatible with the SD Memory Card Specification, Version 2.00. CMD8 determines if the card is capable of working within the host supply voltage specified in the VHS (19:16) field of the CMD; the card supports the current host voltage if a response to CMD8 is received.
- ACMD 41 is started. The response to this command informs the software if the card supports voltage switching; bits 38, 36, and 32 are checked by the card argument of ACMD41; refer to following figure.

| 47                                                                        | 46 | 45-40  | 39      | 38     | 37                                                                | 36     | 35-33          | 32      | 31-16     | 15-08                                                                                                  | 07-01  | 00 |
|---------------------------------------------------------------------------|----|--------|---------|--------|-------------------------------------------------------------------|--------|----------------|---------|-----------|--------------------------------------------------------------------------------------------------------|--------|----|
| S                                                                         | D  | Index  | Busy 31 | HCS 30 | (FB) 29                                                           | XPC 28 | Reserved 27-25 | S18R 24 | OCR 23-08 | Reserved 07-00                                                                                         | CRC7   | E  |
| 0                                                                         | 1  | 101001 | 0       | X      | 0                                                                 | X      | 000            | X       | xxxxh     | 0000000                                                                                                | xxxxxx | 1  |
| Host Capacity Support<br>0b: SDSC-only Host<br>1b: SDHC or SDXC supported |    |        |         |        | SCXC Power Control<br>0b: Power saving<br>1b: Maximum performance |        |                |         |           | S18R: Switching to 1.8V Request<br>0b: Use current signal voltage<br>1b: Switch to 1.8V signal voltage |        |    |

Fig. 22-12 ACMD41 Argument

- Bit 30 informs the card if host supports SDHC/SDXC or not; this bit should be set to 1'b1.
- Bit 28 can be either 1 or 0.
- Bit 24 should be set to 1'b1, indicating that the host is capable of voltage switching; refer to following figure.



Fig. 22-13 ACMD41 Response(R3)

- Bit 30 – If set to 1'b1, card supports SDHC/SDXC; if set to 1'b0, card supports only SDSC
- Bit 24 – If set to 1'b1, card supports voltage switching and is ready for the switch
- Bit 31 – If set to 1'b1, initialization is over; if set to 1'b0, means initialization in process. If the card supports voltage switching, then the software must perform the steps discussed for either the "Voltage Switch Normal Scenario" or the "Voltage Switch Error Scenario".

### 22.6.2.15 Voltage Switch Normal Scenario



Fig. 22-14 Voltage Switch Normal Scenario

- The host programs SDMMC\_CLKENA—cclk\_low\_power register—with zero (0) for the corresponding card, which makes the host controller move to high-power mode. The application should start a timer with a recommended value of 2ms; this value of 2 ms is determined as below: Total cycles required for CMD11 = 48 cycles  
Total cycles required for RESP R1 = 48 cycles  
Maximum clock delay between MCD11 end to start of RESP1 = 60 cycles  
Total = 48+48 + 60 = 160  
Minimum frequency during enumeration is 100 KHz; that is, 10us  
Total time = 160 \* 10us = 1600us = 1. 6ms ~ 2ms
- The host issues CMD11 to start the voltage switch sequence. Set bit 28 to 1'b1 in CMD when setting CMD11; for more information on setting bits, refer to "Boot Operation".
- The card returns R1 response; the host controller does not generate cmd\_done interrupt on receiving R1 response.
- The card drives CMD and DAT [3:0] to low immediately after the response. The host controller generates interrupt (VOLT\_SWITCH\_INT) once the CMD or DAT [3:0] line goes low. The application should wait for this interrupt. If the 2ms timer expires

without an interrupt (CMD/DAT lines going low), do a power cycle.

*Note: Before doing a power cycle, switch off the card clock by programming SDMMC\_CLKENA register  
Proceed to step (5) on getting an interrupt (VOLT\_SWITCH\_INT).*

*Note: This interrupt must be cleared once this interrupt is received. Additionally, this interrupt should not be masked during the voltage switch sequence.*

If the timer expires without interrupt (CMD/DAT lines going low), perform a power cycle.

Proceed to step (5) on interrupt.

- 1) Program the SDMMC\_CLKENA register, with 0 for the corresponding card; the host stops supplying SDCLK.
- 2) Program Voltage register to the required values for the corresponding card. The application should start a timer > 5ms.
- 3) After the 5ms timer expires, the host voltage regulator is stable. Program SDMMC\_CLKENA register, with 1 for the corresponding card; the host starts providing SDCLK at 1. 8V; this can be at zero time after Voltage register has been programmed. When the SDMMC\_CLKENA register is programmed, the application should start another timer > 1ms.
- 4) By detecting SDCLK, the card drives CMD to high at 1. 8V for at least one clock and then stops driving (tri-state); CMD is triggered by the rising edge of SDCLK (SDR timing).
- 5) If switching to 1. 8V signaling is completed successfully, the card drives DAT [3:0] to high at 1. 8V for at least one clock and then stops driving (tri-state); DAT [3:0] is triggered by the rising edge of SDCLK (SDR timing). DAT[3:0] must be high within 1ms from the start of SDCLK.
- 6) The host controller generates a voltage switch interrupt (VOLT\_SWITCH\_INT) and a command done (CD) interrupt once the CMD and DAT[3:0] lines go high. The application should wait for this interrupt to confirm CMD and DAT lines going high before the 1ms timer is done.

If the timer expires without the voltage switch interrupt (VOLT\_SWITCH\_INT), a power cycle should be performed. Program the SDMMC\_CLKENA register to stop the clock for the corresponding card number. Wait for the cmd\_done (CD) interrupt. Proceed for normal operation on interrupt. After the sequence is completed, the host and the card start communication in SDR12 timing.

### 22.6.2.16 Voltage Switch Error Scenario



Fig. 22-15 Voltage Switch Error Scenario

- 1) If the interrupt (VOLT\_SWITCH\_INT) does not come, then the 2 ms timer should time out and a power cycle should be initiated.

*Note: Before performing a power cycle, switch off the card clock by programming SDMMC\_CLKENA register; no cmd\_done (CD) interrupt is generated.*

Additionally, if the card detects a voltage error at any point in between steps (5) and (7) in the card keeps driving DAT[3:0] to low until card power off.

- 2) CMD can be low or tri-state.
- 3) The host controller generates a voltage switch interrupt once the CMD and DAT[3:0] lines go high. The application should check for an interrupt to confirm CMD and DAT lines going high before the 1 ms timer is done.

If the 1 ms timer expires without interrupt (VOLT\_SWITCH\_INT) and cmd\_done (CD), a power cycle should be performed. Program the SDMMC\_CLKENA register to stop SDCLK of the corresponding card. Wait for the cmd\_done interrupt. Proceed for normal operation on interrupt.

- 4) If DAT[3:0] is low, the host drives SDCLK to low and then stops supplying the card power.

*Note: The card checks voltages of its own regulator output and host signals to ensure they are less than 2.5V. Errors are indicated by (1) and (2).*

- If voltage switching is accepted by the card, the default speed is SDR12.
- Command Done is given:
  - If voltage switching is properly done, CMD and DAT line goes high.
  - If switching is not complete, the 1ms timer expires, and the card clock is switched off.

*Note: No other CMD should be driven before the voltage switching operation is completed and Command Done is received.*

- The application should use CMD6 to check and select the particular function; the function appropriate-speed should be selected.

After the function switches, the application should program the correct value in the CLKDIV register, depending on the function chosen. Additionally, if Function 0x4 of the Access mode is chosen—that is, DDR50, then the application should also program 1'b1 in DDR\_REG for the card number that has been selected for DDR50 mode.

## **22.6.3 DDR Operation**

### **22.6.3.1 4-bit DDR Programming Sequence**

DDR programming should be done only after the voltage switch operation has completed.

The following outlines the steps for the DDR programming sequence:

- 1) Once the voltage switch operation is complete, the user must program voltage selection register to the required values for the corresponding card.
- To start a card to work in DDR mode, the application must program a bit of the newly defined SDMMC\_UHSREG[16] register with a value of 1'b1.
- The bit that the user programs depends on which card is to be accessed in DDR mode. To move back to SDR mode, a power cycle should be run on the card—putting the card in SDR12 mode—and only then should SDMMC\_UHSREG[16] be set back to 1'b0 for the appropriate card.

### **22.6.3.2 8-bit DDR Programming Sequence**

The following outlines the steps for the 8-bit DDR programming sequence:

- 1) The cclk\_in signal should be twice the speed of the required cclk\_out. Thus, if the cclk\_out signal is required to be 50 MHz, the cclk\_in signal should be 100 MHz.
- 2) The SDMMC\_CLKDIV register should always be programmed with a value higher than zero (0); that is, a clock divider should always be used for 8-bit DDR mode.
- 3) The application must program the SDMMC\_UHSREG[16] register (ddr\_reg bits) by assigning it with a value of 1 for the bit corresponding to the card number; this causes the selected card to start working in DDR mode.

Depending on the card number, the SDMMC\_CTYPE [16] bits should be set in order to make the host work in the 8-bit mode.

### **22.6.3.3 eMMC4.5 DDR START Bit**

The eMMC4.5 changes the START bit definition in the following manner:

- 1) Receiver samples the START bit on the rising edge.
- 2) On the next rising edge after sampling the START bit, the receiver must sample the data.
- 3) Removes requirement of the START bit and END bit to be high for one full cycle.

*Notes: The Host Controller does not support a START bit duration higher than one clock cycle. START bit durations of one or less than one clock cycle are supported and can be defined at the time of startup by programming the EMMC\_DDR\_REG register.*

### **22.6.3.4 Reset Command/Moving From DDR50 to SDR12**

To reset the mode of operation from DDR50 to SDR12, the following sequence of operations has to be done by the application:

- 1) Issue CMD0.
- 2) When CMD0 is received, the card changes from DDR50 to SDR12.
- 3) Program the SDMMC\_CLKDIV register with an appropriate value.
- 4) Set ddr\_reg to 0.

*Note: The Voltage register should not be programmed to 0 while switching from DDR50 to SDR12, since the card is still operating in 1.8V mode after receiving CMD0.*

## 22.6.4 H/W Reset Operation

When the RST\_n signal goes low, the card enters a pre-idle state from any state other than the inactive state.

The following outlines the steps for the H/W reset programming sequence:

- 1) Program CMD12 to end any transfer in process.
- 2) Wait for DTO, even if no response is sent back by the card.
- 3) Set the following resets:
  - DMA reset—SDMMC\_CTRL [2] bit
  - FIFO reset—SDMMC\_CTRL [1] bit

*Note: The above steps are required only if a transfer is in process.*

- 4) Program the SDMMC\_RSTN register with a value of 0; this can be done at any time when the card is connected to the controller. This programming asserts the RST\_n signal and resets the card.
- 5) Wait for minimum of 1  $\mu$ s or cclk\_in period, whichever is greater
- 6) After a minimum of 1  $\mu$ s, the application should program a value of 0 into the SDMMC\_RSTN register. This de-asserts the RST\_n signal and takes the card out of reset.
- 7) The application can program a new CMD only after a minimum of 200  $\mu$ s after the de-assertion of the RST\_n signal, as per the MMC 4.41 standard.

*Note: For backward compatibility, the RST\_n signal is temporarily disabled in the card by default. The host may need to set the signal as either permanently enabled or permanently disabled before it uses the card.*

## 22.6.5 FBE Scenarios

An FBE occurs due to an AHB error response on the AHB bus. This is a system error, so the software driver should not perform any further programming to the Host. The only recovery mechanism from such scenarios is to do one of the following:

- Issue a hard reset by asserting the reset\_n signal
- Do a program controller reset by writing to the SDMMC\_CTRL[0] bit

### 22.6.5.1 FIFO Overflow and Underflow

During normal data transfer conditions, FIFO overflow and underflow will not occur.

However if there is a programming error, then FIFO overflow/underflow can result. For example, consider the following scenarios.

- For transmit: PBL=4, Tx watermark = 1. For the above programming values, if the FIFO has only one location empty, it issues a dma\_req to IDMAC FSM. Due to PBL value=4, the IDMAC FSM performs 4 pushes into the FIFO. This will result in a FIFO overflow interrupt.
- For receive: PBL=4, Rx watermark = 1. For the above programming values, if the FIFO has only one location filled, it issues a dma\_req to IDMAC FSM. Due to PBL value=4, the IDMAC FSM performs 4 pops to the FIFO. This will result in a FIFO underflow interrupt.

The driver should ensure that the number of bytes to be transferred as indicated in the descriptor should be a multiple of 4bytes with respect to H\_DATA\_WIDTH=32. For example, if the SDMMC\_BYTCNT=13, the number of bytes indicated in the descriptor should be 16 for H\_DATA\_WIDTH=32.

### 22.6.5.2 Programming of PBL and Watermark Levels

The DMAC performs data transfers depending on the programmed PBL and threshold values.

Table 22-15 PBL and Watermark Levels

| PBL (Number of transfers) | Tx/Rx Watermark Value        |
|---------------------------|------------------------------|
| 1                         | Greater than or equal to 1   |
| 4                         | Greater than or equal to 4   |
| 8                         | Greater than or equal to 8   |
| 16                        | Greater than or equal to 16  |
| 32                        | Greater than or equal to 32  |
| 64                        | Greater than or equal to 64  |
| 128                       | Greater than or equal to 128 |
| 256                       | Greater than or equal to 256 |

## 22.6.6 Variable Delay Usage

The delay time of every element is in the range of 36ps~68ps, varying with different voltage and temperature.

The control signals for variable delay element usage are shown as follows.

### 22.6.6.1 SDMMC Variable Delay Usage

Table 22-16 Configuration for SDMMC Variable Delay Usage

| Signal Name          | Source                  | Default | Description                                                                                                                                                                                                          |
|----------------------|-------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| init_state           | VI_GRF_SDMMC_CON1[0]    | 0       | Enable initialization for clock source.<br>1'b0: Disable<br>1'b1: Enable<br>When init_state=1, the host clocks including drive clock and sample clock are inactive.                                                  |
| drv_degree[1:0]      | VI_GRF_SDMMC_CON1[2:1]  | 2       | Phase selection for drive clock.<br>2'h0: 0-degree<br>2'h1: 90-degree<br>2'h2: 180-degree<br>2'h3: 270-degree<br>It can be modified when init_state=1 and should be stable when init_state=0.                        |
| drv_delaynum[7:0]    | VI_GRF_SDMMC_CON1[10:3] | 0       | Delay element number configuration for drive clock.<br>It can be modified when init_state=1 and should be stable when init_state=0.                                                                                  |
| drv_sel              | VI_GRF_SDMMC_CON1[11]   | 0       | Selection for drive clock:<br>1'b0: Select clock delayed by phase shift<br>1'b1: Select clock delayed by phase shift and delay line<br>It can be modified when init_state=1 and should be stable when init_state=0.  |
| sample_degree[1:0]   | VI_GRF_SDMMC_CON2[2:1]  | 0       | Phase selection for sample clock.<br>2'h0: 0-degree<br>2'h1: 90-degree<br>2'h2: 180-degree<br>2'h3: 270-degree<br>It can be modified when init_state=1 and should be stable when init_state=0.                       |
| sample_delaynum[7:0] | VI_GRF_SDMMC_CON2[10:3] | 0       | Delay element number configuration for sample clock.<br>It can be modified when init_state=1 and should be stable when init_state=0.                                                                                 |
| sample_sel           | VI_GRF_SDMMC_CON2[11]   | 0       | Selection for sample clock:<br>1'b0: Select clock delayed by phase shift<br>1'b1: Select clock delayed by phase shift and delay line<br>It can be modified when init_state=1 and should be stable when init_state=0. |

### 22.6.6.2 SDIO Variable Delay Usage

Table 22-17 Configuration for SDIO Variable Delay Usage

| Signal Name          | Source                 | Default | Description                                                                                                                                                                                                          |
|----------------------|------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| init_state           | VO_GRF_SDIO_CON0[0]    | 0       | Enable initialization for clock source.<br>1'b0: Disable<br>1'b1: Enable<br>When init_state=1, the host clocks including drive clock and sample clock are inactive.                                                  |
| drv_degree[1:0]      | VO_GRF_SDIO_CON0[2:1]  | 2       | Phase selection for drive clock.<br>2'h0: 0-degree<br>2'h1: 90-degree<br>2'h2: 180-degree<br>2'h3: 270-degree<br>It can be modified when init_state=1 and should be stable when init_state=0.                        |
| drv_delaynum[7:0]    | VO_GRF_SDIO_CON0[10:3] | 0       | Delay element number configuration for drive clock.<br>It can be modified when init_state=1 and should be stable when init_state=0.                                                                                  |
| drv_sel              | VO_GRF_SDIO_CON0[11]   | 0       | Selection for drive clock:<br>1'b0: Select clock delayed by phase shift<br>1'b1: Select clock delayed by phase shift and delay line<br>It can be modified when init_state=1 and should be stable when init_state=0.  |
| sample_degree[1:0]   | VO_GRF_SDIO_CON1[2:1]  | 0       | Phase selection for sample clock.<br>2'h0: 0-degree<br>2'h1: 90-degree<br>2'h2: 180-degree<br>2'h3: 270-degree<br>It can be modified when init_state=1 and should be stable when init_state=0.                       |
| sample_delaynum[7:0] | VO_GRF_SDIO_CON1[10:3] | 0       | Delay element number configuration for sample clock.<br>It can be modified when init_state=1 and should be stable when init_state=0.                                                                                 |
| sample_sel           | VO_GRF_SDIO_CON1[11]   | 0       | Selection for sample clock:<br>1'b0: Select clock delayed by phase shift<br>1'b1: Select clock delayed by phase shift and delay line<br>It can be modified when init_state=1 and should be stable when init_state=0. |

### 22.6.6.3 EMMC Variable Delay Usage

Table 22-18 Configuration for EMMC Variable Delay Usage

| Signal Name | Source              | Default | Description                     |
|-------------|---------------------|---------|---------------------------------|
| init_state  | PERI_GRF_EMMC_CON0[ | 0       | Enable initialization for clock |

| <b>Signal Name</b>   | <b>Source</b>            | <b>Default</b> | <b>Description</b>                                                                                                                                                                                                   |
|----------------------|--------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | 0]                       |                | source.<br>1'b0: Disable<br>1'b1: Enable<br>When init_state=1, the host clocks including drive clock and sample clock are inactive.                                                                                  |
| drv_degree[1:0]      | PERI_GRF_EMMC_CON0[2:1]  | 2              | Phase selection for drive clock.<br>2'h0: 0-degree<br>2'h1: 90-degree<br>2'h2: 180-degree<br>2'h3: 270-degree<br>It can be modified when init_state=1 and should be stable when init_state=0.                        |
| drv_delaynum[7:0]    | PERI_GRF_EMMC_CON0[10:3] | 0              | Delay element number configuration for drive clock.<br>It can be modified when init_state=1 and should be stable when init_state=0.                                                                                  |
| drv_sel              | PERI_GRF_EMMC_CON0[11]   | 0              | Selection for drive clock:<br>1'b0: Select clock delayed by phase shift<br>1'b1: Select clock delayed by phase shift and delay line<br>It can be modified when init_state=1 and should be stable when init_state=0.  |
| sample_degree[1:0]   | PERI_GRF_EMMC_CON1[2:1]  | 0              | Phase selection for sample clock.<br>2'h0: 0-degree<br>2'h1: 90-degree<br>2'h2: 180-degree<br>2'h3: 270-degree<br>It can be modified when init_state=1 and should be stable when init_state=0.                       |
| sample_delaynum[7:0] | PERI_GRF_EMMC_CON1[10:3] | 0              | Delay element number configuration for sample clock.<br>It can be modified when init_state=1 and should be stable when init_state=0.                                                                                 |
| sample_sel           | PERI_GRF_EMMC_CON1[11]   | 0              | Selection for sample clock:<br>1'b0: Select clock delayed by phase shift<br>1'b1: Select clock delayed by phase shift and delay line<br>It can be modified when init_state=1 and should be stable when init_state=0. |

The following outlines the steps for clock generation sequence:

- 1) Assert init\_state to soft reset the CLKGEN.
- 2) Configure drv\_degree/sample\_degree.
- 3) If fine adjustment required, delay line can be used by configuring drv\_delaynum/sample\_delaynum and drv\_sel/sample\_sel.
- 4) Dis-assert init\_state to start CLKGEN.

## 22.6.7 Variable Delay Tuning

Tuning is defined by SD and MMC cards to determine the correct sampling point required for the host, especially for the speed modes SDR104 and HS200 where the output delays from the cards can be up to 2 UI. Tuning is required for other speed modes—such as DDR50—even though the output delay from the card is less than one cycle.

Command for tuning is different for different cards.

- SD Memory Card:
  - CMD19 – SD card for SDR50 and SDR104 speed modes. Tuning data is defined by card specifications.
  - CMD6 – SD card for speed modes not supporting CMD19. Tuning data is the 64byte SD status.
- Multimedia Card:
  - CMD21 – MMC card for HS200 speed mode. Tuning data is defined by card specifications.
  - CMD8 – MMC card for speed modes not supporting CMD21. Tuning data is 512 byte ExtCSD data.

The following is the procedure for variable delay tuning:

- 1) Set a phase shift of 0-degree on cclk\_in\_sample.
  - 2) Send the Tuning command to the card; the card in turn sends an R1 response on the CMD line and tuning data on the DAT line.
  - 3) If the host sees any of the errors—start bit error, data crc error, end bit error, data read time-out, response CRC error, response error—then the sampling point is incorrect.
  - 4) Send CMD12 to bring the host controller state machines to idle.
    - The card may treat CMD12 as an invalid command because the card has successfully sent the tuning data, and it cannot send a response.
    - The host controller may generate a response time-out interrupt that must be cleared by software.
  - 5) Repeat steps 2) to 4) by increasing the phase shift value or delay element number on cclk\_in\_sample until the correct sampling point is received such that the host does not see any of the errors.
  - 6) Mark this phase shift value as the starting point of the sampling window.
  - 7) Repeat steps 2 to 4 by increasing the phase shift value or delay element number on cclk\_in\_sample until the host sees the errors starting to come again or the phase shift value reaches 360-degree.
  - 8) Mark the last successful phase shift value as the ending point of the sampling window.
- A window is established where the tuning block is matched. For example, for a scenario where the tuning block is received correctly for a phase shift window of 90-degree and 180-degree, then an appropriate sampling point is established as 135-degree. Once a sampling point is established, no errors should be visible in the tuning block.

## 22.6.8 Card Detection Method

There are many methods for SDMMC/SDIO device detection.

- Method1: Using SDMMC\_CDETECT register, which is value on card\_detect\_n input port. 0 represents presence of card. This method is available only for SDMMC/SDIO.
- Method2: Using card detection unit in Host Controller, outputting host interrupt. The card detection unit looks for any changes in the card-detect signals for card insertion or card removal. It filters out the debounces associated with mechanical insertion or removal, and generates one interrupt to the host. You can program the debounce filter value in SDMMC\_DEBNCE [23:0]. Following figure illustrates the timing for card-detect signals. This method is available only for SDMMC/SDIO.



Fig. 22-16 Card Detection Method 2

- Method3: Using general card detection unit, outputting detect\_dual\_edge\_int connecting to IRQ[308]. Similar to Method2, except that the debounce time is configurable by PMU1\_GRF\_SD\_DETECT\_CNT; and the insertion/removal detection interrupt can be enabled or cleared respectively.

The detailed register information is:

Table 22-19 Register for SDMMC Card Detection Method 3

| Signal Name                         | Source                   | Default | Description                                                                                |
|-------------------------------------|--------------------------|---------|--------------------------------------------------------------------------------------------|
| sd_detectn_rise_edge_irq_en         | VI_GRF_SIG_DETECT_CON[0] | 0       | Enable SDMMC detect pin rising edge interrupt.<br>1'b0: Disable<br>1'b1: Enable            |
| sd_detect_fall_edge_detect_en       | VI_GRF_SIG_DETECT_CON[1] | 0       | Enable SDMMC detect pin falling edge interrupt.<br>1'b0: Disable<br>1'b1: Enable           |
| sd_detect_rising_edge_detect_status | VI_GRF_SIG_DETECT_STS[0] | 0       | SDMMC detect pin rising edge status.<br>1'b0: Inactive<br>1'b1: Active                     |
| sd_detect_fall_edge_detect_status   | VI_GRF_SIG_DETECT_STS[1] | 0       | SDMMC detect pin falling edge status.<br>1'b0: Inactive<br>1'b1: Active                    |
| sd_detect_rising_edge_detect_clr    | VI_GRF_SIG_DETECT_CLR[0] | 0       | Enable clear for SDMMC detect pin rising edge interrupt.<br>1'b0: Disable<br>1'b1: Enable  |
| sd_detect_fall_edge_detect_clr      | VI_GRF_SIG_DETECT_CLR[1] | 0       | Enable clear for SDMMC detect pin falling edge interrupt.<br>1'b0: Disable<br>1'b1: Enable |

## 22.6.9 SDMMC IOMUX With JTAG

The GPIO4d2/GPIO4d3 for sdmmc\_cdata2/sdmmc\_cdata3 is shared with jtag\_tck/jtag\_tms. The condition of usage for SDMMC or JTAG usage is as follows.

- If VIIOC\_FORCE\_JTAG\_SDMMC[0] is equal to 1 and SD/MMC card is not detected within detection time (defined in VI\_GRF\_SDMMC\_DET, in the unit of XIN24M clock), the GPIOs are used for JTAG.
- Otherwise, the GPIOs' usage is defined by IOMUX configuration.

## Chapter 23 Serial Peripheral Interface (SPI)

### 23.1 Overview

The serial peripheral interface is an APB slave device. 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 64-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 combining interrupt output
- Support up to half of SPI clock frequency transfer in master mode and one quarter 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
- Support timeout mechanism in slave mode
- Support BYPASS slave mode, in which RX and TX logic is drive by SCLK\_IN directly instead of spi\_clk

### 23.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. 23-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 64x16bits.

### 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 OR relationship between all other SPI interrupts after masking.

## 23.3 Function Description



Fig. 23-2 SPI Master and Slave Interconnection

The SPI controller support dynamic switching between master and slave in a system. The diagram shows 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} \geq 2 \times (\text{maximum } F_{sclk\_out})$

When SPI Controller works as slave, the  $F_{spi\_clk} \geq 6 \times (\text{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. 23-3 SPI Format (SCPH=0 SCPOL=0)



Fig. 23-4 SPI Format (SCPH=0 SCPOL=1)

When the configuration parameter  $\text{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  $\text{SCPH} = 1$ .



Fig. 23-5 SPI Format (SCPH=1 SCPOL=0)



Fig. 23-6 SPI Format (SCPH=1 SCPOL=1)

## 23.4 Register Description

### 23.4.1 Registers Summary

| Name        | Offset | Size | Reset Value | Description                   |
|-------------|--------|------|-------------|-------------------------------|
| SPI CTRLR0  | 0x0000 | W    | 0x00000002  | Control Register 0            |
| SPI CTRLR1  | 0x0004 | W    | 0x00000000  | Control Register 1            |
| SPI ENR     | 0x0008 | W    | 0x00000000  | SPI Enable Register           |
| SPI SER     | 0x000C | W    | 0x00000000  | Slave Enable Register         |
| SPI BAUDR   | 0x0010 | W    | 0x00000000  | Baud Rate Select              |
| SPI TXFTLR  | 0x0014 | W    | 0x00000000  | Transmit FIFO Threshold Level |
| SPI RXFTLR  | 0x0018 | W    | 0x00000000  | Receive FIFO Threshold Level  |
| SPI TXFLR   | 0x001C | W    | 0x00000000  | Transmit FIFO Level           |
| SPI RXFLR   | 0x0020 | W    | 0x00000000  | Receive FIFO Level            |
| SPI SR      | 0x0024 | W    | 0x0000004C  | SPI Status                    |
| SPI IPR     | 0x0028 | W    | 0x00000000  | Interrupt Polarity            |
| SPI IMR     | 0x002C | W    | 0x00000000  | Interrupt Mask                |
| SPI ISR     | 0x0030 | W    | 0x00000000  | Interrupt Status              |
| SPI RISR    | 0x0034 | W    | 0x00000001  | 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        |

| Name        | Offset | Size | Reset Value | Description              |
|-------------|--------|------|-------------|--------------------------|
| SPI_TIMEOUT | 0x004C | W    | 0x00000000  | Timeout control register |
| SPI_BYPASS  | 0x0050 | W    | 0x00000000  | BYPASS control register  |
| SPI_TXDR    | 0x0400 | W    | 0x00000000  | Transmit FIFO Data       |
| SPI_RXDR    | 0x0800 | W    | 0x00000000  | Receive FIFO Data        |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

### 23.4.2 Detail Registers Description

#### SPI\_CTRLR0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 25    | RW   | 0x0         | lbk<br>Loop back mode select.<br>1'b0: Normal mode.<br>1'b1: Loop back mode, rxd is connected to txd.                                                                                                                                                                                                                                                                                         |
| 24:23 | RW   | 0x0         | soi<br>SS_N output inverted.<br>1'b0: Corresponding bit of ss_in is not inverted.<br>1'b1: Corresponding bit of ss_in is inverted.                                                                                                                                                                                                                                                            |
| 22    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 21    | RW   | 0x0         | mtm<br>Valid when frame format is set to National Semiconductors Microwire.<br>1'b0: Non sequential transfer<br>1'b1: Sequential transfer                                                                                                                                                                                                                                                     |
| 20    | RW   | 0x0         | opm<br>Master and slave mode select.<br>1'b0: Master Mode<br>1'b1: Slave Mode                                                                                                                                                                                                                                                                                                                 |
| 19:18 | RW   | 0x0         | xfm<br>Transmit and receive mode select.<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   | 0x0         | rsd<br>When SPI is configured as a master, if the rxd data cannot be sampled by the sclk_out edge at the right time, this register should be configured to define the number of the spi_clk cycles after the active sclk_out edge to sample rxd data later when SPI 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 |
| 13    | RW   | 0x0         | bht<br>Valid when data frame size is 8bit.<br>1'b0: APB 16bit write/read, spi 8bit write/read.<br>1'b1: APB 8bit write/read, spi 8bit write/read.                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | fbm<br>1'b0: First bit is MSB.<br>1'b1: First bit is LSB.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11         | RW          | 0x0                | em<br>Serial endian mode can be configured by this bit. APB endian mode is always little endian.<br>1'b0: Little endian<br>1'b1: Big endian                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10         | RW          | 0x0                | ssd<br>Valid when the frame format is set to Motorola SPI and SPI used as a master.<br>1'b0: The period between ss_n active and sclk_out active is half sclk_out cycles.<br>1'b1: The period between ss_n active and sclk_out active is one sclk_out cycle.                                                                                                                                                                                                                                                                                                                                                                               |
| 9:8        | RW          | 0x0                | csm<br>Valid when the frame format is set to Motorola SPI and SPI used as a master.<br>2'b00: ss_n keep low after every frame data is transferred.<br>2'b01: ss_n be high for half sclk_out cycles after every frame data is transferred.<br>2'b10: ss_n be high for one sclk_out cycle after every frame data is transferred.<br>2'b11: Reserved                                                                                                                                                                                                                                                                                         |
| 7          | RW          | 0x0                | scpol<br>Valid when the frame format is set to Motorola SPI.<br>1'b0: Inactive state of serial clock is low.<br>1'b1: Inactive state of serial clock is high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6          | RW          | 0x0                | scph<br>Valid when the frame format is set to Motorola SPI.<br>1'b0: Serial clock toggles in middle of first data bit.<br>1'b1: Serial clock toggles at start of first data bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5:2        | RW          | 0x0                | cfs<br>Selects the length of the control word for the Microwire frame 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'b1000: 9-bit serial data transfer<br>4'b1001: 10-bit serial data transfer<br>4'b1010: 11-bit serial data transfer<br>4'b1011: 12-bit serial data transfer<br>4'b1100: 13-bit serial data transfer<br>4'b1101: 14-bit serial data transfer<br>4'b1110: 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | ndm<br>When Transfer Mode is receive only, this register field sets the number of data frames to be continuously received by the SPI. The SPI continues to receive serial data until the number of data frames received is equal to this register value plus 1, which enables you to receive up to 4GB of data in a continuous transfer. |

**SPI ENR**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                   |
| 0          | RW          | 0x0                | enr<br>Enables and disables all SPI operations. Transmit and receive FIFO buffers are cleared when the device is disabled. |

**SPI SER**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                                                                                     |
| 1:0        | RW          | 0x0                | ser<br>Slave enable register. The register enable the individual slave select output lines, 2 slave-select output pins are available. This register is valid only when SPI is configured as a master device. |

**SPI BAUDR**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 15:0       | RW          | 0x0000             | baudr<br>SPI Clock Divider. This register is valid only when the SPI is configured as a master device. The LSB for this field is always set to 0 and is unaffected by a write operation, which ensures an even value is held in this register. If the value is 0, the serial output clock (sclk_out) is disabled. The frequency of the sclk_out is derived from the following equation:<br>$F_{sclk\_out} = F_{spi\_clk} / SCKDV$<br>Where SCKDV is any even value between 2 and 65534.<br>For example:<br>for $F_{spi\_clk} = 3.6864\text{MHz}$ and $SCKDV = 2$<br>$F_{sclk\_out} = 3.6864/2 = 1.8432\text{MHz}$ |

**SPI TXFTLR**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                               |
| 5:0        | RW          | 0x00               | xftlr<br>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)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0        | RW          | 0x00               | rxftlr<br>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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                 |
| 6:0        | RO          | 0x00               | txflr<br>Contains the number of valid data entries in the transmit FIFO. |

**SPI RXFLR**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                |
| 6:0        | RO          | 0x00               | rxflr<br>Contains the number of valid data entries in the receive FIFO. |

**SPI SR**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                                                                                  |
| 6          | RO          | 0x1                | ssi<br>1'b0: ss_in_n is low.<br>1'b1: ss_in_n is high.                                                                                                                                                    |
| 5          | RO          | 0x0                | stb<br>1'b0: Slave tx not busy.<br>1'b1: Slave tx busy.                                                                                                                                                   |
| 4          | RO          | 0x0                | rff<br>1'b0: Receive FIFO is not full.<br>1'b1: Receive FIFO is full.                                                                                                                                     |
| 3          | RO          | 0x1                | rfe<br>1'b0: Receive FIFO is not empty.<br>1'b1: Receive FIFO is empty.                                                                                                                                   |
| 2          | RO          | 0x1                | tfe<br>1'b0: Transmit FIFO is not empty.<br>1'b1: Transmit FIFO is empty.                                                                                                                                 |
| 1          | RO          | 0x0                | tff<br>1'b0: Transmit FIFO is not full.<br>1'b1: Transmit FIFO is full.                                                                                                                                   |
| 0          | RO          | 0x0                | bsf<br>When set, indicates that a serial transfer is in progress; when cleared, indicates that the SPI is idle or disabled.<br>1'b0: SPI is idle or disabled.<br>1'b1: SPI is actively transferring data. |

**SPI IPR**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                               |
| 0          | RW          | 0x0                | ipr<br>Interrupt Polarity Register.<br>1'b0: Active Interrupt Polarity Level is HIGH.<br>1'b1: Active Interrupt Polarity Level is LOW. |

**SPI IMR**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                              |
| 7          | RW          | 0x0                | txfim<br>1'b0: TX finish interrupt is masked.<br>1'b1: TX finish interrupt is not masked.             |
| 6          | RW          | 0x0                | sspim<br>1'b0: ss_in_n posedge interrupt is masked.<br>1'b1: ss_in_n posedge interrupt is not masked. |
| 5          | RW          | 0x0                | toim<br>1'b0: spi timeout interrupt is masked.<br>1'b1: spi timeout interrupt is not masked.          |
| 4          | RW          | 0x0                | rffim<br>1'b0: spi_rxf_intr interrupt is masked.<br>1'b1: spi_rxf_intr interrupt is not masked.       |
| 3          | RW          | 0x0                | rfoim<br>1'b0: spi_rxo_intr interrupt is masked.<br>1'b1: spi_rxo_intr interrupt is not masked.       |
| 2          | RW          | 0x0                | rfuim<br>1'b0: spi_rxu_intr interrupt is masked.<br>1'b1: spi_rxu_intr interrupt is not masked.       |
| 1          | RW          | 0x0                | tfoim<br>1'b0: spi_txo_intr interrupt is masked.<br>1'b1: spi_txo_intr interrupt is not masked.       |
| 0          | RW          | 0x0                | tfeim<br>1'b0: spi_txe_intr interrupt is masked.<br>1'b1: spi_txe_intr interrupt is not masked.       |

**SPI ISR**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                          |
| 7          | RW          | 0x0                | txfis<br>1'b0: TX finish interrupt is not active after masking.<br>1'b1: TX finish interrupt is active after masking.             |
| 6          | RW          | 0x0                | sspis<br>1'b0: ss_in_n posedge interrupt is not active after masking.<br>1'b1: ss_in_n posedge interrupt is active after masking. |
| 5          | RW          | 0x0                | tois<br>1'b0: spi timeout interrupt is not active after masking.<br>1'b1: spi timeout interrupt is active after masking.          |
| 4          | RO          | 0x0                | rffis<br>1'b0: spi_rxf_intr interrupt is not active after masking.<br>1'b1: spi_rxf_intr interrupt is full after masking.         |
| 3          | RO          | 0x0                | rfois<br>1'b0: spi_rxo_intr interrupt is not active after masking.<br>1'b1: spi_rxo_intr interrupt is active after masking.       |
| 2          | RO          | 0x0                | rfuis<br>1'b0: spi_rxu_intr interrupt is not active after masking.<br>1'b1: spi_rxu_intr interrupt is active after masking.       |
| 1          | RO          | 0x0                | tfois<br>1'b0: spi_txo_intr interrupt is not active after masking.<br>1'b1: spi_txo_intr interrupt is active after masking.       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | tfeis<br>1'b0: spi_txe_intr interrupt is not active after masking.<br>1'b1: spi_txe_intr interrupt is active after masking. |

**SPI\_RISR**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                 |
| 7          | RW          | 0x0                | txfris<br>1'b0: TX finish interrupt is not active prior to masking.<br>1'b1: TX finish interrupt is active prior to masking.             |
| 6          | RW          | 0x0                | sspris<br>1'b0: ss_in_n posedge interrupt is not active prior to masking.<br>1'b1: ss_in_n posedge interrupt is active prior to masking. |
| 5          | RW          | 0x0                | toris<br>1'b0: spi_timeout interrupt is not active prior to masking.<br>1'b1: spi_timeout interrupt is active prior to masking.          |
| 4          | RO          | 0x0                | rffris<br>1'b0: spi_rxf_intr interrupt is not active prior to masking.<br>1'b1: spi_rxf_intr interrupt is full prior to masking.         |
| 3          | RO          | 0x0                | rforis<br>1'b0: spi_rxo_intr interrupt is not active prior to masking.<br>1'b1: spi_rxo_intr interrupt is active prior to masking.       |
| 2          | RO          | 0x0                | rfuris<br>1'b0: spi_rxu_intr interrupt is not active prior to masking.<br>1'b1: spi_rxu_intr interrupt is active prior to masking.       |
| 1          | RO          | 0x0                | tforis<br>1'b0: spi_txo_intr interrupt is not active prior to masking.<br>1'b1: spi_txo_intr interrupt is active prior to masking.       |
| 0          | RO          | 0x1                | tferis<br>1'b0: spi_txe_intr interrupt is not active prior to masking.<br>1'b1: spi_txe_intr interrupt is active prior to masking.       |

**SPI\_ICR**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:7       | RO          | 0x0000000          | reserved                                                    |
| 6          | WO          | 0x0                | ctxfi<br>Write 1 to Clear tx finish Interrupt.              |
| 5          | WO          | 0x0                | csspi<br>Write 1 to Clear ss_in_n posedge Interrupt.        |
| 4          | WO          | 0x0                | ctoi<br>Write 1 to Clear Timeout Interrupt.                 |
| 3          | WO          | 0x0                | ctfoi<br>Write 1 to Clear Transmit FIFO Overflow Interrupt. |
| 2          | WO          | 0x0                | crfoi<br>Write 1 to Clear Receive FIFO Overflow Interrupt.  |
| 1          | WO          | 0x0                | crfui<br>Write 1 to Clear Receive FIFO Underflow Interrupt. |
| 0          | WO          | 0x0                | cci<br>Write 1 to Clear Combined Interrupt.                 |

**SPI\_DMACR**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                           |
| 1          | RW          | 0x0                | tde<br>1'b0: Transmit DMA disabled.<br>1'b1: Transmit DMA enabled. |
| 0          | RW          | 0x0                | rde<br>1'b0: Receive DMA disabled.<br>1'b1: Receive DMA enabled.   |

**SPI DMATDLR**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                     |
| 5:0        | RW          | 0x00               | tdl<br>This bit field controls the level at which a DMA request is made by 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 transmit FIFO is equal to or below this field value, and transmit DMA is enabled (DMACR[1] = 1). |

**SPI DMARDLR**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                     |
| 5:0        | RW          | 0x00               | rdl<br>This bit field controls the level at which a DMA request is made by the receive logic. The watermark level = DMARDL+1; that is, dma_rx_req is generated when the number of valid data entries in the receive FIFO is equal to or above this field value + 1, and receive DMA is enabled (DMACR[0]=1). |

**SPI TIMEOUT**

Address: Operational Base + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                                                             |
| 16         | RW          | 0x0                | toe<br>Timeout enable.<br>1'b0: Timeout counter is inactive.<br>1'b1: Timeout counter will be active after the first rising edge of sclk_in.                         |
| 15:0       | RW          | 0x0000             | tov<br>Timeout threshold value. If sclk_in keep inactive for a threshold time, timeout interrupt will be triggered. The timeout threshold time is TOV*pclk_perid*16. |

**SPI BYPASS**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                               |
| 4          | RW          | 0x0                | txcp<br>TX clock polarity. This bit is only valid in bypass mode.<br>1'b0: TX logic use raw SCLK.<br>1'b1: TX logic use inverted SCLK. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | rxcp<br>RX clock polarity.This bit is only valid in bypass mode.<br>1'b0: RX logic use raw SCLK.<br>1'b1: RX logic use inverted SCLK. |
| 2          | RW          | 0x0                | end<br>Endian mode.This bit is only valid in bypass mode.<br>1'b0: Work in little endian mode.<br>1'b1: Work in big endian mode.      |
| 1          | RW          | 0x0                | fbm<br>First bit mode.This bit is only valid in bypass mode.<br>1'b0: First bit is LSB.<br>1'b1: First bit is MSB.                    |
| 0          | RW          | 0x0                | byen<br>Bypass enable.<br>1'b0: Normal mode.<br>1'b1: Bypass mode, SPI serial/parallel convert logic is drive by SCLK.                |

**SPI TXDR**

Address: Operational Base + offset (0x0400)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                              |
| 15:0       | WO          | 0x0000             | txdr<br>When it is written to, data are moved into the transmit FIFO. |

**SPI RXDR**

Address: Operational Base + offset (0x0800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                 |
| 15:0       | RO          | 0x0000             | rxdr<br>When the register is read, data in the receive FIFO is accessed. |

**23.5 Interface Description**

Table 23-1 SPI0 Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b>                                                                               | <b>IOMUX Setting</b>                        |
|-------------------|------------|-----------------------------------------------------------------------------------------------|---------------------------------------------|
| spi_sclk          | I/O        | SDMMC1_D0_M1/SPI0_CLK_M0/PWM4_M2 /VICAP_D3_M1/LCD_D6/GPIO1_C1_d                               | VENC_IOC_GPIO1C_I<br>OMUX_SEL_L[6:4]=3'h4   |
| spi_mosi          | I/O        | SPI0_MOSI_M0/SDMMC1_CLK_M1/I2C4_S CL_M1/PWM5_M2/VICAP_D4_M1/LCD_D5/ GPIO1_C2_d                | VENC_IOC_GPIO1C_I<br>OMUX_SEL_L[10:8]=3'h6  |
| spi_miso          | I/O        | SPI0_MISO_M0/SDMMC1_CMD_M1/I2C4_S DA_M1/PWM6_M2/VICAP_D5_M1/LCD_D4/ GPIO1_C3_d                | VENC_IOC_GPIO1C_I<br>OMUX_SEL_L[14:12]=3'h6 |
| spi_csn0          | I/O        | SDMMC1_D1_M1/SPI0_CS0n_M0/PWM2_M 2/VICAP_D2_M1/LCD_D7/GPIO1_C0_d                              | VENC_IOC_GPIO1C_I<br>OMUX_SEL_L[2:0]=3'h4   |
| spi_csn1          | O          | DSMAUDIO_P/PWM0_M1/SPI0_CS1n_M0/U ART5_RX_M1/I2C3_SDA_M1/VICAP_VSYNC _M1/LCD_VSYNC/GPIO1_D2_d | VENC_IOC_GPIO1D_I<br>OMUX_SEL_L[10:8]=3'h5  |

Table 23-2 SPI1 Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b>                                         | <b>IOMUX Setting</b>                        |
|-------------------|------------|---------------------------------------------------------|---------------------------------------------|
| spi_sclk          | I/O        | I2C2_SCL_M1/UART1_RX_M2/SPI1_CLK_M 0/EMMC_D5/GPIO4_A7_u | PERI_IOC_GPIO4A_IO<br>MUX_SEL_H[14:12]=3'h2 |

|          |     |                                                                       |                                           |
|----------|-----|-----------------------------------------------------------------------|-------------------------------------------|
| spi_mosi | I/O | TEST_CLK3_OUT/I2C0_SCL_M1/UART0_TX_M2/SPI1_MOSI_M0/EMMC_D6/GPIO4_A1_u | PERI_IOC_GPIO4A_IO<br>MUX_SEL_L[6:4]=3'h2 |
| spi_miso | I/O | TEST_CLK2_OUT/I2C0_SDA_M1/UART0_RX_M2/SPI1_MISO_M0/EMMC_D7/GPIO4_A0_u | PERI_IOC_GPIO4A_IO<br>MUX_SEL_L[2:0]=3'h2 |
| spi_csn0 | I/O | I2C2_SDA_M1/UART1_TX_M2/SPI1_CS0n_M0/EMMC_D4/GPIO4_A5_u               | PERI_IOC_GPIO4A_IO<br>MUX_SEL_H[6:4]=3'h2 |
| spi_csn1 | O   | VICAP_D1_M1/SPI1_CS1n_M0/PWM7_IR_M1/UART4_TX_M0/GPIO1_B1_d            | VENC_IOC_GPIO1B_I<br>OMUX_SEL_L[6:4]=3'h3 |

## 23.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  $F_{spi\_clk} \geq 2 \times (\text{maximum } F_{sclk\_out})$

When SPI Controller works as slave, the  $F_{spi\_clk} \geq 4 \times (\text{maximum } F_{sclk\_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. 23-7 SPI Master transfer flow diagram



Fig. 23-8 SPI Slave transfer

## Chapter 24 Real Time Clock (RTC)

### 24.1 Overview

The main function of a real-time clock (RTC) is to keep track of the current time of computer. The main characteristics of RTC are listed below:

- Supply voltage: 1.6v~3.3v.
- Support battery voltage detect.
- Support RTC external power off indication.
- Analog working current typical 2.5uA.
- Support 32.768 kHz clock self-detect.
- Provides year, month, day, weekday, hours, minutes, and seconds based on a 32.768 kHz crystal oscillator.
- Support compensation for the second and hour count.
- BCD representation of time, calendar and alarm.
- 12- or 24-hour clock with AM and PM in 12-hour mode.
- APB interface with 8bit data bus width.
- Bus-compatible interrupt signals (IRQ)
- Interrupts are separately software maskable
  - Alarm interrupt
  - Periodic interrupt
  - Chip power off interrupt
  - Battery power atypical interrupt

### 24.2 Block Diagram



Fig. 24-1 RTC Block Diagram

#### System Interface

The system interface implements the APB slave operation. Rtc\_test and RTC use the common APBus address decoder, the common control bus and data bus.

#### rtc\_test

rtc 32k clock test module, test the 32k clock accuracy.

#### rtc\_analog

Battery power domain, support power and generate 32k clock for RTC digital, and some detect function, such as external power off and battery voltage atypical.

#### rtc\_timer

Include npor, clock\_gen, irq\_gen, timer and reg\_file, the main function is to keep track of the current time, alarm, and some control registers for RTC Analog.

### 24.3 Function Description

#### 24.3.1 APB Interface

There is an APB slave interface in RTC. It is responsible for accessing registers.

#### 24.3.2 Alarm interrupt

Alarm interrupt generate from the real-time, the alarm time, and the alarm\_irq\_mask bit.

alarm\_irq\_mask[0]: 1'b0: fix alarm second, 1'b1: every second.

alarm\_irq\_mask[1]: 1'b0: fix alarm minute, 1'b1: every minute.

alarm\_irq\_mask[2]: 1'b0: fix alarm hour, 1'b1: every hour.

alarm\_irq\_mask[3]: 1'b0: fix alarm day, 1'b1: every day.

alarm\_irq\_mask[4]: 1'b0: fix alarm month, 1'b1: every month.

alarm\_irq\_mask[5]: 1'b0: fix alarm year

when alarm\_irq\_mask = 6'h3, means every hour fix min and fix second alarm.

When alarm\_irq\_mask = 6'b101011, fix year, every month, fix day every hour fix min and fix second alarm.

### 24.3.3 RTC 32k clock test

Due to the analog generator 32k clock affected by temperature, voltage, clock precision need test with the environment change. In rtc test, use 24M clock as reference clock to measure the 32k clock. Before start test 32k clock, we should enable clk32k test(0x80), and configure test length, when rtc test done(0x84[2]), latch the 24M clock domain counter, and read out the counter from rtc\_test registers(0x8c~0x98) via app bus.

### 24.3.4 Compensation

In RTC digital design, we set three level compensation, the compensation value due to the RTC 32k clock test result, and if we need compensation, we need configure the compensation enable bit.

Compensation every hour, compensation at last minute every hour, and support add time and sub time by the MSB bit.

Compensation every day, compensation at last minute in last hour every day, and support add time and sub time by the MSB bit.

Compensation every month, compensation at last minute in last hour in last day every month, and support add time and sub time by the MSB bit.

## 24.4 Register Description

### 24.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

RTC digital register address space: 0x00~0x80

RTC test register address space: 0x84~0x98

No reset registers: 0x00~0x38, 0x50[2:1], 0x54, 0x58~0x60.

### 24.4.2 Registers Summary

| Name              | Offset | Size | Reset Value | Description                    |
|-------------------|--------|------|-------------|--------------------------------|
| RTC SET SECONDS   | 0x0000 | W    | 0x00000000  | Seconds                        |
| RTC SET MINUTES   | 0x0004 | W    | 0x00000000  | Minutes                        |
| RTC SET HOURS     | 0x0008 | W    | 0x00000000  | Hours                          |
| RTC SET DAYS      | 0x000C | W    | 0x00000000  | Days                           |
| RTC SET MONTHS    | 0x0010 | W    | 0x00000000  | Months                         |
| RTC SET YEARSL    | 0x0014 | W    | 0x00000000  | Years(LSB)                     |
| RTC SET YEARSH    | 0x0018 | W    | 0x00000000  | Years(MSB)                     |
| RTC SET WEEKS     | 0x001C | W    | 0x00000000  | Weeks                          |
| RTC ALARM SECONDS | 0x0020 | W    | 0x00000000  | Alarm seconds                  |
| RTC ALARM MINUTES | 0x0024 | W    | 0x00000000  | Alarm minutes                  |
| RTC ALARM HOURS   | 0x0028 | W    | 0x00000000  | Alarm hours                    |
| RTC ALARM DAYS    | 0x002C | W    | 0x00000000  | Alarm days                     |
| RTC ALARM MONTHS  | 0x0030 | W    | 0x00000000  | Alarm months                   |
| RTC ALARM YEARSL  | 0x0034 | W    | 0x00000000  | Alarm years(LSB)               |
| RTC ALARM YEARSH  | 0x0038 | W    | 0x00000000  | Alarm years(MSB)               |
| RTC CTRL          | 0x003C | W    | 0x00000000  | RTC control registers          |
| RTC STATUS0       | 0x0040 | W    | 0x00000000  | RTC Status registers           |
| RTC STATUS1       | 0x0044 | W    | 0x00000000  | RTC Status registers           |
| RTC INTO_EN       | 0x0048 | W    | 0x00000000  | RTC interrupt enable registers |
| RTC INT1_EN       | 0x004C | W    | 0x00000000  | RTC interrupt enable registers |
| RTC MSEC_CTRL     | 0x0050 | W    | 0x00000000  | millisecond control            |
| RTC MSEC_CNT      | 0x0054 | W    | 0x00000000  | millisecond periodic count     |
| RTC COMP_H        | 0x0058 | W    | 0x00000000  | Hour compensation registers    |
| RTC COMP_D        | 0x005C | W    | 0x00000000  | Day compensation registers     |
| RTC COMP_M        | 0x0060 | W    | 0x00000000  | Month compensation registers   |
| RTC VREF_DET      | 0x0064 | W    | 0x00000000  | Vref trim bits                 |
| RTC VREF_TRIM     | 0x0068 | W    | 0x00000000  | Vref trim bits                 |
| RTC XO_TRIMO      | 0x006C | W    | 0x00000000  | XO trim registers              |

| Name            | Offset | Size | Reset Value | Description                         |
|-----------------|--------|------|-------------|-------------------------------------|
| RTC_XO_TRIM1    | 0x0070 | W    | 0x00000000  | XO trim registers                   |
| RTC_TEST_SEL    | 0x0074 | W    | 0x00000000  | Analog test                         |
| RTC_LDO_CTRL    | 0x0078 | W    | 0x00000000  | LDO control                         |
| RTC_ANALOG_EN   | 0x007C | W    | 0x00000000  | Analog config.                      |
| RTC_CLK32K_TEST | 0x0080 | W    | 0x00000000  | Test 32k Hz clock enable            |
| RTC_TEST_ST     | 0x0084 | W    | 0x00000000  | Test 32k clock start and status     |
| RTC_TEST_LEN    | 0x0088 | W    | 0x00000000  | Test 32k clock length, unit second. |
| RTC_CNT_0       | 0x008C | W    | 0x00000000  | 24M clock counter[7:0]              |
| RTC_CNT_1       | 0x0090 | W    | 0x00000000  | 24M clock counter[15:8]             |
| RTC_CNT_2       | 0x0094 | W    | 0x00000000  | 24M clock counter[23:16]            |
| RTC_CNT_3       | 0x0098 | W    | 0x00000000  | 24M clock counter[31:24]            |

Notes: Size: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

#### 24.4.3 Detail Registers Description

##### RTC\_SET\_SECONDS

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                            |
|------|------|-------------|--------------------------------------------------------|
| 31:7 | RO   | 0x00000000  | reserved                                               |
| 6:4  | RW   | 0x0         | SEC1<br>Set the second digit of the RTC seconds (0-5). |
| 3:0  | RW   | 0x0         | SEC0<br>Set the first digit of the RTC seconds (0-9).  |

##### RTC\_SET\_MINUTES

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                            |
|------|------|-------------|--------------------------------------------------------|
| 31:7 | RO   | 0x00000000  | reserved                                               |
| 6:4  | RW   | 0x0         | MIN1<br>Set the second digit of the RTC minutes (0-5). |
| 3:0  | RW   | 0x0         | MIN0<br>Set the first digit of the RTC minutes (0-9).  |

##### RTC\_SET\_HOURS

Address: Operational Base + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                        |
|------|------|-------------|----------------------------------------------------|
| 31:8 | RO   | 0x00000000  | reserved                                           |
| 7    | RW   | 0x0         | AMPM<br>Only used in PM-AM mode<br>1: PM<br>0: AM. |
| 6    | RO   | 0x0         | reserved                                           |
| 5:4  | RW   | 0x0         | HOUR1<br>Set the second digit of the RTC hours.    |
| 3:0  | RW   | 0x0         | HOUR0<br>Set the first digit of the RTC hours.     |

##### RTC\_SET\_DAYS

Address: Operational Base + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                   |
|------|------|-------------|-----------------------------------------------|
| 31:6 | RO   | 0x00000000  | reserved                                      |
| 5:4  | RW   | 0x0         | DAY1<br>Set the second digit of the RTC days. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 3:0        | RW          | 0x0                | DAY0<br>Set the first digit of the RTC days. |

**RTC SET MONTHS**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                          |
| 4          | RW          | 0x0                | MONTH1<br>Set the second digit of the RTC months. |
| 3:0        | RW          | 0x0                | MONTH0<br>Set the first digit of the RTC months.  |

**RTC SET YEARSL**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                        |
| 7:4        | RW          | 0x0                | YEAR1<br>Set the second digit of the RTC years. |
| 3:0        | RW          | 0x0                | YEAR0<br>Set the first digit of the RTC years.  |

**RTC SET YEARSH**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                        |
| 7:4        | RW          | 0x0                | YEAR3<br>Set the 3th digit of the RTC years.    |
| 3:0        | RW          | 0x0                | YEAR2<br>Set the second digit of the RTC years. |

**RTC SET WEEKS**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                |
| 2:0        | RW          | 0x0                | WEEK<br>Set the second digit of the RTC weeks.<br>configure value: 1~7. |

**RTC ALARM SECONDS**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                     |
| 6:4        | RW          | 0x0                | ALARM_SEC1<br>Set the second digit of the RTC alarm seconds. |
| 3:0        | RW          | 0x0                | ALARM_SEC0<br>Set the first digit of the RTC alarm seconds.  |

**RTC ALARM MINUTES**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                     |
| 6:4        | RW          | 0x0                | ALARM_MIN1<br>Set the second digit of the RTC alarm minutes. |
| 3:0        | RW          | 0x0                | ALARM_MIN0<br>Set the first digit of the RTC alarm minutes.  |

**RTC ALARM HOURS**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                       |
| 7          | RW          | 0x0                | ALARM_PM_AM<br>Set alarm PM or AM: only used in PM-AM mode.<br>1: PM<br>0: AM. |
| 6          | RO          | 0x0                | reserved                                                                       |
| 5:4        | RW          | 0x0                | ALARM_HOUR1<br>Set the second digit of the RTC alarm hours.                    |
| 3:0        | RW          | 0x0                | ALARM_HOUR0<br>Set the first digit of the RTC alarm hours.                     |

**RTC ALARM DAYS**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                  |
| 5:4        | RW          | 0x0                | ALARM_DAY1<br>Set the second digit of the RTC alarm days. |
| 3:0        | RW          | 0x0                | ALARM_DAY0<br>Set the first digit of the RTC alarm days.  |

**RTC ALARM MONTHS**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                            |
|------------|-------------|--------------------|---------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                      |
| 4          | RW          | 0x0                | ALARM_MONTH1<br>Set the second digit of the RTC alarm months. |
| 3:0        | RW          | 0x0                | ALARM_MONTH0<br>Set the first digit of the RTC alarm months.  |

**RTC ALARM YEARSL**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                    |
| 7:4        | RW          | 0x0                | ALARM_YEAR1<br>Set the second digit of the RTC alarm years. |
| 3:0        | RW          | 0x0                | ALARM_YEAR0<br>Set the first digit of the RTC alarm years.  |

**RTC ALARM YEARTH**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                    |
| 7:4        | RW          | 0x0                | ALARM_YEAR3<br>Set the 3th digit of the RTC alarm years.    |
| 3:0        | RW          | 0x0                | ALARM_YEAR2<br>Set the second digit of the RTC alarm years. |

**RTC CTRL**

Address: Operational Base + offset (0x003C)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | RTC_READ_SEL<br>Reserved                                                                                                                                                 |
| 6          | RW          | 0x0                | GET_TIME<br>Reserved                                                                                                                                                     |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                                                 |
| 3          | RW          | 0x0                | AMPM_MODE<br>AMPM mode set.<br>0: 24 hours mode<br>1: 12 hours mode.                                                                                                     |
| 2          | RW          | 0x0                | COMP_EN<br>Auto compensation enable bit.<br>0: No auto compensation<br>1: Auto compensation enabled.                                                                     |
| 1          | RW          | 0x0                | PSEL_SEL<br>Psel select bit.<br>1'b0: psel<br>1'b1: psel & sys_npor                                                                                                      |
| 0          | RW          | 0x0                | START_RTC<br>RTC trigger bit.<br>0: RTC stop<br>1: RTC start.<br>Note:<br>RTC_time(SET_SECONDS/MINUTES/HOURS/DAYS/MONTHS/YEAR<br>S) can only be changed during RTC stop. |

**RTC\_STATUS0**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                       |
| 6          | RW          | 0x0                | MSEC_ST<br>milisec periodic interrupt occurred.                |
| 5          | RO          | 0x0                | reserved                                                       |
| 4          | RW          | 0x0                | ALARM<br>Indicates that an alarm interrupt has been generated. |
| 3          | RW          | 0x0                | EVENT_1D<br>One day has occurred.                              |
| 2          | RW          | 0x0                | EVENT_1H<br>One hour has occurred.                             |
| 1          | RW          | 0x0                | EVENT_1M<br>One minutes has occurred.                          |
| 0          | RW          | 0x0                | EVENT_1S<br>One second has occurred.                           |

**RTC\_STATUS1**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                      |
| 3          | RO          | 0x0                | EXT_OFF<br>RTC external power detect status.<br>0: external power on<br>1: external power off.                |
| 2          | RO          | 0x0                | BAT_DET<br>Battery voltage detect status.<br>0: battery voltage in typical range<br>1: battery voltage lower. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | SYS_INT<br>Reserved                                                                               |
| 0          | RO          | 0x0                | RUN_ST<br>0: RTC is frozen. 1: RTC is running.<br>Note: This bit shows the real state of the RTC. |

**RTC INTO EN**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7          | RW          | 0x0                | ALARM_IRQ_EN<br>Alarm interrupt output enable bit.<br>1: enable<br>0: disable.<br>include external power on or off.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6          | RW          | 0x0                | ALARM_IRQ_EN_PD<br>Alarm interrupt output enable bit(only asserted when external power down).<br>1: enable<br>0: disable.<br>not need config ALARM_IRQ_EN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5:0        | RW          | 0x00               | ALARM_IRQ_MASK<br>Alarm irq mask:<br>alarm irq mask[0]: second alarm<br>alarm irq mask[1]: minute alarm<br>alarm irq mask[2]: hour alarm<br>alarm irq mask[3]: day alarm<br>alarm irq mask[4]: month alarm<br>alarm irq mask[5]: year alarm<br>if mask bit equal 1'b1, means that fix point, if mask bit equal 1'b0, means every.<br><br>example:<br>if configure ALARM_IRQ_MASK = 6'h01,<br>configure RTC_ALARM_SECONDS = 8'h03,<br>every minute, if second == 8'h03, alarm active;<br><br>if configure ALARM_IRQ_MASK = 6'h17,<br>configure RTC_ALARM_SECONDS = 8'h30:<br>configure RTC_ALARM_MINUTES = 8'h30:<br>configure RTC_ALARM_HOURS = 8'h8(24hour mode):<br>configure RTC_ALARM_MONTH=8'h2.<br>every day in February, when Am 8:30:30(H:M:S), alarm active. |

**RTC INT1 EN**

Address: Operational Base + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                          |
| 7          | RW          | 0x0                | MSEC_IRQ_EN<br>Milisecond interrupt output enable bit.<br>0: Disable<br>1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | EXT_IRQ_EN<br>External power off interrupt output enable bit.<br>0: disable<br>1: Enable.                                                                                                                                                                      |
| 5          | RW          | 0x0                | BAT_IRQ_EN<br>Detect battery voltage lower interrupt output enable bit.<br>0: Disable<br>1: Enable.                                                                                                                                                            |
| 4          | RW          | 0x0                | SYS_IRQ_MASK<br>System interrupt mask bit.<br>0: Normal mode, no system interrupt masked<br>1: system interrupt masked, no system interrupt output.                                                                                                            |
| 3          | RW          | 0x0                | PER_PD_MASK_EN<br>Periodic interrupt output enable bit, when RTC external power down.<br>1: Mask periodic interrupt while the external power down<br>0: Normal mode, no periodic interrupt masked when external power down<br>Need config PER_TIMER_EN enable. |
| 2          | RW          | 0x0                | PER_TIMER_EN<br>Periodic interrupt output enable bit.<br>0: Disable<br>1: Enable.                                                                                                                                                                              |
| 1:0        | RW          | 0x0                | EVERY_TYPE_SEL<br>Periodic interrupt type select.<br>2'b00: Every second<br>2'b01: Every minute<br>2'b10: Every hour<br>2'b11: Every day.                                                                                                                      |

**RTC MSEC CTRL**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                         |
| 2:1        | RW          | 0x0                | MSEC_SEL<br>Milisec periodic clock select.<br>00b: 8hz<br>01b: 128hz<br>10b: 1khz<br>11b: 32khz. |
| 0          | RW          | 0x0                | MSEC_EN<br>Milisec periodic function enable.                                                     |

**RTC MSEC CNT**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                         |
| 7:0        | RW          | 0x00               | MSEC_CNT<br>Number of milisec periodic interrupt interval clock. |

**RTC COMP H**

Address: Operational Base + offset (0x0058)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | COMP_H_DIR<br>Compensation direction every hour.<br>1: Add second<br>0: Sub second.                                               |
| 6:0        | RW          | 0x00               | COMP_HOUR<br>This register contains the number of second periods to be added/sub every hour.<br>the 7bit value need 8421BCD code. |

**RTC COMP D**

Address: Operational Base + offset (0x005C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                        |
| 7          | RW          | 0x0                | COMP_D_DIR<br>Compensation direction every day.<br>1: Add second<br>0: Sub second.                                              |
| 6:0        | RW          | 0x00               | COMP_DAY<br>This register contains the number of second periods to be added/sub every day.<br>the 7bit value need 8421BCD code. |

**RTC COMP M**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                            |
| 7          | RW          | 0x0                | COMP_M_DIR<br>Compensation direction every month.<br>1: Add second<br>0: Sub second.                                                |
| 6:0        | RW          | 0x00               | COMP_MONTH<br>This register contains the number of second periods to be added/sub every month.<br>the 7bit value need 8421BCD code. |

**RTC VREF DET**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:3       | RO          | 0x000000000        | reserved                                                   |
| 2:0        | RW          | 0x0                | D2A_TRIM_VREF_DET<br>Vref set, for battery voltage detect. |

**RTC VREF TRIM**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:7       | RO          | 0x0000000          | reserved                                                  |
| 6:4        | RW          | 0x0                | D2A_TRIM_VREF_1P0<br>Vref set, for xo ldo output voltage. |
| 3          | RO          | 0x0                | reserved                                                  |
| 2:0        | RW          | 0x0                | D2A_TRIM_VREF_DIG<br>Vref set, for rtc digital voltage.   |

**RTC XO TRIM0**

Address: Operational Base + offset (0x006C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                    |
| 7:4        | RW          | 0x0                | D2A_XO_OTA<br>Reserved                                                                                                                                      |
| 3:1        | RW          | 0x0                | D2A_XO_CAP<br>Capacitance compensation for xo load.<br>3'h0: 0pf<br>3'h1: 1pf<br>3'h2: 2pf<br>3'h3: 3pf<br>3'h4: 4pf<br>3'h5: 5pf<br>3'h6: 6pf<br>3'h7: 7pf |
| 0          | RW          | 0x0                | D2A_XO_EN<br>XO enable bit.<br>0: Disable<br>1: Enable<br>configure 1'b1 for rtc analog 32k generate.                                                       |

**RTC XO TRIM1**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>          |
|------------|-------------|--------------------|-----------------------------|
| 31:8       | RO          | 0x000000           | reserved                    |
| 7:6        | RW          | 0x0                | D2A_XO_GM<br>Reserved       |
| 5:3        | RW          | 0x0                | D2A_XO_START_UP<br>Reserved |
| 2:0        | RW          | 0x0                | D2A_XO_START<br>Reserved    |

**RTC TEST SEL**

Address: Operational Base + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                               |
| 7:4        | RW          | 0x0                | D2A_LDO_XO_SEL<br>Calibrate LDO output voltage for xo. |
| 3:0        | RW          | 0x0                | D2A_TEST_SEL<br>Reserved                               |

**RTC LDO CTRL**

Address: Operational Base + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                     |
| 6:4        | RW          | 0x0                | D2A_RESERVE<br>D2A_RESERVE[0]: d2a_por_ref_sel[1]<br>D2A_RESERVE[1]: clk_32k_h gating enable bit<br>D2A_RESERVE[2]: reserved |
| 3          | RO          | 0x0                | reserved                                                                                                                     |
| 2:0        | RW          | 0x0                | D2A_DIG_LDO_VREF<br>Calibrate LDO output voltage for rtc digital.                                                            |

**RTC ANALOG EN**

Address: Operational Base + offset (0x007C)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | D2A_CLK_OUT_EN<br>XO clock output enable bit.<br>0: Disable<br>1: Enable.<br>configure d2a_clk_out_en 1'b1 after d2a_xo_en, about 500ms. |
| 4          | RW          | 0x0                | D2A_BAT_DET_EN<br>battery voltage detect enable bit.<br>0: Disable<br>1: Enable.                                                         |
| 3:2        | RW          | 0x0                | D2A_VDET_CUR_SEL<br>Reserved                                                                                                             |
| 1          | RW          | 0x0                | D2A_POR_REF_SEL<br>Reserved                                                                                                              |
| 0          | RW          | 0x0                | D2A_CLK_BYPS_EN<br>32K clock input from XIN pin.<br>0: Disable<br>1: Enable.                                                             |

**RTC CLK32K TEST**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                |
| 0          | RW          | 0x0                | CLK_TEST_EN<br>32k clock output enable bit.<br>0: Disable<br>1: Enable. |

**RTC TEST ST**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                         |
| 2          | RO          | 0x0                | TEST_DONE<br>32K clock test status.<br>0: Test idle or in test.<br>1: Test done. |
| 1          | RO          | 0x0                | TEST_START_ST<br>Test clk32k status.<br>0: Idle<br>1: In test.                   |
| 0          | RW          | 0x0                | TEST_START<br>Test clk32k start.<br>0: Stop<br>1: Start.                         |

**RTC TEST LEN**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                       |
|------------|-------------|--------------------|------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                 |
| 7:0        | RW          | 0x00               | TEST_LENGTH<br>Test length, unit second. |

**RTC CNT 0**

Address: Operational Base + offset (0x008C)

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

| Bit | Attr | Reset Value | Description                |
|-----|------|-------------|----------------------------|
| 7:0 | RW   | 0x00        | CLK24M_CNT_0<br>Count[7:0] |

**RTC CNT 1**

Address: Operational Base + offset (0x0090)

| Bit  | Attr | Reset Value | Description                 |
|------|------|-------------|-----------------------------|
| 31:8 | RO   | 0x000000    | reserved                    |
| 7:0  | RW   | 0x00        | CLK24M_CNT_1<br>Count[15:8] |

**RTC CNT 2**

Address: Operational Base + offset (0x0094)

| Bit  | Attr | Reset Value | Description                  |
|------|------|-------------|------------------------------|
| 31:8 | RO   | 0x000000    | reserved                     |
| 7:0  | RW   | 0x00        | CLK24M_CNT_2<br>Count[23:16] |

**RTC CNT 3**

Address: Operational Base + offset (0x0098)

| Bit  | Attr | Reset Value | Description                  |
|------|------|-------------|------------------------------|
| 31:8 | RO   | 0x000000    | reserved                     |
| 7:0  | RW   | 0x00        | CLK24M_CNT_3<br>Count[31:24] |

**24.5 Interface Description**

Table 24-1 RTC Interface Description

| Pin Name       | Direction | Description                                      |
|----------------|-----------|--------------------------------------------------|
| pclk           | input     | APB2.0, use the common bus signal with rtc_test. |
| psel           | input     | APB2.0, use the common bus signal with rtc_test. |
| penable        | input     | APB2.0, use the common bus signal with rtc_test. |
| pwrite         | input     | APB2.0, use the common bus signal with rtc_test. |
| paddr[7:0]     | input     | APB2.0, use the common bus signal with rtc_test. |
| pwdata[7:0]    | input     | APB2.0, use the common bus signal with rtc_test. |
| prdata[7:0]    | output    | APB2.0, To rtc_test block.                       |
| clk24M         | input     | 24M clock.                                       |
| clk_32k_o      | output    | 32k clock output.                                |
| clk_32k_H      | output    | 32k clock output.                                |
| rtc_intr       | output    | High active, interrupt from RTC.                 |
| dig_ldo_rdy_o  | output    | High active.                                     |
| external_off_o | output    | Low active, used to iso cell enable.             |

**24.6 Application Notes**

- 1) APB configuration operation:  
pwdata[31:8] == 24'hc45229, pwdata[7:0] store the configure value.
- 2) If enable AMPM mode, AMPM mode need set before real time set.
- 3) If update real time, need stop RTC first, and then set real time registers and start RTC.
- 4) Rtc work sequence:  
Wait ldo rdy;  
APB cfg D2A\_XO\_EN: 0x6c[0] = 1  
Wait 200ms for xo 32k clock stable;  
APB cfg D2A\_CLK\_OUT\_EN: 0x7c[5] = 1

APB cfg real time: 0x00~0x1c;  
APB cfg alarm time: 0x20~0x38;  
APB cfg interrupt enable: 0x48, 0x4c;  
APB cfg millisecond register: 0x50, 0x54;  
APB cfg compensation register: 0x58, 0x5c, 0x60;  
Set START\_RTC, 0x3c[0] = 1  
Read RUN\_ST, 0x44[0], check rtc status.

- 5) Read time: Read time from: 0x00~0x1c

Due to shadow registers delete, read time maybe not all right, need read at least three times: time0, time1, time2(need in 1 second).

If time0, time1, time2 all different, the right time is the time2;

If time0, time1, time2 have two or three the same, the right time is the same time.

- 6) Stop RTC: APB cfg 0x3c[0]=0; read RUN\_ST check RTC stop.

Rockchip Confidential

## Chapter 25 DECOM

### 25.1 Overview

DECOM can decompress compressed files in GZIP, DEFLATE and ZLIB formats. DECOM controller supports the following features:

- Support for decompressing GZIP files
- Support for decompressing data in DEFLATE format
- Support for decompressing data in ZLIB format
- Not support for decompressing LZ4 files
- There is a 32bit APB slave interface for configuring decompression parameters and querying register status
- There is a 128-bit AXI master interface for reading compressed data and outputting decompressed data. The AXI master interface supports burst 4/8/16 and single transmissions
- Support one internal 128-bit wide and 64-location deep FIFO(RX\_FIFO) for caching source compressed data
- Support one internal 24-bit wide and 64-location deep FIFO(HF\_FIFO) for caching intermediate data during decompression
- Built-in a 8KB two-port RAM for storing decompressed data
- Support complete interrupt and error interrupt output
- Support the limit\_size function of the decompressed data to prevent the memory from being maliciously destroyed during the decompression process
- Support software to stop the decompression process

### 25.2 Block Diagram



Fig. 25-1 DECOM Block Diagram

### 25.3 Function Description

#### 25.3.1 Module Introduction

##### 25.3.1.1 APB INTERFACE

The APB slave interface is used for registers configuration, decompression file parameter reading and interrupt status query, etc.

##### 25.3.1.2 AXI MASTER INTERFACE

The AXI master interface is used to read compressed file data from external storage into the RX\_FIFO and output the decompressed data to external storage.

### **25.3.1.3 RX\_FIFO**

The RX\_FIFO is used to buffer the source compressed file data read back through the AXI master interface. The RX\_FIFO is an asynchronous FIFO, the write interface uses aclk, and the read interface uses dclk.

### **25.3.1.4 Data Bag**

The Data Bag reads and bites the data in the RX\_FIFO, and extracts the corresponding number of bits according to the needs of the decompression module.

### **25.3.1.5 GZIP\_ZLIB**

The GZIP\_ZLIB module is used to perform file header and file end parsing for compressed files in GZIP format and compressed data in ZLIB format, and the compressed data portion is decompressed by the INFLATE module. The GZIP or ZLIB decompression mode can be configured by configuring the CTRL register.

### **25.3.1.6 INFLATE Module**

INFLATE Module is used to decompress compressed files in DEFLATE format, implement static/dynamic huffman decoding, decompress compressed data in DEFLATE format into LZ77 format (match length-match distance) data pairs or character data, and store them in HF\_FIFO.

### **25.3.1.7 HF\_FIFO**

The HF\_FIFO is used to buffer the LZ77 format (match length-match distance) data pair or character data decompressed by the INFLATE module, and wait for the UNLZ77 module to further decompress the intermediate data. The HF\_FIFO is an asynchronous FIFO, the write interface uses dclk, and the read interface uses aclk.

### **25.3.1.8 UNLZ77 Module**

UNLZ77 is used to implement LZ77 decoding and store the decompressed data in 8K RAM. When the matching distance is less than 8k byte, matching replication is performed in 8K RAM. When the matching distance is greater than 8k byte, the AXI master interface is controlled to perform matching replication in the external storage.

### **25.3.1.9 8K-RAM**

The 8K RAM is used to buffer the decompressed data. During the decompression process, the UNLZ77 module also performs read access to the RAM to complete the data matching.

### **25.3.1.10 Interface and Clock**

The 32-bit APB Slave interface in DECOM is used for register configuration and interrupt status query interface, using pclk as the interface clock.

DECOM uses 128bit AXI master interface to realize the functions of reading the data to be compressed, decompressing the data output and reading external matching data; it should be noted that the AXI master interface supports Single and Burst transmission, which only supports incr4, incr8 and Incr16 three transmission types, does not support Wrap transmission. DECOM automatically configures the burst type according to the length of the transmitted data and the starting address. The software configuration is not supported to select the burst type.

DECOM has three sets of clock and reset inputs, pclk and presetn, dclk and drstn, aclk and aresetn. Among them pclk and aclk are APB and AXI bus clocks respectively, and dclk is decompression clock.

### 25.3.2 Data Flow



Fig. 25-2 DECOM Data Flow

### 25.4 Register Description

#### 25.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

#### 25.4.2 Registers Summary

| Name           | Offset | Size | Reset Value | Description                              |
|----------------|--------|------|-------------|------------------------------------------|
| DECOM_CTRL     | 0x0000 | W    | 0x00000000  | Control Register                         |
| DECOM_ENR      | 0x0004 | W    | 0x00000000  | Enable Register                          |
| DECOM_RADDR    | 0x0008 | W    | 0x00000000  | Read Address                             |
| DECOM_WADDR    | 0x000C | W    | 0x00000000  | Write Address                            |
| DECOM_UDDSL    | 0x0010 | W    | 0xFFFFFFFF  | Undecompressed Data Size                 |
| DECOM_UDDSH    | 0x0014 | W    | 0xFFFFFFFF  | Undecompressed Data Size                 |
| DECOM_TXTHR    | 0x0018 | W    | 0x00000100  | Transmit Threshold Level                 |
| DECOM_SLEN     | 0x0020 | W    | 0x00000000  | INFLATE Store Length                     |
| DECOM_STAT     | 0x0024 | W    | 0x00000000  | DECOM Status Register                    |
| DECOM_ISR      | 0x0028 | W    | 0x00000000  | Interrupt Status Register                |
| DECOM_IEN      | 0x002C | W    | 0x00000000  | Interrupt Enable Register                |
| DECOM_AXI_STAT | 0x0030 | W    | 0x00000010  | AXI Master Interface State               |
| DECOM_TSIZEL   | 0x0034 | W    | 0x00000000  | Decompressed Data Total Size Lower 32bit |
| DECOM_TSIZEH   | 0x0038 | W    | 0x00000000  | Decompressed Data Total Size Upper 32bit |
| DECOM_MGNUM    | 0x003C | W    | 0x00000000  | LZ4 File Magic Number                    |
| DECOM_FRAME    | 0x0040 | W    | 0x00000000  | LZ4 File Frame Descriptor                |
| DECOM_DICTID   | 0x0044 | W    | 0x00000000  | Dictionary ID                            |
| DECOM_CSL      | 0x0048 | W    | 0x00000000  | LZ4 Content Size(CS) Lower 32-bits       |
| DECOM_CSH      | 0x004C | W    | 0x00000000  | LZ4 Content Size(CS) Upper 32-bits       |
| DECOM_LMTSL    | 0x0050 | W    | 0xFFFFFFFF  | Limit Size of Decompressed Data          |
| DECOM_LMTSH    | 0x0054 | W    | 0xFFFFFFFF  | Limit Size of Decompressed Data          |
| DECOM_GZFHD    | 0x0058 | W    | 0x00000000  | GZIP/ZLIB File Header Information        |
| DECOM_VERSION  | 0x00F0 | W    | 0x20211216  | DECOM Version Number                     |

Notes:  
**B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**-Double WORD (64 bits) access

### 25.4.3 Detail Registers Description

#### DECOM CTRL

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5    | RW   | 0x0         | ZLIBM<br>ZLIB mode.<br>1'b0: Disable<br>1'b1: Enable<br>When decompressing ZLIB compressed data, ZLIBM must be enabled and DEM should be set to 1.                                                                                                                                                                                                                                                                                                                                                          |
| 4    | RW   | 0x0         | GZIPM<br>GZIP mode.<br>1'b0: Disable<br>1'b1: Enable<br>When decompressing GZIP files, GZIPM must be enabled and DEM should be set to 1.                                                                                                                                                                                                                                                                                                                                                                    |
| 3    | RW   | 0x0         | CCEN<br>LZ4 content checksum check enable.<br>1'b0: Disable<br>1'b1: Enable<br>In LZ4 files, a 32-bits content checksum will be appended at the end of the file. When CCEN is enabled, DECOM will verify the content checksum to check if the decompressed data is correct. Only valid when decompressing LZ4 files.                                                                                                                                                                                        |
| 2    | RW   | 0x0         | BCEN<br>LZ4 block checksum check enable. Not used.<br>1'b0: Disable<br>1'b1: Enable<br>In LZ4 files, each data block will be followed by a 4-bytes checksum, calculated by using the xxHash-32 algorithm on the compressed data block. The intention is to detect data corruption(storage or transmission errors) immediately, before decoding. When BCEN is enabled, DECOM will check the block checksum to determine if the block to be decompressed is correct. Only valid when decompressing LZ4 files. |
| 1    | RW   | 0x0         | HCEN<br>LZ4 header checksum check enable. Not used.<br>1'b0: Disable<br>1'b1: Enable<br>The LZ4 header contains a 1-byte xxh32 checksum value(HC). When HCEN is enabled, DECOM will check the HC to check if the header is correct. Only valid when decompressing LZ4 files.                                                                                                                                                                                                                                |
| 0    | RW   | 0x0         | DEM<br>DECOM mode select.<br>1'b0: UNLZ4 mode. Decompress the file in LZ4 format.<br>1'b1: INFLATE mode. Decompress the file in INFLATE format. If GZIPM=1'b1 or GZLIBM=1'b1, DEM must be set 1.                                                                                                                                                                                                                                                                                                            |

#### DECOM ENR

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:1 | RO   | 0x00000000  | reserved    |

| Bit | Attr   | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                             |
|-----|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | R/W SC | 0x0         | <p>ENR</p> <p>Enables and disables all decompress operations.</p> <p>1'b0: Disable decompressor</p> <p>1'b1: Enable decompressor to work</p> <p>All FIFO buffers and aclk/dclk domain work registers are cleared when the device is disabled. Self clear when decompression is complete.</p> <p>The ENR should be enabled after the other registers are configured.</p> |

**DECOM\_RADDR**

Address: Operational Base + offset (0x0008)

| Bit  | Attr | Reset Value | Description                                                                                                                      |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>RADDR</p> <p>Read address.</p> <p>This register is used to configure the starting address of the file to be decompressed.</p> |

**DECOM\_WADDR**

Address: Operational Base + offset (0x000C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>WADDR</p> <p>Write address.</p> <p>This register is used to configure the starting address of the location where the decompressed data is written.</p> <p>Note: WADDR[31:0] must be configured with a 128bit aligned address (WADDR[3:0]==4'b0).</p> |

**DECOM\_UDDSL**

Address: Operational Base + offset (0x0010)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0xffffffff  | <p>UDDSL</p> <p>Undecompressed data size lower 32bits. (Unit:byte)</p> <p>UDDSL[63:0] is the total size of undecompressed file. DECOM will read the compressed file data according to the value of UDDSL[63:0], but the configuration of this register is optional. If this register is not configured, DECOM will use the default value of 64'hffff_ffff_ffff_ffff, and DECOM will keep reading data until the current decompression process ends.</p> |

**DECOM\_UDDSH**

Address: Operational Base + offset (0x0014)

| Bit  | Attr | Reset Value | Description                                                 |
|------|------|-------------|-------------------------------------------------------------|
| 31:0 | RW   | 0xffffffff  | <p>UDDSH</p> <p>Undecompressed data size higher 32bits.</p> |

**DECOM\_TXTHR**

Address: Operational Base + offset (0x0018)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                     |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000100  | <p>TXTHR</p> <p>When the number of 8K_MEM entries is greater than or equal to this value, the DECOM will automatically transfer the data in the 8K_MEM to the external via the AXI Master interface. The value ranges is 0~7680.(Unit:byte)</p> |

**DECOM SLEN**

Address: Operational Base + offset (0x0020)

| Bit  | Attr | Reset Value | Description                                                                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | SLEN<br>INFLATE store block size. (Unit:byte)<br>Indicate the block size when decompressing the store block of INFALTE file. For debugging SLC_ERR. |

**DECOM STAT**

Address: Operational Base + offset (0x0024)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                                                                                                                     |
| 1    | RO   | 0x0         | LAST<br>Used to indicate whether the currently processed compressed data block is the last one.<br>1'b0: Not last block<br>1'b1: Last block                                  |
| 0    | RO   | 0x0         | COMPLETE<br>DECOM complete flag.<br>1'b0: Not complete<br>1'b1: Decompress is complete with no error<br>Only decompress total complete with no error, this flag is set to 1. |

**DECOM ISR**

Address: Operational Base + offset (0x0028)

| Bit   | Attr | Reset Value | Description                                                                                                                          |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                                                                                             |
| 19    | W1C  | 0x0         | DSOLI<br>Decompressed data size over limit_size interrupt.<br>1'b0: Interrupt is not active<br>1'b1: Interrupt is active             |
| 18    | W1C  | 0x0         | ZDICTEI<br>ZLIB dictionary error interrupt.<br>1'b0: Interrupt is not active<br>1'b1: Interrupt is active                            |
| 17    | W1C  | 0x0         | GCMEI<br>GZIP/ZLIB compression method check error interrupt.<br>1'b0: Interrupt is not active<br>1'b1: Interrupt is active           |
| 16    | W1C  | 0x0         | GIDEI<br>GZIP ID error interrupt.<br>1'b0: Interrupt is not active<br>1'b1: Interrupt is active                                      |
| 15    | W1C  | 0x0         | CCCEI<br>UNLZ4 content checksum check error interrupt.<br>1'b0: ccc_err interrupt is not active<br>1'b1: ccc_err interrupt is active |
| 14    | W1C  | 0x0         | BCCEI<br>UNLZ4 block checksum check error interrupt.<br>1'b0: bcc_err interrupt is not active<br>1'b1: bcc_err interrupt is active   |
| 13    | W1C  | 0x0         | HCCEI<br>UNLZ4 header checksum check error interrupt.<br>1'b0: hcc_err interrupt is not active<br>1'b1: hcc_err interrupt is active  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | W1<br>C     | 0x0                | CSEI<br>UNLZ4 content size (or GZIP isize) error interrupt.<br>1'b0: cs_err interrupt is not active<br>1'b1: cs_err interrupt is active                                                                                                                                      |
| 11         | W1<br>C     | 0x0                | DICTEI<br>UNLZ4 dictionary error interrupt.<br>1'b0: Interrupt is not active<br>1'b1: Interrupt is active                                                                                                                                                                    |
| 10         | W1<br>C     | 0x0                | VNEI<br>UNLZ4 version number error interrupt.<br>1'b0: vn_err interrupt is not active<br>1'b1: vn_err interrupt is active                                                                                                                                                    |
| 9          | W1<br>C     | 0x0                | MNEI<br>UNLZ4 magic number error interrupt.<br>1'b0: mn_err interrupt is not active<br>1'b1: mn_err interrupt is active                                                                                                                                                      |
| 8          | W1<br>C     | 0x0                | RDCEI<br>AXI read channel error interrupt.<br>1'b0: INFLATE AXI RDC_ERR interrupt is not active<br>1'b1: INFLATE AXI RDC_ERR interrupt is active                                                                                                                             |
| 7          | W1<br>C     | 0x0                | WRCEI<br>AXI write channel error interrupt.<br>1'b0: INFLATE AXI WRC_ERR interrupt is not active<br>1'b1: INFLATE AXI WRC_ERR interrupt is active                                                                                                                            |
| 6          | W1<br>C     | 0x0                | DISEI<br>INFLATE huffman distance error interrupt.<br>1'b0: INFLATE HFDIS_ERR interrupt is not active<br>1'b1: INFLATE HFDIS_ERR interrupt is active                                                                                                                         |
| 5          | W1<br>C     | 0x0                | LENEI<br>INFLATE huffman length error interrupt.<br>1'b0: INFLATE HFLEN_ERR interrupt is not active<br>1'b1: INFLATE HFLEN_ERR interrupt is active                                                                                                                           |
| 4          | W1<br>C     | 0x0                | LITEI<br>INFLATE huffman literal error interrupt.<br>1'b0: INFLATE HFLIT_ERR interrupt is not active<br>1'b1: INFLATE HFLIT_ERR interrupt is active                                                                                                                          |
| 3          | W1<br>C     | 0x0                | SQMEI<br>INFLATE SQ match error interrupt.<br>1'b0: INFLATE SQM_ERR interrupt is not active<br>1'b1: INFLATE SQM_ERR interrupt is active                                                                                                                                     |
| 2          | W1<br>C     | 0x0                | SLCEI<br>INFLATE store block length check error interrupt.<br>1'b0: INFLATE SLC_ERR interrupt is not active<br>1'b1: INFLATE SLC_ERR interrupt is active                                                                                                                     |
| 1          | W1<br>C     | 0x0                | HDEI<br>INFLATE file header error interrupt.<br>1'b0: INFLATE header error interrupt is not active<br>1'b1: INFLATE header error interrupt is active                                                                                                                         |
| 0          | W1<br>C     | 0x0                | DSI<br>DECOM stop interrupt.<br>1'b0: Decompression stop interrupt is not active<br>1'b1: Decompression stop interrupt is active<br>This interrupt indicates that DECOM has stopped working.<br>Including decompression completion or decompression<br>encountered an error. |

**DECOM IEN**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                              |
| 19         | RW          | 0x0                | DSOLIEN<br>Decompressed data size over limit_size interrupt enable.<br>1'b0: Disable<br>1'b1: Enable  |
| 18         | RW          | 0x0                | ZDICTEIEN<br>ZLIB dictionary error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                 |
| 17         | RW          | 0x0                | GCMEIEN<br>GZIP/ZLIB compression method error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable      |
| 16         | RW          | 0x0                | GIDEIEN<br>GZIP ID error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                           |
| 15         | RW          | 0x0                | CCCEIEN<br>UNLZ4 content checksum check error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable      |
| 14         | RW          | 0x0                | BCCEIEN<br>UNLZ4 block checksum check error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable        |
| 13         | RW          | 0x0                | HCCEIEN<br>UNLZ4 header checksum check error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable       |
| 12         | RW          | 0x0                | CSEIEN<br>UNLZ4 content size (or GZIP isize) error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable |
| 11         | RW          | 0x0                | DICTEIEN<br>UNLZ4 dictionary error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                 |
| 10         | RW          | 0x0                | VNEIEN<br>UNLZ4 version number error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable               |
| 9          | RW          | 0x0                | WNEIEN<br>UNLZ4 magic number error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                 |
| 8          | RW          | 0x0                | RDCEIEN<br>AXI read channel error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                  |
| 7          | RW          | 0x0                | WRCEIEN<br>AXI write channel error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | DISEIEN<br>INFLATE huffman distance error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable        |
| 5          | RW          | 0x0                | LENEIEN<br>INFLATE huffman length error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable          |
| 4          | RW          | 0x0                | LITEIEN<br>INFLATE huffman literal error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable         |
| 3          | RW          | 0x0                | SQMEIEN<br>INFLATE SQ match error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                |
| 2          | RW          | 0x0                | SLCIEN<br>INFLATE store block length check error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | HDEIEN<br>INFLATE file header error interrupt enable.<br>1'b0: Disable<br>1'b1: Enable              |
| 0          | RW          | 0x0                | DSIEN<br>DECOM stop interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                              |

**DECOM AXI STAT**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4          | RO          | 0x1                | AXI_IDLE<br>AXI master idle state register.<br>1'b0: AXI master is busy<br>1'b1: AXI master is idle<br><br>When the decompression is aborted, DECOM will wait for AXI master's current read/write transfer to complete, that is, wait for AXI_IDLE=1, then reset DECOM, otherwise the uncompleted AXI transmission will cause AXI bus exception.<br>It should be noted that after the decompression is abnormal, the AXI master's unfinished write operation will continue, but the output value of wstrb[15:0] will become 16'b0. |
| 3:2        | RO          | 0x0                | RRESP<br>AXI read channel response state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1:0        | RO          | 0x0                | BRESP<br>AXI write channel response state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

**DECOM TSIZEL**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TSIZEL<br>The total size of the data after decompression.<br>TSIZE[63:0]. (Unit:byte) |

**DECOM\_TSIZEH**

Address: Operational Base + offset (0x0038)

| Bit  | Attr | Reset Value | Description                                               |
|------|------|-------------|-----------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | TSIZEH<br>The total size of the data after decompression. |

**DECOM\_MGNUM**

Address: Operational Base + offset (0x003C)

| Bit  | Attr | Reset Value | Description                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | MGNUM<br>Magic number of LZ4 is 0x184D2204.<br>If the MGNUM is not 0x184D2204, a magic number error(mn_err) will be generated. And DECOM will stop decompressing. |

**DECOM\_FRAME**

Address: Operational Base + offset (0x0040)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 23:16 | RO   | 0x00        | HCC<br>Header checksum byte.<br>One-byte checksum of combined descriptor fields, including optional ones. The value is the second byte of xxh32() using zero as a seed, and the full frame descriptor as an input (including optional fields when they are present). A wrong checksum indicates an error in the descriptor. Header checksum is informational and can be skipped.<br>The header checksum check function can be enabled by controlling the HCEN enable signal in the CTRL register. After being turned on, DECOM calculates the hash32 check value based on the data of the frame descriptor part of the LZ4 compressed file, and performs the header checksum byte in the file. In contrast, if they are not equal, an HCC error will be generated and an interrupt will be generated. |
| 15:8  | RO   | 0x00        | BD<br>BD byte.<br>Including Block Maximum Size information. This information is useful to help the decoder allocate memory. Size here refers to the original(uncompressed) data size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7:6   | RO   | 0x0         | VN_NUM<br>Version number.<br>2-bits field, must be set to 2'b01. Any other value cannot be decoded by this version of the specification. If the version number is error, Version number error(VNE) will be generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5     | RO   | 0x0         | BCC_FLG<br>Block checksum flag.<br>If this flag is set, each data block will be followed by a 4-bytes checksum, calculated by using the xxHash-32 algorithm on the raw (compressed) data block. The intention is to detect data corruption (storage or transmission errors) immediately, before decoding. Block checksum usage is optional.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | BIND_FLG<br>Block independence flag.<br>If this flag is set to "1", blocks are independent. If this flag is set to "0", each block depends on previous ones (up to LZ4 window size, which is 64 KB). In such case, it's necessary to decode all blocks in sequence. Block dependency improves compression ratio, especially for small blocks. On the other hand, it makes random access or multi-threaded decoding impossible. For debugging. |
| 3          | RO          | 0x0                | CS_FLG<br>Content size flag.<br>If this flag is set, the uncompressed size of data included within the frame will be present as an 8 bytes unsigned little endian value, after the flags. Content size usage is optional.                                                                                                                                                                                                                     |
| 2          | RO          | 0x0                | CCC_FLG<br>Content checksum flag.<br>If this flag is set, a 32-bits content checksum will be appended after the EndMark.                                                                                                                                                                                                                                                                                                                      |
| 1          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0          | RO          | 0x0                | DICT_FLG<br>Dictionary ID flag.<br>If this flag is set, a 4-bytes Dict-ID field will be present, after the descriptor flags and the Content Size. If this flag is set, Dictionary ID error will be generated. DECOM will stop decompressing.                                                                                                                                                                                                  |

**DECOM\_DICTID**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | DICTID<br>Dictionary ID in the compressed file header.<br>Dictionary ID is only present if the DID_FLG is set. It works as a kind of "known prefix" which is used by both the compressor and the decompressor to "warm-up" reference tables. |

**DECOM\_CSL**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | CSL<br>Content size(CS) lower 32-bits. (Unit:byte)<br>CS[63:0] is the original(uncompressed) size. This information is optional in LZ4 file header, and only present if CS_FLG is set.<br>CS[63:0]={CSH, CSL}; |

**DECOM\_CSH**

Address: Operational Base + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                               |
| 0          | RO          | 0x0                | CSH<br>Content size(CS) upper 32-bits. |

**DECOM\_LMTSL**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0xffffffff         | LMTSL<br>Limit size of decompressed data lower 32bits. (Unit:byte)<br>When the amount of decompressed data is greater than the LMTS, DSOLI interrupt is generated and the decompression process is stopped. |

**DECOM\_LMTSH**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:0       | RW          | 0xffffffff         | LMTSH<br>Limit size of decompressed data higher 32bits. |

**DECOM\_GZFHD**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                        |
| 0          | RO          | 0x0                | GZFHD<br>GZIP/ZLIB file header information.<br>When GZIPM = 1, GZFHD is GZIP file header information.<br>When ZLIBM = 1, GZFHD is ZLIB file header information. |

**DECOM\_VERSION**

Address: Operational Base + offset (0x00F0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:0       | RO          | 0x00000926         | VERSION<br>Version number = 32'h2021_1216. |

**25.5 Application Notes**

- After configuring the decompression mode and other decompression parameters, configure the decompression enable register ENR
- When the decompression is not completed, setting ENR from 1 to 0 will force the decompression process to stop and DECOM will return to the IDLE state. Need to reconfigure and enable DECOM to start the next decompression
- When an error is encountered in the decompression, DECOM will immediately stop the decompression process, set the relevant status register, and generate the corresponding interrupt
- After the decompression process is stopped, ENR will automatically change to 0
- After the decompression process is stopped, DSI will be set to 1. If DSien is 1, an interrupt will be generated; if DSien is 0, no interrupt will be generated
- After the decompression process is stopped, COMPLETE (STAT[0]) is not set to 1 if there is an error in the decompression process; COMPLETE is set to 1 only when the decompression is complete and there are no errors

## Chapter 26 Video Capture (VICAP)

### 26.1 Overview

The Video Capture, receives the data from Camera via DVP/MIPI/LVDS, and transfers the data into system main memory by AXI bus.

- Support BT601 YCbCr 422 8bit input, RAW 8/10/12bit input
- Support BT656 YCbCr 422 8bit progressive/interlace input
- Support BT1120 YCbCr 422 16bit progressive/interlace input, single/dual-edge sampling
- Support YUYV sequence configurable
- Support the polarity of hsync and vsync configurable
- Support receiving two interfaces of MIPI CSI/MIPI DSI/LVDS, up to four IDs for each interface
- Support five CSI data formats: RAW8/10/12/14, YUV422
- Support three modes of MIPI CSI HDR: virtual channel mode, identification code mode, line counter mode
- Support four LVDS data formats: RAW8/10/12, YUV422
- Support reducing frame rate
- Support window cropping
- Support RAW data through to ISP
- Support 8/16/32 times down-sampling for RAW data
- Support virtual stride when write to DDR
- Support NV16/NV12/YUV400/YUYV output format for YUV data
- Support compact/non-compact output format for RAW data
- Support DMA burst gather
- Support soft reset, auto-reset when DMA error.

### 26.2 Block Diagram



Fig. 26-1 VICAP Block Diagram

#### VICAP comprises with:

- AHB Slave
- AXI Master
- INTERFACE
- CROP
- SCALE
- TOISP
- DMA

## 26.3 Function Description

### 26.3.1 Interface

Translate the input video data(DVP/MIPI CSI/LVDS) into the requisite data format

- DVP BT656/BT1120 format



Fig. 26-2 BT656/BT1120 interlace timing relationship



Fig. 26-3 BT656/BT1120 progressive timing relationship

- DVP BT601 format



Fig. 26-4 BT656/BT1120 timing relationship

- MIPI CSI RAW8 format



Fig. 26-5 MIPI CSI RAW8 format

- MIPI CSI RAW10 format



Fig. 26-6 MIPI CSI RAW10 format

- MIPI CSI RAW12 format



Fig. 26-7 MIPI CSI RAW12 format

- MIPI CSI RAW14 format



Fig. 26-8 MIPI CSI RAW14 format

- MIPI CSI YUV422 format



Fig. 26-9 MIPI CSI YUV422 format

- LVDS RAW8 format



Fig. 26-10 LVDS RAW8 format

- LVDS RAW10 format



Fig. 26-11 LVDS RAW10 format

- LVDS RAW12 format



Fig. 26-12 LVDS RAW12 format

### 26.3.2 Crop

Bypass or crop the source video data to a smaller size destination.



Fig. 26-13 Crop

### 26.3.3 Scale

Scale down for RAW data .



Fig. 26-14 8 times Scale down

### 26.3.4 Toisp

The parsed video data can go straight to ISP for real-time processing.

### 26.3.5 DMA

The DMA is used to transfer the data from crop module to the AXI master block which will send the data to the AXI bus.

- NV16



Fig. 26-15 NV16

- NV12



Fig. 26-16 NV12

- YUV400



Fig. 26-17 YUV400

- YUYV



Fig. 26-18 YUYV

- Compact RAW



Fig. 26-19 Compact RAW12

- Noncompact RAW



Fig. 26-20 Noncompact RAW12(high align)

### 26.3.6 AXI Master

Transmit the data to chip memory via the AXI Master.

### 26.3.7 AHB Slave

Host configure the registers via the AHB Slave.

## 26.4 Register Description

### 26.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

Table 26-1 VICAP Address Mapping

| Base Address[11:8] | Device     | Address Length | Offset Address Range |
|--------------------|------------|----------------|----------------------|
| 4'b0000            | Global/DVP | 256 BYTE       | 0x0000 ~ 0x00ff      |
| 4'b0001            | MIPI/LVDS0 | 512 BYTE       | 0x0100 ~ 0x02ff      |

| Base Address[11:8] | Device      | Address Length | Offset Address Range |
|--------------------|-------------|----------------|----------------------|
| 4'b0011            | MIPI/LVDS1  | 512 BYTE       | 0x0300 ~ 0x04ff      |
| 4'b0111            | Scale/TOISP | 256 BYTE       | 0x0700 ~ 0x07ff      |

## 26.4.2 Registers Summary

| Name                        | Offset | Size | Reset Value | Description                                     |
|-----------------------------|--------|------|-------------|-------------------------------------------------|
| VICAP GLB CTRL              | 0x0000 | W    | 0x00011C01  | VICAP global control                            |
| VICAP GLB INTEN             | 0x0004 | W    | 0x00000000  | VICAP global interrupt enable.                  |
| VICAP GLB INTST             | 0x0008 | W    | 0x00000000  | VICAP global interrupt status.                  |
| VICAP DVP CTRL              | 0x0010 | W    | 0x00000000  | DVP path control                                |
| VICAP DVP INTEN             | 0x0014 | W    | 0x00000000  | DVP path interrupt status                       |
| VICAP DVP INTSTAT           | 0x0018 | W    | 0x00000000  | DVP path interrupt status                       |
| VICAP DVP FORMAT            | 0x001C | W    | 0x00000000  | DVP path format                                 |
| VICAP DVP SAV EAV           | 0x0024 | W    | 0xFEDCBA98  | SAV/EAV for ACT/BLK                             |
| VICAP DVP CROP SIZE         | 0x0028 | W    | 0x01E002D0  | The expected width and height of received image |
| VICAP DVP CROP START        | 0x002C | W    | 0x00000000  | The start point of DVP path cropping            |
| VICAP DVP FRM0 ADDR Y_ID0   | 0x0030 | W    | 0x00000000  | DVP path frame0 y address                       |
| VICAP DVP FRM0 ADDR UV_ID0  | 0x0034 | W    | 0x00000000  | DVP path frame0 uv address                      |
| VICAP DVP FRM1 ADDR Y_ID0   | 0x0038 | W    | 0x00000000  | DVP path frame1 y address                       |
| VICAP DVP FRM1 ADDR UV_ID0  | 0x003C | W    | 0x00000000  | DVP path frame1 uv address                      |
| VICAP DVP VIR LINE WIDTH    | 0x0070 | W    | 0x00000000  | DVP path virtual line width                     |
| VICAP DVP LINE INT NUMBER_1 | 0x0074 | W    | 0x00000040  | DVP path line interrupt number                  |
| VICAP DVP LINE CNT ID_0_1   | 0x007C | W    | 0x00000000  | DVP path line count                             |
| VICAP DVP PIX NUM ID_0      | 0x0084 | W    | 0x00000000  | DVP path ID0 PIXEL NUMBER                       |
| VICAP DVP LINE NUM ID_D0    | 0x0088 | W    | 0x00000000  | DVP path ID0 LINE NUMBER                        |
| VICAP DVP SYNC HEADER       | 0x00A4 | W    | 0x00000000  | DVP SYNC HEADER FOR BT656/BT1120                |
| VICAP MIPIO ID0 CTRL0       | 0x0100 | W    | 0x00000000  | MIPIO path id0 control0                         |
| VICAP MIPIO LVDS0 ID0 CTRL1 | 0x0104 | W    | 0x00000000  | MIPIO/LVDS0 path id0 control1                   |
| VICAP MIPIO ID1 CTRL0       | 0x0108 | W    | 0x00000000  | MIPIO path id1 control0                         |
| VICAP MIPIO LVDS0 ID1 CTRL1 | 0x010C | W    | 0x00000000  | MIPIO/LVDS0 path id1 control1                   |
| VICAP MIPIO ID2 CTRL0       | 0x0110 | W    | 0x00000000  | MIPIO path id2 control0                         |
| VICAP MIPIO LVDS0 ID2 CTRL1 | 0x0114 | W    | 0x00000000  | MIPIO/LVDS0 path id2 control1                   |
| VICAP MIPIO ID3 CTRL0       | 0x0118 | W    | 0x00000000  | MIPIO path id3 control0                         |
| VICAP MIPIO LVDS0 ID3 CTRL1 | 0x011C | W    | 0x00000000  | MIPIO/LVDS0 path id3 control1                   |
| VICAP MIPIO LVDS0 CTRL      | 0x0120 | W    | 0x00000000  | MIPIO/LVDS0 path control                        |

| Name                                  | Offset | Size | Reset Value | Description                                              |
|---------------------------------------|--------|------|-------------|----------------------------------------------------------|
| VICAP MIPIO LVDS0 FRA ME0 ADDR Y ID0  | 0x0124 | W    | 0x00000000  | First address of even frame for ID0 Y/Raw/RGB path       |
| VICAP MIPIO LVDS0 FRA ME1 ADDR Y ID0  | 0x0128 | W    | 0x00000000  | First address of odd frame for ID0 Y path                |
| VICAP MIPIO LVDS0 FRA ME0 ADDR UV ID0 | 0x012C | W    | 0x00000000  | First address of even frame for ID0 UV path              |
| VICAP MIPIO LVDS0 FRA ME1 ADDR UV ID0 | 0x0130 | W    | 0x00000000  | First address of odd frame for ID0 UV path               |
| VICAP MIPIO LVDS0 VLW ID0             | 0x0134 | W    | 0x00000000  | Virtual line width for ID0                               |
| VICAP MIPIO LVDS0 FRA ME0 ADDR Y ID1  | 0x0138 | W    | 0x00000000  | First address of even frame for ID1 Y/Raw/RGB path       |
| VICAP MIPIO LVDS0 FRA ME1 ADDR Y ID1  | 0x013C | W    | 0x00000000  | First address of odd frame for ID1 Y/Raw/RGB path        |
| VICAP MIPIO LVDS0 FRA ME0 ADDR UV ID1 | 0x0140 | W    | 0x00000000  | First address of even frame for ID1 UV path              |
| VICAP MIPIO LVDS0 FRA ME1 ADDR UV ID1 | 0x0144 | W    | 0x00000000  | First address of odd frame for ID1 UV path               |
| VICAP MIPIO LVDS0 VLW ID1             | 0x0148 | W    | 0x00000000  | Virtual line width of even frame for ID1 path            |
| VICAP MIPIO LVDS0 FRA ME0 ADDR Y ID2  | 0x014C | W    | 0x00000000  | First address of even frame for ID2 Y/Raw/RGB path       |
| VICAP MIPIO LVDS0 FRA ME1 ADDR Y ID2  | 0x0150 | W    | 0x00000000  | First address of odd frame for ID2 Y/Raw/RGB path        |
| VICAP MIPIO LVDS0 FRA ME0 ADDR UV ID2 | 0x0154 | W    | 0x00000000  | First address of even frame for ID2 UV path              |
| VICAP MIPIO LVDS0 FRA ME1 ADDR UV ID2 | 0x0158 | W    | 0x00000000  | First address of odd frame for ID2 UV path               |
| VICAP MIPIO LVDS0 VLW ID2             | 0x015C | W    | 0x00000000  | Virtual line width of even frame for ID2 path            |
| VICAP MIPIO LVDS0 FRA ME0 ADDR Y ID3  | 0x0160 | W    | 0x00000000  | First address of even frame for ID3 Y/Raw/RGB path       |
| VICAP MIPIO LVDS0 FRA ME1 ADDR Y ID3  | 0x0164 | W    | 0x00000000  | First address of odd frame for ID3 Y/Raw/RGB path        |
| VICAP MIPIO LVDS0 FRA ME0 ADDR UV ID3 | 0x0168 | W    | 0x00000000  | First address of even frame for ID3 UV path              |
| VICAP MIPIO LVDS0 FRA ME1 ADDR UV ID3 | 0x016C | W    | 0x00000000  | First address of odd frame for ID3 UV path               |
| VICAP MIPIO LVDS0 VLW ID3             | 0x0170 | W    | 0x00000000  | Virtual line width of even frame for ID3 path            |
| VICAP MIPIO LVDS0 INT EN              | 0x0174 | W    | 0x00000000  | MIPIO/LVDS0 path interrupt enable                        |
| VICAP MIPIO LVDS0 INT STAT            | 0x0178 | W    | 0x00000000  | MIPIO/LVDS0 path interrupt status                        |
| VICAP MIPIO LVDS0 LIN E INT NUM ID0_1 | 0x017C | W    | 0x00400040  | Line number of the MIPIO/LVDS0 path ID0/1 line interrupt |
| VICAP MIPIO LVDS0 LIN E INT NUM ID2_3 | 0x0180 | W    | 0x00400040  | Line number of the MIPIO/LVDS0 path ID2/3 line interrupt |
| VICAP MIPIO LVDS0 LIN E CNT ID0_1     | 0x0184 | W    | 0x00000000  | Line count of the MIPIO/LVDS0 path ID0/1                 |
| VICAP MIPIO LVDS0 LIN E CNT ID2_3     | 0x0188 | W    | 0x00000000  | Line count of the MIPIO/LVDS0 path ID2/3                 |
| VICAP MIPIO LVDS0 ID0 CROP START      | 0x018C | W    | 0x00000000  | The start point of MIPIO/LVDS0 ID0 cropping              |

| Name                             | Offset | Size | Reset Value | Description                                  |
|----------------------------------|--------|------|-------------|----------------------------------------------|
| VICAP MIPIO LVDS0 ID1 CROP START | 0x0190 | W    | 0x000000000 | The start point of MIPIO/LVDS0 ID1 cropping  |
| VICAP MIPIO LVDS0 ID2 CROP START | 0x0194 | W    | 0x000000000 | The start point of MIPIO/LVDS0 ID2 cropping  |
| VICAP MIPIO LVDS0 ID3 CROP START | 0x0198 | W    | 0x000000000 | The start point of MIPIO/LVDS0 ID3 cropping  |
| VICAP MIPIO FRAME NUM VC0        | 0x019C | W    | 0x000000000 | The frame number of virtual channel 0        |
| VICAP MIPIO FRAME NUM VC1        | 0x01A0 | W    | 0x000000000 | The frame number of virtual channel 1        |
| VICAP MIPIO FRAME NUM VC2        | 0x01A4 | W    | 0x000000000 | The frame number of virtual channel 2        |
| VICAP MIPIO FRAME NUM VC3        | 0x01A8 | W    | 0x000000000 | The frame number of virtual channel 3        |
| VICAP MIPIO ID0 EFFECT_CODE      | 0x01AC | W    | 0x000000000 | The effect code of MIPIO ID0                 |
| VICAP MIPIO ID1 EFFECT_CODE      | 0x01B0 | W    | 0x000000000 | The effect code of MIPIO ID1                 |
| VICAP MIPIO ID2 EFFECT_CODE      | 0x01B4 | W    | 0x000000000 | The effect code of MIPIO ID2                 |
| VICAP MIPIO ID3 EFFECT_CODE      | 0x01B8 | W    | 0x000000000 | The effect code of MIPIO ID3                 |
| VICAP MIPIO ON PAD VALUE         | 0x01BC | W    | 0x000000000 | The ON padding value of MIPIO                |
| VICAP MIPIO LVDS0 SIZE_NUM_ID0   | 0x01C0 | W    | 0x000000000 | MIPIO/LVDS0 path ID0 SIZE NUMBER             |
| VICAP MIPIO LVDS0 SIZE_NUM_ID1   | 0x01C4 | W    | 0x000000000 | MIPIO/LVDS0 path ID1 SIZE NUMBER             |
| VICAP MIPIO LVDS0 SIZE_NUM_ID2   | 0x01C8 | W    | 0x000000000 | MIPIO/LVDS0 path ID2 SIZE NUMBER             |
| VICAP MIPIO LVDS0 SIZE_NUM_ID3   | 0x01CC | W    | 0x000000000 | MIPIO/LVDS0 path ID3 SIZE NUMBER             |
| VICAP LVDS0 ID0 CTRL0            | 0x01D0 | W    | 0x000000000 | LVDS0 path id0 control0                      |
| VICAP LVDS0 ID1 CTRL0            | 0x01D4 | W    | 0x000000000 | LVDS0 path id1 control0                      |
| VICAP LVDS0 ID2 CTRL0            | 0x01D8 | W    | 0x000000000 | LVDS0 path id2 control0                      |
| VICAP LVDS0 ID3 CTRL0            | 0x01DC | W    | 0x000000000 | LVDS0 path id3 control0                      |
| VICAP LVDS0 SAV_EAV_ACT0_ID0     | 0x01E0 | W    | 0x000000000 | LVDS0 sync code of SAV_ACT0/EAV_ACT0 for id0 |
| VICAP LVDS0 SAV_EAV_BLK0_ID0     | 0x01E4 | W    | 0x000000000 | LVDS0 sync code of SAV_BLK0/EAV_BLK0 for id0 |
| VICAP LVDS0 SAV_EAV_ACT1_ID0     | 0x01E8 | W    | 0x000000000 | LVDS0 sync code of SAV_ACT1/EAV_ACT1 for id0 |
| VICAP LVDS0 SAV_EAV_BLK1_ID0     | 0x01EC | W    | 0x000000000 | LVDS0 sync code of SAV_BLK1/EAV_BLK1 for id0 |
| VICAP LVDS0 SAV_EAV_ACT0_ID1     | 0x01F0 | W    | 0x000000000 | LVDS0 sync code of SAV_ACT0/EAV_ACT0 for id1 |
| VICAP LVDS0 SAV_EAV_BLK0_ID1     | 0x01F4 | W    | 0x000000000 | LVDS0 sync code of SAV_BLK0/EAV_BLK0 for id1 |
| VICAP LVDS0 SAV_EAV_ACT1_ID1     | 0x01F8 | W    | 0x000000000 | LVDS0 sync code of SAV_ACT1/EAV_ACT1 for id1 |
| VICAP LVDS0 SAV_EAV_BLK1_ID1     | 0x01FC | W    | 0x000000000 | LVDS0 sync code of SAV_BLK1/EAV_BLK1 for id1 |
| VICAP LVDS0 SAV_EAV_ACT0_ID2     | 0x0200 | W    | 0x000000000 | LVDS0 sync code of SAV_ACT0/EAV_ACT0 for id2 |

| Name                                  | Offset | Size | Reset Value | Description                                        |
|---------------------------------------|--------|------|-------------|----------------------------------------------------|
| VICAP_LVDS0_SAV_EAV_BLK0_ID2          | 0x0204 | W    | 0x000000000 | LVDS0 sync code of SAV_BLK0/EAV_BLK0 for id2       |
| VICAP_LVDS0_SAV_EAV_ACT1_ID2          | 0x0208 | W    | 0x000000000 | LVDS0 sync code of SAV_ACT1/EAV_ACT1 for id2       |
| VICAP_LVDS0_SAV_EAV_BLK1_ID2          | 0x020C | W    | 0x000000000 | LVDS0 sync code of SAV_BLK1/EAV_BLK1 for id2       |
| VICAP_LVDS0_SAV_EAV_ACT0_ID3          | 0x0210 | W    | 0x000000000 | LVDS0 sync code of SAV_ACT0/EAV_ACT0 for id3       |
| VICAP_LVDS0_SAV_EAV_BLK0_ID3          | 0x0214 | W    | 0x000000000 | LVDS0 sync code of SAV_BLK0/EAV_BLK0 for id3       |
| VICAP_LVDS0_SAV_EAV_ACT1_ID3          | 0x0218 | W    | 0x000000000 | LVDS0 sync code of SAV_ACT1/EAV_ACT1 for id3       |
| VICAP_LVDS0_SAV_EAV_BLK1_ID3          | 0x021C | W    | 0x000000000 | LVDS0 sync code of SAV_BLK1/EAV_BLK1 for id3       |
| VICAP_MIPI1_ID0_CTRL0                 | 0x0300 | W    | 0x000000000 | MIPI1 path id0 control0                            |
| VICAP_MIPI1_LVDS1_ID0_CTRL1           | 0x0304 | W    | 0x000000000 | MIPI1/LVDS1 path id0 control1                      |
| VICAP_MIPI1_ID1_CTRL0                 | 0x0308 | W    | 0x000000000 | MIPI1 path id1 control0                            |
| VICAP_MIPI1_LVDS1_ID1_CTRL1           | 0x030C | W    | 0x000000000 | MIPI1/LVDS1 path id1 control1                      |
| VICAP_MIPI1_ID2_CTRL0                 | 0x0310 | W    | 0x000000000 | MIPI1 path id2 control0                            |
| VICAP_MIPI1_LVDS1_ID2_CTRL1           | 0x0314 | W    | 0x000000000 | MIPI1/LVDS1 path id2 control1                      |
| VICAP_MIPI1_ID3_CTRL0                 | 0x0318 | W    | 0x000000000 | MIPI1 path id3 control0                            |
| VICAP_MIPI1_LVDS1_ID3_CTRL1           | 0x031C | W    | 0x000000000 | MIPI1/LVDS1 path id3 control1                      |
| VICAP_MIPI1_LVDS1_CTR_L               | 0x0320 | W    | 0x000000000 | MIPI1/LVDS1 path control                           |
| VICAP_MIPI1_LVDS1_FRA_ME0_ADDR_Y_ID0  | 0x0324 | W    | 0x000000000 | First address of even frame for ID0 Y/Raw/RGB path |
| VICAP_MIPI1_LVDS1_FRA_ME1_ADDR_Y_ID0  | 0x0328 | W    | 0x000000000 | First address of odd frame for ID0 Y path          |
| VICAP_MIPI1_LVDS1_FRA_ME0_ADDR_UV_ID0 | 0x032C | W    | 0x000000000 | First address of even frame for ID0 UV path        |
| VICAP_MIPI1_LVDS1_FRA_ME1_ADDR_UV_ID0 | 0x0330 | W    | 0x000000000 | First address of odd frame for ID0 UV path         |
| VICAP_MIPI1_LVDS1_VLW_ID0             | 0x0334 | W    | 0x000000000 | Virtual line width for ID0                         |
| VICAP_MIPI1_LVDS1_FRA_ME0_ADDR_Y_ID1  | 0x0338 | W    | 0x000000000 | First address of even frame for ID1 Y/Raw/RGB path |
| VICAP_MIPI1_LVDS1_FRA_ME1_ADDR_Y_ID1  | 0x033C | W    | 0x000000000 | First address of odd frame for ID1 Y/Raw/RGB path  |
| VICAP_MIPI1_LVDS1_FRA_ME0_ADDR_UV_ID1 | 0x0340 | W    | 0x000000000 | First address of even frame for ID1 UV path        |
| VICAP_MIPI1_LVDS1_FRA_ME1_ADDR_UV_ID1 | 0x0344 | W    | 0x000000000 | First address of odd frame for ID1 UV path         |
| VICAP_MIPI1_LVDS1_VLW_ID1             | 0x0348 | W    | 0x000000000 | Virtual line width of even frame for ID1 path      |
| VICAP_MIPI1_LVDS1_FRA_ME0_ADDR_Y_ID2  | 0x034C | W    | 0x000000000 | First address of even frame for ID2 Y/Raw/RGB path |
| VICAP_MIPI1_LVDS1_FRA_ME1_ADDR_Y_ID2  | 0x0350 | W    | 0x000000000 | First address of odd frame for ID2 Y/Raw/RGB path  |
| VICAP_MIPI1_LVDS1_FRA_ME0_ADDR_UV_ID2 | 0x0354 | W    | 0x000000000 | First address of even frame for ID2 UV path        |

| Name                                  | Offset | Size | Reset Value | Description                                              |
|---------------------------------------|--------|------|-------------|----------------------------------------------------------|
| VICAP MIPI1 LVDS1 FRA ME1 ADDR UV ID2 | 0x0358 | W    | 0x00000000  | First address of odd frame for ID2 UV path               |
| VICAP MIPI1 LVDS1 VLW ID2             | 0x035C | W    | 0x00000000  | Virtual line width of even frame for ID2 path            |
| VICAP MIPI1 LVDS1 FRA ME0 ADDR Y ID3  | 0x0360 | W    | 0x00000000  | First address of even frame for ID3 Y/Raw/RGB path       |
| VICAP MIPI1 LVDS1 FRA ME1 ADDR Y ID3  | 0x0364 | W    | 0x00000000  | First address of odd frame for ID3 Y/Raw/RGB path        |
| VICAP MIPI1 LVDS1 FRA ME0 ADDR UV ID3 | 0x0368 | W    | 0x00000000  | First address of even frame for ID3 UV path              |
| VICAP MIPI1 LVDS1 FRA ME1 ADDR UV ID3 | 0x036C | W    | 0x00000000  | First address of odd frame for ID3 UV path               |
| VICAP MIPI1 LVDS1 VLW ID3             | 0x0370 | W    | 0x00000000  | Virtual line width of even frame for ID3 path            |
| VICAP MIPI1 LVDS1 INT EN              | 0x0374 | W    | 0x00000000  | MIPI1/LVDS1 path interrupt enable                        |
| VICAP MIPI1 LVDS1 INT STAT            | 0x0378 | W    | 0x00000000  | MIPI1/LVDS1 path interrupt status                        |
| VICAP MIPI1 LVDS1 LINE INT NUM ID0_1  | 0x037C | W    | 0x00400040  | Line number of the MIPI1/LVDS1 path ID0/1 line interrupt |
| VICAP MIPI1 LVDS1 LINE INT NUM ID2_3  | 0x0380 | W    | 0x00400040  | Line number of the MIPI1/LVDS1 path ID2/3 line interrupt |
| VICAP MIPI1 LVDS1 LINE CNT ID0_1      | 0x0384 | W    | 0x00000000  | Line count of the MIPI1/LVDS1 path ID0/1                 |
| VICAP MIPI1 LVDS1 LINE CNT ID2_3      | 0x0388 | W    | 0x00000000  | Line count of the MIPI1/LVDS1 path ID2/3                 |
| VICAP MIPI1 LVDS1 ID0 CROP START      | 0x038C | W    | 0x00000000  | The start point of MIPI1/LVDS1 ID0 cropping              |
| VICAP MIPI1 LVDS1 ID1 CROP START      | 0x0390 | W    | 0x00000000  | The start point of MIPI1/LVDS1 ID1 cropping              |
| VICAP MIPI1 LVDS1 ID2 CROP START      | 0x0394 | W    | 0x00000000  | The start point of MIPI1/LVDS1 ID2 cropping              |
| VICAP MIPI1 LVDS1 ID3 CROP START      | 0x0398 | W    | 0x00000000  | The start point of MIPI1/LVDS1 ID3 cropping              |
| VICAP MIPI1 FRAME NUMBER VC0          | 0x039C | W    | 0x00000000  | The frame number of virtual channel 0                    |
| VICAP MIPI1 FRAME NUMBER VC1          | 0x03A0 | W    | 0x00000000  | The frame number of virtual channel 1                    |
| VICAP MIPI1 FRAME NUMBER VC2          | 0x03A4 | W    | 0x00000000  | The frame number of virtual channel 2                    |
| VICAP MIPI1 FRAME NUMBER VC3          | 0x03A8 | W    | 0x00000000  | The frame number of virtual channel 3                    |
| VICAP MIPI1 ID0 EFFECT CODE           | 0x03AC | W    | 0x00000000  | The effect code of MIPI1 ID0                             |
| VICAP MIPI1 ID1 EFFECT CODE           | 0x03B0 | W    | 0x00000000  | The effect code of MIPI1 ID1                             |
| VICAP MIPI1 ID2 EFFECT CODE           | 0x03B4 | W    | 0x00000000  | The effect code of MIPI2 ID2                             |
| VICAP MIPI1 ID3 EFFECT CODE           | 0x03B8 | W    | 0x00000000  | The effect code of MIPI1 ID3                             |
| VICAP MIPI1 ON PAD VALUE              | 0x03BC | W    | 0x00000000  | The ON padding value of MIPI1                            |
| VICAP MIPI1 LVDS1 SIZE NUMBER         | 0x03C0 | W    | 0x00000000  | MIPI1/LVDS1 path ID0 SIZE NUMBER                         |

| Name                           | Offset | Size | Reset Value | Description                                     |
|--------------------------------|--------|------|-------------|-------------------------------------------------|
| VICAP MIPI1 LVDS1 SIZE NUM ID1 | 0x03C4 | W    | 0x00000000  | MIPI1/LVDS1 path ID1 SIZE NUMBER                |
| VICAP MIPI1 LVDS1 SIZE NUM ID2 | 0x03C8 | W    | 0x00000000  | MIPI1/LVDS1 path ID2 SIZE NUMBER                |
| VICAP MIPI1 LVDS1 SIZE NUM ID3 | 0x03CC | W    | 0x00000000  | MIPI1/LVDS1 path ID3 SIZE NUMBER                |
| VICAP LVDS1 ID0_CTRL0          | 0x03D0 | W    | 0x00000000  | LVDS1 path id0 control0                         |
| VICAP LVDS1 ID1_CTRL0          | 0x03D4 | W    | 0x00000000  | LVDS1 path id1 control0                         |
| VICAP LVDS1 ID2_CTRL0          | 0x03D8 | W    | 0x00000000  | LVDS1 path id2 control0                         |
| VICAP LVDS1 ID3_CTRL0          | 0x03DC | W    | 0x00000000  | LVDS1 path id3 control0                         |
| VICAP LVDS1 SAV_EAV_ACT0_ID0   | 0x03E0 | W    | 0x00000000  | LVDS1 sync code of SAV_ACT0/EAV_ACT0 for id0    |
| VICAP LVDS1 SAV_EAV_BLK0_ID0   | 0x03E4 | W    | 0x00000000  | LVDS1 sync code of SAV_BLK0/EAV_BLK0 for id0    |
| VICAP LVDS1 SAV_EAV_ACT1_ID0   | 0x03E8 | W    | 0x00000000  | LVDS1 sync code of SAV_ACT1/EAV_ACT1 for id0    |
| VICAP LVDS1 SAV_EAV_BLK1_ID0   | 0x03EC | W    | 0x00000000  | LVDS1 sync code of SAV_BLK1/EAV_BLK1 for id0    |
| VICAP LVDS1 SAV_EAV_ACT0_ID1   | 0x03F0 | W    | 0x00000000  | LVDS1 sync code of SAV_ACT0/EAV_ACT0 for id1    |
| VICAP LVDS1 SAV_EAV_BLK0_ID1   | 0x03F4 | W    | 0x00000000  | LVDS1 sync code of SAV_BLK0/EAV_BLK0 for id1    |
| VICAP LVDS1 SAV_EAV_ACT1_ID1   | 0x03F8 | W    | 0x00000000  | LVDS1 sync code of SAV_ACT1/EAV_ACT1 for id1    |
| VICAP LVDS1 SAV_EAV_BLK1_ID1   | 0x03FC | W    | 0x00000000  | LVDS1 sync code of SAV_BLK1/EAV_BLK1 for id1    |
| VICAP LVDS1 SAV_EAV_ACT0_ID2   | 0x0400 | W    | 0x00000000  | LVDS1 sync code of SAV_ACT0/EAV_ACT0 for id2    |
| VICAP LVDS1 SAV_EAV_BLK0_ID2   | 0x0404 | W    | 0x00000000  | LVDS1 sync code of SAV_BLK0/EAV_BLK0 for id2    |
| VICAP LVDS1 SAV_EAV_ACT1_ID2   | 0x0408 | W    | 0x00000000  | LVDS1 sync code of SAV_ACT1/EAV_ACT1 for id2    |
| VICAP LVDS1 SAV_EAV_BLK1_ID2   | 0x040C | W    | 0x00000000  | LVDS1 sync code of SAV_BLK1/EAV_BLK1 for id2    |
| VICAP LVDS1 SAV_EAV_ACT0_ID3   | 0x0410 | W    | 0x00000000  | LVDS1 sync code of SAV_ACT0/EAV_ACT0 for id3    |
| VICAP LVDS1 SAV_EAV_BLK0_ID3   | 0x0414 | W    | 0x00000000  | LVDS1 sync code of SAV_BLK0/EAV_BLK0 for id3    |
| VICAP LVDS1 SAV_EAV_ACT1_ID3   | 0x0418 | W    | 0x00000000  | LVDS1 sync code of SAV_ACT1/EAV_ACT1 for id3    |
| VICAP LVDS1 SAV_EAV_BLK1_ID3   | 0x041C | W    | 0x00000000  | LVDS1 sync code of SAV_BLK1/EAV_BLK1 for id3    |
| VICAP SCL_CH_CTRL              | 0x0700 | W    | 0x00000000  | Scale channel0 path control                     |
| VICAP SCL_CTRL                 | 0x0704 | W    | 0x00000000  | MIPI3 path control                              |
| VICAP SCL_FRAME0_ADDR_CH0      | 0x0708 | W    | 0x00000000  | First address of even frame for CH0 path        |
| VICAP SCL_FRAME1_ADDR_CH0      | 0x070C | W    | 0x00000000  | First address of odd frame for CH0 path         |
| VICAP SCL_VLW_CH0              | 0x0710 | W    | 0x00000000  | Virtual line width for CH0                      |
| VICAP SCL_CH0_BLACK_LEVEL      | 0x0738 | W    | 0x00000000  | Scale channel0 black level                      |
| VICAP TOISPO_CH_CTRL           | 0x0780 | W    | 0x00000000  | TOISPO path control                             |
| VICAP TOISPO_CROP_SIZE         | 0x0784 | W    | 0x01E002D0  | The expected width and height of received image |

| Name                    | Offset | Size | Reset Value | Description                             |
|-------------------------|--------|------|-------------|-----------------------------------------|
| VICAP_TOISPO_CROP_START | 0x0788 | W    | 0x00000000  | The start point of toisp0 path cropping |

Notes:Size:**B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**-Double WORD (64 bits) access

### 26.4.3 Detail Registers Description

#### VICAP GLB CTRL

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | RO   | 0x0000      | reserved                                                                                                                                                                                                                            |
| 16    | RW   | 0x1         | ro_axi_idle<br>1'b0: AXI is working<br>1'b1: AXI is idle.                                                                                                                                                                           |
| 15:13 | RO   | 0x0         | reserved                                                                                                                                                                                                                            |
| 12    | RW   | 0x1         | sw_dma_group_mode<br>1'b0: Group 2(2 bursts gather)<br>1'b1: Group 4(4 bursts gather).<br>This bit is valid when sw_dma_group_en=1.                                                                                                 |
| 11    | RW   | 0x1         | sw_dma_adapt_en<br>1'b0: Disable dma self-adapt(dma will transport data according the configured height)<br>1'b1: Enable dma self-adapt(dma will transport data according the actual height).                                       |
| 10    | RW   | 0x1         | sw_dma_group_en<br>1'b0: Disable dma burst group<br>1'b1: Enable dma burst group.                                                                                                                                                   |
| 9     | RW   | 0x0         | sw_infrst_en<br>1'b0: Disable pre-interface reset<br>1'b1: Enable pre-interface reset.                                                                                                                                              |
| 8     | RW   | 0x0         | sw_clk_gating_dis<br>1'b0: Enable the auto clk gating<br>1'b1: Disable the auto clk gating                                                                                                                                          |
| 7     | RO   | 0x0         | reserved                                                                                                                                                                                                                            |
| 6:5   | RW   | 0x0         | sw_soft_rst_mode<br>2'b00: Soft reset and protect toisp path frame integrity;<br>2'b01: Soft reset and protect toisp path frame integrity and pull down sw_cap_en automatically;<br>2'b10: Soft reset directly;<br>2'b11: Reserved. |
| 4     | RW   | 0x0         | sw_soft_rst<br>1'b0: Not reset<br>1'b1: Reset the VICAP(except MMU/AXI MASTER/REG FILE)                                                                                                                                             |
| 3:1   | RO   | 0x0         | reserved                                                                                                                                                                                                                            |
| 0     | RW   | 0x1         | sw_cap_en<br>1'b0: Disable all interface capture<br>1'b1: Enable capture(still depends on sw_xxx_cap_en).                                                                                                                           |

#### VICAP GLB INTEN

Address: Operational Base + offset (0x0004)

| Bit   | Attr | Reset Value | Description                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------|
| 31:27 | RO   | 0x00        | reserved                                                                                                             |
| 26    | RW   | 0x0         | toisp0_fifo_overflow_inten<br>Enable the interrupt of fifo overflow of TOISPO path.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 25:23      | RO          | 0x0                | reserved                                                                                                                         |
| 22         | RW          | 0x0                | frame_end_toisp0_ch2_inten<br>Enable the interrupt of frame end for TOISP0 channel2.<br>1'b0: Disable<br>1'b1: Enable            |
| 21         | RW          | 0x0                | frame_end_toisp0_ch1_inten<br>Enable the interrupt of frame end for TOISP0 channel1.<br>1'b0: Disable<br>1'b1: Enable            |
| 20         | RW          | 0x0                | frame_end_toisp0_ch0_inten<br>Enable the interrupt of frame end for TOISP0 channel0.<br>1'b0: Disable<br>1'b1: Enable            |
| 19:17      | RO          | 0x0                | reserved                                                                                                                         |
| 16         | RW          | 0x0                | frame_start_toisp0_ch2_inten<br>Enable the interrupt of frame start for TOISP0 channel2.<br>1'b0: Disable<br>1'b1: Enable        |
| 15         | RW          | 0x0                | frame_start_toisp0_ch1_inten<br>Enable the interrupt of frame start for TOISP0 channel1.<br>1'b0: Disable<br>1'b1: Enable        |
| 14         | RW          | 0x0                | frame_start_toisp0_ch0_inten<br>Enable the interrupt of frame start for TOISP0 channel0.<br>1'b0: Disable<br>1'b1: Enable        |
| 13:11      | RO          | 0x0                | reserved                                                                                                                         |
| 10         | RW          | 0x0                | dma_fifo_overflow_scl_ch0_inten<br>Enable the interrupt of dma fifo overflow of scale path CH0.<br>1'b0: Disable<br>1'b1: Enable |
| 9:4        | RO          | 0x00               | reserved                                                                                                                         |
| 3          | RW          | 0x0                | frame1_dma_end_scl_ch0_inten<br>Enable the interrupt of end of odd frame for scale CH0.<br>1'b0: Disable<br>1'b1: Enable         |
| 2          | RW          | 0x0                | frame0_dma_end_scl_ch0_inten<br>Enable the interrupt of end of even frame for scale CH0.<br>1'b0: Disable<br>1'b1: Enable        |
| 1          | RO          | 0x0                | reserved                                                                                                                         |
| 0          | RW          | 0x0                | axi0_bus_err_inten<br>Enable the interrupt of axi0 bus error.<br>1'b0: Disable<br>1'b1: Enable                                   |

**VICAP GLB INTST**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                                            |
| 26         | W1<br>C     | 0x0                | toisp0_fifo_overflow_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 25:23      | RO          | 0x0                | reserved                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 22         | W1<br>C     | 0x0                | frame_end_toisp0_ch2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt      |
| 21         | W1<br>C     | 0x0                | frame_end_toisp0_ch1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt      |
| 20         | W1<br>C     | 0x0                | frame_end_toisp0_ch0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt      |
| 19:17      | RO          | 0x0                | reserved                                                                 |
| 16         | W1<br>C     | 0x0                | frame_start_toisp0_ch2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt    |
| 15         | W1<br>C     | 0x0                | frame_start_toisp0_ch1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt    |
| 14         | W1<br>C     | 0x0                | frame_start_toisp0_ch0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt    |
| 13:11      | RO          | 0x0                | reserved                                                                 |
| 10         | W1<br>C     | 0x0                | dma_fifo_overflow_scl_ch0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 9:4        | RO          | 0x00               | reserved                                                                 |
| 3          | W1<br>C     | 0x0                | frame1_dma_end_scl_ch0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt    |
| 2          | W1<br>C     | 0x0                | frame0_dma_end_scl_ch0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt    |
| 1          | RO          | 0x0                | reserved                                                                 |
| 0          | W1<br>C     | 0x0                | axi0_bus_err_intst<br>1'b0: No interrupt<br>1'b1: Interrupt              |

**VICAP DVP CTRL**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                       |
| 23         | RW          | 0x0                | sw_dma_en_id3<br>1'b0: Disable<br>1'b1: Enable |
| 22         | RW          | 0x0                | sw_dma_en_id2<br>1'b0: Disable<br>1'b1: Enable |
| 21         | RW          | 0x0                | sw_dma_en_id1<br>1'b0: Disable<br>1'b1: Enable |
| 20         | RW          | 0x0                | sw_dma_en_id0<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:18      | RW          | 0x0                | sw_soft_RST_mode<br>2'b00: Soft reset and protect toisp path frame integrity;<br>2'b01: Soft reset and protect toisp path frame integrity and pull down sw_cap_en automatically;<br>2'b10: Soft reset directly;<br>2'b11: Reserved. |
| 17         | RW          | 0x0                | sw_soft_RST<br>1'b0: Not reset<br>1'b1: Reset the VICAP DVP path(except MMU/AXI MASTER/REG FILE)                                                                                                                                    |
| 16         | RW          | 0x0                | sw_dma_RST<br>Write 1 will reset VICAP DVP path dma.<br>When this bit change to 0,dma is reseted completely.                                                                                                                        |
| 15:13      | RW          | 0x0                | sw_press_value<br>Press value.                                                                                                                                                                                                      |
| 12         | RW          | 0x0                | sw_press_en<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                        |
| 11:9       | RW          | 0x0                | sw_hurry_value<br>Hurry value.                                                                                                                                                                                                      |
| 8          | RW          | 0x0                | sw_hurry_en<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                        |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                            |
| 6:5        | RW          | 0x0                | sw_water_line<br>2'b00: 75%<br>2'b01: 50%<br>2'b10: 25%<br>2'b11: 0%                                                                                                                                                                |
| 4          | RW          | 0x0                | sw_cap_en_id3<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                      |
| 3          | RW          | 0x0                | sw_cap_en_id2<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                      |
| 2          | RW          | 0x0                | sw_cap_en_id1<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                      |
| 1          | RW          | 0x0                | sw_cap_en_id0<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                      |
| 0          | RW          | 0x0                | sw_cap_en<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                          |

**VICAP DVP INTEN**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:23      | RO          | 0x000              | reserved                                            |
| 22         | RW          | 0x0                | size_err_id0_inten<br>1'b0: Disable<br>1'b1: Enable |
| 21:19      | RO          | 0x0                | reserved                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 18         | RW          | 0x0                | line_id0_inten<br>1'b0: Disable<br>1'b1: Enable                                                                 |
| 17         | RW          | 0x0                | bandwidth_lack_inten<br>Enable the interrupt of bandwidth lack.<br>1'b0: Disable<br>1'b1: Enable                |
| 16         | RW          | 0x0                | dma_fifo_overflow_inten<br>Enable the interrupt of dma fifo overflow .<br>1'b0: Disable<br>1'b1: Enable         |
| 15:10      | RO          | 0x00               | reserved                                                                                                        |
| 9          | RW          | 0x0                | frame1_dma_end_id0_inten<br>Enable the interrupt of end of odd frame for ID0.<br>1'b0: Disable<br>1'b1: Enable  |
| 8          | RW          | 0x0                | frame0_dma_end_id0_inten<br>Enable the interrupt of end of even frame for ID0.<br>1'b0: Disable<br>1'b1: Enable |
| 7:2        | RO          | 0x00               | reserved                                                                                                        |
| 1          | RW          | 0x0                | frame1_start_id0_inten<br>Enable the interrupt of start of odd frame for ID0.<br>1'b0: Disable<br>1'b1: Enable  |
| 0          | RW          | 0x0                | frame0_start_id0_inten<br>Enable the interrupt of start of even frame for ID0.<br>1'b0: Disable<br>1'b1: Enable |

**VICAP DVP INTSTAT**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:23      | RO          | 0x000              | reserved                                                          |
| 22         | W1 C        | 0x0                | size_err_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt       |
| 21:19      | RO          | 0x0                | reserved                                                          |
| 18         | W1 C        | 0x0                | line_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt           |
| 17         | W1 C        | 0x0                | bandwidth_lack_intst<br>1'b0: No interrupt<br>1'b1: Interrupt     |
| 16         | W1 C        | 0x0                | dma_fifo_overflow_intst<br>1'b0: No interrupt<br>1'b1: Interrupt  |
| 15:10      | RO          | 0x00               | reserved                                                          |
| 9          | W1 C        | 0x0                | frame1_dma_end_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 8          | W1 C        | 0x0                | frame0_dma_end_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 7:2        | RO          | 0x00               | reserved                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 1          | W1<br>C     | 0x0                | frame1_start_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 0          | W1<br>C     | 0x0                | frame0_start_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |

**VICAP DVP FORMAT**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                                                                                                                             |
| 21         | RW          | 0x0                | sw_align<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.      |
| 20:19      | RW          | 0x0                | sw_yuv_out_order<br>2'b00: UYVY<br>2'b01: VYUY<br>2'b10: YUYV<br>2'b11: YVYU                                                                                         |
| 18:16      | RW          | 0x0                | sw_wrddr_type<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                             |
| 13         | RW          | 0x0                | sw_only_sav_mode<br>1'b0: Detect SAV and EAV<br>1'b1: Only detect SAV                                                                                                |
| 12         | RW          | 0x0                | sw_yc_swap<br>1'b0: No swap for y and c<br>1'b1: Swap for y and c<br>Only for BT1120 mode.                                                                           |
| 11         | RW          | 0x0                | sw_dualedge_en<br>1'b0: Only use single edge of clock<br>1'b1: Use double edges of clock<br>Only for BT1120 mode.                                                    |
| 10         | RW          | 0x0                | sw_field_order<br>1'b0: Odd field first<br>1'b1: Even field first.                                                                                                   |
| 9          | RW          | 0x0                | sw_interlace_en<br>1'b0: Progress<br>1'b1: Interlace                                                                                                                 |
| 8:7        | RW          | 0x0                | sw_raw_width<br>2'b00: 8bit raw data<br>2'b01: 10bit raw data<br>2'b10: 12bit raw data<br>2'b11: Reserved                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:5        | RW          | 0x0                | sw_yuv_in_order<br>2'b00: UYVY<br>2'b01: VYUY<br>2'b10: YUYV<br>2'b11: YVYU                                                                         |
| 4:2        | RW          | 0x0                | sw_input_mode<br>3'b000: BT601 YUV422<br>3'b001: BT601 RAW<br>3'b010: BT656 YUV422<br>3'b011: BT1120 YUV422<br>3'b100: SONY RAW<br>Others: Reserved |
| 1          | RW          | 0x0                | sw_href_pol<br>1'b0: High active<br>1'b1: Low active                                                                                                |
| 0          | RW          | 0x0                | sw_vsync_pol<br>1'b0: Low active<br>1'b1: High active                                                                                               |

**VICAP\_DVP\_SAV\_EAV**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:28      | RW          | 0xf                | sw_eav_blk1<br>EAV for even field blank.  |
| 27:24      | RW          | 0xe                | sw_sav_blk1<br>SAV for even field blank.  |
| 23:20      | RW          | 0xd                | sw_eav_act1<br>EAV for even field active. |
| 19:16      | RW          | 0xc                | sw_sav_act1<br>SAV for even field active. |
| 15:12      | RW          | 0xb                | sw_eav_blk0<br>EAV for odd field blank.   |
| 11:8       | RW          | 0xa                | sw_sav_blk0<br>SAV for odd field blank.   |
| 7:4        | RW          | 0x9                | sw_eav_act0<br>EAV for odd field active.  |
| 3:0        | RW          | 0x8                | sw_sav_act0<br>SAV for odd field active.  |

**VICAP\_DVP\_CROP\_SIZE**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                            |
| 28:16      | RW          | 0x01e0             | sw_height<br>The expected height of received image. |
| 15:13      | RO          | 0x0                | reserved                                            |
| 12:0       | RW          | 0x02d0             | sw_width<br>The expected width of received image.   |

**VICAP\_DVP\_CROP\_START**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                |
| 28:16      | RW          | 0x0000             | sw_start_y<br>The vertical ordinate of the start point. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 15:13      | RO          | 0x0                | reserved                                                  |
| 12:0       | RW          | 0x0000             | sw_start_x<br>The horizontal ordinate of the start point. |

**VICAP\_DVP\_FRM0\_ADDR\_Y\_ID0**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_y_id0<br>DVP path frame0 y address. |

**VICAP\_DVP\_FRM0\_ADDR\_UV\_ID0**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_uv_id0<br>DVP path frame0 uv address. |

**VICAP\_DVP\_FRM1\_ADDR\_Y\_ID0**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_y_id1<br>DVP path frame1 y address. |

**VICAP\_DVP\_FRM1\_ADDR\_UV\_ID0**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_uv_id0<br>DVP path frame1 uv address. |

**VICAP\_DVP\_VIR\_LINE\_WIDTH**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                       |
| 19:0       | RW          | 0x00000            | vir_line_width<br>DVP path virtual line width. |

**VICAP\_DVP\_LINE\_INT\_NUM\_ID0\_1**

Address: Operational Base + offset (0x0074)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                               |
| 15         | RW          | 0x0                | line_int_mode_id0<br>1'b0: One-time mode<br>1'b1: Circular mode                                                                                                                                                                                                        |
| 14:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                               |
| 12:0       | RW          | 0x0040             | sw_line_int_num_id0<br>For one-time mode,if line_int_num_id0=100,then channel 0 receive 100th line,the line_id0_intst will be 1.<br>For circular mode ,if line_int_num_id0=100,then channel 0 receive 100th line200th line300th line.....the line_id0_intst will be 1. |

**VICAP\_DVP\_LINE\_CNT\_ID0\_1**

Address: Operational Base + offset (0x007C)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                     |
|------------|-------------|--------------------|----------------------------------------|
| 13:0       | RO          | 0x0000             | ro_line_cnt_id0<br>Current line count. |

**VICAP\_DVP\_PIX\_NUM\_ID0**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                  |
| 29:16      | RO          | 0x0000             | ro_uv_pix_num_id0<br>The id0 UV pixel number in one line. |
| 15:14      | RO          | 0x0                | reserved                                                  |
| 13:0       | RO          | 0x0000             | ro_y_pix_num_id0<br>The id0 Y pixel number in one line.   |

**VICAP\_DVP\_LINE\_NUM\_ID0**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                   |
| 29:16      | RO          | 0x0000             | ro_uv_line_num_id0<br>The id0 UV line number in one frame. |
| 15:14      | RO          | 0x0                | reserved                                                   |
| 13:0       | RO          | 0x0000             | ro_y_line_num_id0<br>The id0 Y line number in one frame.   |

**VICAP\_DVP\_SYNC\_HEADER**

Address: Operational Base + offset (0x00A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | ro_sync_header_7<br>Sync header 7.                                                          |
| 27:24      | RO          | 0x0                | ro_sync_header_6<br>Sync header 6.                                                          |
| 23:20      | RO          | 0x0                | ro_sync_header_5<br>Sync header 5.                                                          |
| 19:16      | RO          | 0x0                | ro_sync_header_4<br>Sync header 4.                                                          |
| 15:12      | RO          | 0x0                | ro_sync_header_3<br>Sync header 3.                                                          |
| 11:8       | RO          | 0x0                | ro_sync_header_2<br>Sync header 2.                                                          |
| 7:4        | RO          | 0x0                | ro_sync_header_1<br>Sync header 1.                                                          |
| 3:0        | RO          | 0x0                | ro_sync_header_0<br>Sync header 0.<br>Header 0 is the latest, and header 7 is the earliest. |

**VICAP\_MIPIO\_ID0\_CTRL0**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RW          | 0x0                | sw_vc_hdr_id_main_id0<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_mode_idx=2'b00 and sw_vc_hdr_protect=1'b1. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29         | RW          | 0x0                | sw_vc_hdr_protect_id0<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.<br>Note: This register is available when sw_hdr_mode_idx=2'b00.<br>And sw_vc_hdr_id_main must be configured correctly(the first coming id). |
| 28         | RW          | 0x0                | sw_dma_en_id0<br>Enable dma transport id0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                     |
| 27         | RW          | 0x0                | sw_align_id0<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                                                                                                             |
| 26         | RW          | 0x0                | sw_command_mode_en_id0<br>Select command mode for id0.<br>1'b0: Not command mode<br>1'b1: Command mode                                                                                                                                                                                          |
| 25:24      | RW          | 0x0                | sw_on_hdr_line_cnt_id0<br>If sw_mipi0_on_hdr_mode_id0=1(2),the line count value will circulate between 0~1(2).And if sw_mipi0_on_hdr_line_cnt_id0=1, id0 channel will capture the line which line count value equal to 1.                                                                       |
| 23:22      | RW          | 0x0                | sw_on_hdr_mode_id0<br>2'b00: Normal mode(no HDR)<br>2'b01: 2 frames HDR<br>2'b10: 3 frames HDR<br>2'b11: Reserved                                                                                                                                                                               |
| 21:20      | RW          | 0x0                | sw_hdr_mode_id0<br>2'b00: HDR distinguished by virtual channel<br>2'b01: HDR distinguished by line number(ON HDR mode)<br>2'b10: HDR distinguished by first 4pixel(SONY HDR mode)<br>2'b11: Reserved                                                                                            |
| 19:18      | RW          | 0x0                | sw_yuyv_out_order_id0<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                                                                                               |
| 17:16      | RW          | 0x0                | sw_yuyv_in_order_id0<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                                                                                                |
| 15:10      | RW          | 0x00               | sw_dt_id0<br>Data type for id0.                                                                                                                                                                                                                                                                 |
| 9:8        | RW          | 0x0                | sw_vc_id0<br>Virtual channel for id0.                                                                                                                                                                                                                                                           |
| 7:5        | RW          | 0x0                | sw_wrddr_type_id0<br>The write ddr type of id0.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | sw_crop_en_id0<br>Enable to crop for id0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                          |
| 3:1        | RW          | 0x0                | sw_parse_type_id0<br>The parse type of id0.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: For raw14(data will be clipped to 12bit)<br>3'b100: For yuv422 8bit<br>Others: Reserved |
| 0          | RW          | 0x0                | sw_cap_en_id0<br>Enable to capture id0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                            |

**VICAP MIPIO LVDS0 ID0 CTRL1**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 29:16      | RW          | 0x0000             | sw_height_id0<br>Height for id0.                                                                                                                                                                                                                                                                                                  |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 13:0       | RW          | 0x0000             | sw_width_id0<br>Width for id0.if sw_wrddr_type is rgb888,then the width is equal to the number of bytes(not pixel).<br>If sw_crop_en_id0 is enable the width value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12, and must be 24 aligned when sw_wrddr_type is rgb888. |

**VICAP MIPIO ID1 CTRL0**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RW          | 0x0                | sw_vc_hdr_id_main_id1<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_mode_idx=2'b00 and sw_vc_hdr_protect=1'b1.                                                                                                                                         |
| 29         | RW          | 0x0                | sw_vc_hdr_protect_id1<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.<br>Note: This register is available when sw_hdr_mode_idx=2'b00. And sw_vc_hdr_id_main must be configured correctly(the first coming id). |
| 28         | RW          | 0x0                | sw_dma_en_id1<br>Enable dma transport id1.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                  |
| 27         | RW          | 0x0                | sw_align_id1<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26         | RW          | 0x0                | sw_command_mode_en_id1<br>Select command mode for id1.<br>1'b0: Not command mode<br>1'b1: Command mode                                                                                                                    |
| 25:24      | RW          | 0x0                | sw_on_hdr_line_cnt_id1<br>If sw_mipi0_on_hdr_mode_id1=1(2),the line count value will circulate between 0~1(2).And if sw_mipi0_on_hdr_line_cnt_id1=1, id1 channel will capture the line which line count value equal to 1. |
| 23:22      | RW          | 0x0                | sw_on_hdr_mode_id1<br>2'b00: Normal mode(no HDR)<br>2'b01: 2 frames HDR<br>2'b10: 3 frames HDR<br>2'b11: Reserved                                                                                                         |
| 21:20      | RW          | 0x0                | sw_hdr_mode_id1<br>2'b00: HDR distinguished by virtual channel<br>2'b01: HDR distinguished by line number(ON HDR mode)<br>2'b10: HDR distinguished by first 4pixel(SONY HDR mode)<br>2'b11: Reserved                      |
| 19:18      | RW          | 0x0                | sw_yuyv_out_order_id1<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                         |
| 17:16      | RW          | 0x0                | sw_yuyv_in_order_id1<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                          |
| 15:10      | RW          | 0x00               | sw_dt_id1<br>Data type for id1.                                                                                                                                                                                           |
| 9:8        | RW          | 0x0                | sw_vc_id1<br>Virtual channel for id1.                                                                                                                                                                                     |
| 7:5        | RW          | 0x0                | sw_wrddr_type_id1<br>The write ddr type of id1.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved                    |
| 4          | RW          | 0x0                | sw_crop_en_id1<br>Enable to crop for id1.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                |
| 3:1        | RW          | 0x0                | sw_parse_type_id1<br>The parse type of id1.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: For raw14(data will be clipped to 12bit)<br>3'b100: For yuv422 8bit<br>Others: Reserved       |

| Bit | Attr | Reset Value | Description                                                              |
|-----|------|-------------|--------------------------------------------------------------------------|
| 0   | RW   | 0x0         | sw_cap_en_id1<br>Enable to capture id1.<br>1'b0: Disable<br>1'b1: Enable |

**VICAP MIPIO LVDS0 ID1 CTRL1**

Address: Operational Base + offset (0x010C)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                       |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                          |
| 29:16 | RW   | 0x0000      | sw_height_id1<br>Height for id1.                                                                                                                                                                                                                                                                                                  |
| 15:14 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                          |
| 13:0  | RW   | 0x0000      | sw_width_id1<br>Width for id1.if sw_wrddr_type is rgb888,then the width is equal to the number of bytes(not pixel).<br>If sw_crop_en_id1 is enable the width value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12, and must be 24 aligned when sw_wrddr_type is rgb888. |

**VICAP MIPIO ID2 CTRL0**

Address: Operational Base + offset (0x0110)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RW   | 0x0         | sw_vc_hdr_id_main_id2<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_mode_idx=2'b00 and sw_vc_hdr_protect=1'b1.                                                                                                                                         |
| 29    | RW   | 0x0         | sw_vc_hdr_protect_id2<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.<br>Note: This register is available when sw_hdr_mode_idx=2'b00. And sw_vc_hdr_id_main must be configured correctly(the first coming id). |
| 28    | RW   | 0x0         | sw_dma_en_id2<br>Enable dma transport id2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                  |
| 27    | RW   | 0x0         | sw_align_id2<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                                                                                                          |
| 26    | RW   | 0x0         | sw_command_mode_en_id2<br>Select command mode for id2.<br>1'b0: Not command mode<br>1'b1: Command mode                                                                                                                                                                                       |
| 25:24 | RW   | 0x0         | sw_on_hdr_line_cnt_id2<br>If sw_mipi0_on_hdr_mode_id2=1(2),the line count value will circulate between 0~1(2).And if sw_mipi0_on_hdr_line_cnt_id2=1, id2 channel will capture the line which line count value equal to 1.                                                                    |
| 23:22 | RW   | 0x0         | sw_on_hdr_mode_id2<br>2'b00: Normal mode(no HDR)<br>2'b01: 2 frames HDR<br>2'b10: 3 frames HDR<br>2'b11: Reserved                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:20      | RW          | 0x0                | sw_hdr_mode_id2<br>2'b00: HDR distinguished by virtual channel<br>2'b01: HDR distinguished by line number(ON HDR mode)<br>2'b10: HDR distinguished by first 4pixel(SONY HDR mode)<br>2'b11: Reserved                |
| 19:18      | RW          | 0x0                | sw_yuyv_out_order_id2<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                   |
| 17:16      | RW          | 0x0                | sw_yuyv_in_order_id2<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                    |
| 15:10      | RW          | 0x00               | sw_dt_id2<br>Data type for id2.                                                                                                                                                                                     |
| 9:8        | RW          | 0x0                | sw_vc_id2<br>Virtual channel for id2.                                                                                                                                                                               |
| 7:5        | RW          | 0x0                | sw_wrddr_type_id2<br>The write ddr type of id2.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved              |
| 4          | RW          | 0x0                | sw_crop_en_id2<br>Enable to crop for id2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                          |
| 3:1        | RW          | 0x0                | sw_parse_type_id2<br>The parse type of id2.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: For raw14(data will be clipped to 12bit)<br>3'b100: For yuv422 8bit<br>Others: Reserved |
| 0          | RW          | 0x0                | sw_cap_en_id2<br>Enable to capture id2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                            |

**VICAP MIPI0 LVDS0 ID2 CTRL1**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:30      | RO          | 0x0                | reserved                         |
| 29:16      | RW          | 0x0000             | sw_height_id2<br>Height for id2. |
| 15:14      | RO          | 0x0                | reserved                         |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0 | RW   | 0x0000      | sw_width_id2<br>Width for id2.if sw_wrddr_type is rgb888,then the width is equal to the number of bytes(not pixel).<br>If sw_crop_en_id2 is enable the width value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12, and must be 24 aligned when sw_wrddy_type is rgb888. |

**VICAP MIPIO ID3 CTRL0**

Address: Operational Base + offset (0x0118)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RW   | 0x0         | sw_vc_hdr_id_main_id3<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_mode_idx=2'b00 and sw_vc_hdr_protect=1'b1.                                                                                                                                         |
| 29    | RW   | 0x0         | sw_vc_hdr_protect_id3<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.<br>Note: This register is available when sw_hdr_mode_idx=2'b00. And sw_vc_hdr_id_main must be configured correctly(the first coming id). |
| 28    | RW   | 0x0         | sw_dma_en_id3<br>Enable dma transport id3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                  |
| 27    | RW   | 0x0         | sw_align_id3<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                                                                                                          |
| 26    | RW   | 0x0         | sw_command_mode_en_id3<br>Select command mode for id3.<br>1'b0: Not command mode<br>1'b1: Command mode                                                                                                                                                                                       |
| 25:24 | RW   | 0x0         | sw_on_hdr_line_cnt_id3<br>If sw_mipi0_on_hdr_mode_id3=1(2),the line count value will circulate between 0~1(2).And if sw_mipi0_on_hdr_line_cnt_id3=1, id3 channel will capture the line which line count value equal to 1.                                                                    |
| 23:22 | RW   | 0x0         | sw_on_hdr_mode_id3<br>2'b00: Normal mode(no HDR)<br>2'b01: 2 frames HDR<br>2'b10: 3 frames HDR<br>2'b11: Reserved                                                                                                                                                                            |
| 21:20 | RW   | 0x0         | sw_hdr_mode_id3<br>2'b00: HDR distinguished by virtual channel<br>2'b01: HDR distinguished by line number(ON HDR mode)<br>2'b10: HDR distinguished by first 4pixel(SONY HDR mode)<br>2'b11: Reserved                                                                                         |
| 19:18 | RW   | 0x0         | sw_yuyv_out_order_id3<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16      | RW          | 0x0                | sw_yuyv_in_order_id3<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                    |
| 15:10      | RW          | 0x00               | sw_dt_id3<br>Data type for id3.                                                                                                                                                                                     |
| 9:8        | RW          | 0x0                | sw_vc_id3<br>Virtual channel for id3.                                                                                                                                                                               |
| 7:5        | RW          | 0x0                | sw_wrddr_type_id3<br>The write ddr type of id3.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved              |
| 4          | RW          | 0x0                | sw_crop_en_id3<br>Enable to crop for id3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                          |
| 3:1        | RW          | 0x0                | sw_parse_type_id3<br>The parse type of id3.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: For raw14(data will be clipped to 12bit)<br>3'b100: For yuv422 8bit<br>Others: Reserved |
| 0          | RW          | 0x0                | sw_cap_en_id3<br>Enable to capture id3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                            |

**VICAP MIPIO LVDS0 ID3 CTRL1**

Address: Operational Base + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 29:16      | RW          | 0x0000             | sw_height_id3<br>Height for id3.                                                                                                                                                                                                                                                                                                  |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 13:0       | RW          | 0x0000             | sw_width_id3<br>Width for id3.if sw_wrddr_type is rgb888,then the width is equal to the number of bytes(not pixel).<br>If sw_crop_en_id3 is enable the width value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12, and must be 24 aligned when sw_wrddr_type is rgb888. |

**VICAP MIPIO LVDS0 CTRL**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31:30      | RW          | 0x0                | sw_drop_frame_main_id<br>The id that is the last coming in HDR mode. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24      | RW          | 0x00               | sw_drop_frame_m<br>Receive m frames, and drop n frames.(m>0,n>0)                                                                                                                                                                    |
| 23:21      | RW          | 0x0                | sw_drop_frame_n<br>Receive m frames, and drop n frames.(m>0,n>0)                                                                                                                                                                    |
| 20         | RW          | 0x0                | sw_drop_frame_en_all<br>1'b0: Disable drop all id frame<br>1'b1: Enable drop all id frame.                                                                                                                                          |
| 19:18      | RW          | 0x0                | sw_soft_RST_mode<br>2'b00: Soft reset and protect toisp path frame integrity;<br>2'b01: Soft reset and protect toisp path frame integrity and pull down sw_cap_en automatically;<br>2'b10: Soft reset directly;<br>2'b11: Reserved. |
| 17         | RW          | 0x0                | sw_soft_RST<br>1'b0: Not reset<br>1'b1: Reset the VICAP MIPIO path(except MMU/AXI MASTER/REG FILE)                                                                                                                                  |
| 16         | RW          | 0x0                | sw_dma_RST<br>Write 1 will reset VICAP MIPIO path dma.<br>When this bit change to 0,dma is reseted completely.                                                                                                                      |
| 15:13      | RW          | 0x0                | sw_press_value<br>Press value.                                                                                                                                                                                                      |
| 12         | RW          | 0x0                | sw_press_en<br>1'b0: Disable press<br>1'b1: Enable press                                                                                                                                                                            |
| 11         | RW          | 0x0                | sw_drop_frame_en_id3<br>1'b0: Disable drop id3 frame<br>1'b1: Enable drop id3 frame.                                                                                                                                                |
| 10         | RW          | 0x0                | sw_drop_frame_en_id2<br>1'b0: Disable drop id2 frame<br>1'b1: Enable drop id2 frame.                                                                                                                                                |
| 9          | RW          | 0x0                | sw_drop_frame_en_id1<br>1'b0: Disable drop id1 frame<br>1'b1: Enable drop id1 frame.                                                                                                                                                |
| 8          | RW          | 0x0                | sw_drop_frame_en_id0<br>1'b0: Disable drop id0 frame<br>1'b1: Enable drop id0 frame.                                                                                                                                                |
| 7:5        | RW          | 0x0                | sw_hurry_value<br>Hurry value.                                                                                                                                                                                                      |
| 4          | RW          | 0x0                | sw_hurry_en<br>1'b0: Disable hurry<br>1'b1: Enable hurry                                                                                                                                                                            |
| 3          | RW          | 0x0                | sw_mipi_lvds_sel<br>1'b0: MIPI path<br>1'b1: LVDS path                                                                                                                                                                              |
| 2:1        | RW          | 0x0                | sw_water_line<br>2'b00: 75%<br>2'b01: 50%<br>2'b10: 25%<br>2'b11: 0%                                                                                                                                                                |
| 0          | RW          | 0x0                | sw_cap_en<br>1'b0: Disable capture all id<br>1'b1: Enable capture all id.                                                                                                                                                           |

**VICAP MIPIO LVDS0 FRAME0 ADDR Y ID0**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_y_id0<br>First address of even frame for ID0 Y/Raw/RGB path(must be aligned to double word). |

**VICAP MIPI0 LVDS0 FRAME1 ADDR Y ID0**

Address: Operational Base + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_y_id0<br>First address of odd frame for ID0 Y path(must be aligned to double word). |

**VICAP MIPI0 LVDS0 FRAME0 ADDR UV ID0**

Address: Operational Base + offset (0x012C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_uv_id0<br>First address of even frame for ID0 UV path(must be aligned to double word). |

**VICAP MIPI0 LVDS0 FRAME1 ADDR UV ID0**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_uv_id0<br>First address of odd frame for ID0 UV path(must be aligned to double word). |

**VICAP MIPI0 LVDS0 VLW ID0**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                     |
| 19:0       | RW          | 0x00000            | sw_vlw_id0<br>Virtual line width of even frame for ID0 path(must be aligned to double word). |

**VICAP MIPI0 LVDS0 FRAME0 ADDR Y ID1**

Address: Operational Base + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_y_id1<br>First address of even frame for ID1 Y/Raw/RGB path(must be aligned to double word). |

**VICAP MIPI0 LVDS0 FRAME1 ADDR Y ID1**

Address: Operational Base + offset (0x013C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_y_id1<br>First address of odd frame for ID1 Y/Raw/RGB path(must be aligned to double word). |

**VICAP MIPI0 LVDS0 FRAME0 ADDR UV ID1**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_uv_id1<br>First address of even frame for ID1 UV path(must be aligned to double word). |

**VICAP MIPIO LVDS0 FRAME1 ADDR UV ID1**

Address: Operational Base + offset (0x0144)

| Bit  | Attr | Reset Value | Description                                                                                          |
|------|------|-------------|------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | sw_frame1_addr_uv_id1<br>First address of odd frame for ID1 UV path(must be aligned to double word). |

**VICAP MIPIO LVDS0 VLW ID1**

Address: Operational Base + offset (0x0148)

| Bit   | Attr | Reset Value | Description                                                                                            |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                                                               |
| 19:0  | RW   | 0x00000     | sw_vlw_id1<br>Virtual line width of even frame for ID1 Y/Raw/RGB path(must be aligned to double word). |

**VICAP MIPIO LVDS0 FRAME0 ADDR Y ID2**

Address: Operational Base + offset (0x014C)

| Bit  | Attr | Reset Value | Description                                                                                                 |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | sw_frame0_addr_y_id2<br>First address of even frame for ID2 Y/Raw/RGB path(must be aligned to double word). |

**VICAP MIPIO LVDS0 FRAME1 ADDR Y ID2**

Address: Operational Base + offset (0x0150)

| Bit  | Attr | Reset Value | Description                                                                                                |
|------|------|-------------|------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | sw_frame1_addr_y_id2<br>First address of odd frame for ID2 Y/Raw/RGB path(must be aligned to double word). |

**VICAP MIPIO LVDS0 FRAME0 ADDR UV ID2**

Address: Operational Base + offset (0x0154)

| Bit  | Attr | Reset Value | Description                                                                                           |
|------|------|-------------|-------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | sw_frame0_addr_uv_id2<br>First address of even frame for ID2 UV path(must be aligned to double word). |

**VICAP MIPIO LVDS0 FRAME1 ADDR UV ID2**

Address: Operational Base + offset (0x0158)

| Bit  | Attr | Reset Value | Description                                                                                          |
|------|------|-------------|------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | sw_frame1_addr_uv_id0<br>First address of odd frame for ID2 UV path(must be aligned to double word). |

**VICAP MIPIO LVDS0 VLW ID2**

Address: Operational Base + offset (0x015C)

| Bit   | Attr | Reset Value | Description                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------|
| 31:20 | RO   | 0x000       | reserved                                                                                     |
| 19:0  | RW   | 0x00000     | sw_vlw_id2<br>Virtual line width of even frame for ID2 path(must be aligned to double word). |

**VICAP MIPIO LVDS0 FRAME0 ADDR Y ID3**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_y_id3<br>First address of even frame for ID3 Y/RAW/RGB path(must be aligned to double word). |

**VICAP MIPIO LVDS0 FRAME1 ADDR Y ID3**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_y_id3<br>First address of odd frame for ID3 Y/RAW/RGB path(must be aligned to double word). |

**VICAP MIPIO LVDS0 FRAME0 ADDR UV ID3**

Address: Operational Base + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_uv_id3<br>First address of even frame for ID3 UV path(must be aligned to double word). |

**VICAP MIPIO LVDS0 FRAME1 ADDR UV ID3**

Address: Operational Base + offset (0x016C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_uv_id3<br>First address of odd frame for ID3 UV path(must be aligned to double word). |

**VICAP MIPIO LVDS0 VLW ID3**

Address: Operational Base + offset (0x0170)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                     |
| 19:0       | RW          | 0x00000            | sw_vlw_id3<br>Virtual line width of even frame for ID3 path(must be aligned to double word). |

**VICAP MIPIO LVDS0 INTEN**

Address: Operational Base + offset (0x0174)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                            |
| 27         | RW          | 0x0                | size_err_id3_inten<br>1'b0: Disable<br>1'b1: Enable |
| 26         | RW          | 0x0                | size_err_id2_inten<br>1'b0: Disable<br>1'b1: Enable |
| 25         | RW          | 0x0                | size_err_id1_inten<br>1'b0: Disable<br>1'b1: Enable |
| 24         | RW          | 0x0                | size_err_id0_inten<br>1'b0: Disable<br>1'b1: Enable |
| 23         | RW          | 0x0                | line_id3_inten<br>1'b0: Disable<br>1'b1: Enable     |
| 22         | RW          | 0x0                | line_id2_inten<br>1'b0: Disable<br>1'b1: Enable     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 21         | RW          | 0x0                | line_id1_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                            |
| 20         | RW          | 0x0                | line_id0_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                            |
| 19         | RW          | 0x0                | csi2rx_fifo_overflow_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                |
| 18         | RW          | 0x0                | bandwidth_lack_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                      |
| 17         | RW          | 0x0                | dma_uv_fifo_overflow_inten<br>Enable the interrupt of dma fifo overflow of MIPI uv path or LVDS id1 path.<br>1'b0: Disable<br>1'b1: Enable |
| 16         | RW          | 0x0                | dma_y_fifo_overflow_inten<br>Enable the interrupt of dma fifo overflow of MIPI y path or LVDS id0 path.<br>1'b0: Disable<br>1'b1: Enable   |
| 15         | RW          | 0x0                | frame1_dma_end_id3_inten<br>Enable the interrupt of end of odd frame for ID1.<br>1'b0: Disable<br>1'b1: Enable                             |
| 14         | RW          | 0x0                | frame0_dma_end_id3_inten<br>Enable the interrupt of end of even frame for ID3.<br>1'b0: Disable<br>1'b1: Enable                            |
| 13         | RW          | 0x0                | frame1_dma_end_id2_inten<br>Enable the interrupt of end of odd frame for ID1.<br>1'b0: Disable<br>1'b1: Enable                             |
| 12         | RW          | 0x0                | frame0_dma_end_id2_inten<br>Enable the interrupt of end of even frame for ID2.<br>1'b0: Disable<br>1'b1: Enable                            |
| 11         | RW          | 0x0                | frame1_dma_end_id1_inten<br>Enable the interrupt of end of odd frame for ID1.<br>1'b0: Disable<br>1'b1: Enable                             |
| 10         | RW          | 0x0                | frame0_dma_end_id1_inten<br>Enable the interrupt of end of even frame for ID1.<br>1'b0: Disable<br>1'b1: Enable                            |
| 9          | RW          | 0x0                | frame1_dma_end_id0_inten<br>Enable the interrupt of end of odd frame for ID0.<br>1'b0: Disable<br>1'b1: Enable                             |
| 8          | RW          | 0x0                | frame0_dma_end_id0_inten<br>Enable the interrupt of end of even frame for ID0.<br>1'b0: Disable<br>1'b1: Enable                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | frame1_start_id3_inten<br>Enable the interrupt of start of odd frame for ID3.<br>1'b0: Disable<br>1'b1: Enable  |
| 6          | RW          | 0x0                | frame0_start_id3_inten<br>Enable the interrupt of start of even frame for ID3.<br>1'b0: Disable<br>1'b1: Enable |
| 5          | RW          | 0x0                | frame1_start_id2_inten<br>Enable the interrupt of start of odd frame for ID2.<br>1'b0: Disable<br>1'b1: Enable  |
| 4          | RW          | 0x0                | frame0_start_id2_inten<br>Enable the interrupt of start of even frame for ID2.<br>1'b0: Disable<br>1'b1: Enable |
| 3          | RW          | 0x0                | frame1_start_id1_inten<br>Enable the interrupt of start of odd frame for ID1.<br>1'b0: Disable<br>1'b1: Enable  |
| 2          | RW          | 0x0                | frame0_start_id1_inten<br>Enable the interrupt of start of even frame for ID1.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | frame1_start_id0_inten<br>Enable the interrupt of start of odd frame for ID0.<br>1'b0: Disable<br>1'b1: Enable  |
| 0          | RW          | 0x0                | frame0_start_id0_inten<br>Enable the interrupt of start of even frame for ID0.<br>1'b0: Disable<br>1'b1: Enable |

**VICAP MIPIO LVDS0 INTSTAT**

Address: Operational Base + offset (0x0178)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                    |
| 27         | W1C         | 0x0                | size_err_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 26         | W1C         | 0x0                | size_err_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 25         | W1C         | 0x0                | size_err_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 24         | W1C         | 0x0                | size_err_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 23         | W1C         | 0x0                | line_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt     |
| 22         | W1C         | 0x0                | line_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 21         | W1<br>C     | 0x0                | line_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt             |
| 20         | W1<br>C     | 0x0                | line_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt             |
| 19         | W1<br>C     | 0x0                | csi2rx_fifo_overflow_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 18         | W1<br>C     | 0x0                | bandwidth_lack_intst<br>1'b0: No interrupt<br>1'b1: Interrupt       |
| 17         | W1<br>C     | 0x0                | dma_uv_fifo_overflow_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 16         | W1<br>C     | 0x0                | dma_y_fifo_overflow_intst<br>1'b0: No interrupt<br>1'b1: Interrupt  |
| 15         | W1<br>C     | 0x0                | frame1_dma_end_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 14         | W1<br>C     | 0x0                | frame0_dma_end_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 13         | W1<br>C     | 0x0                | frame1_dma_end_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 12         | W1<br>C     | 0x0                | frame0_dma_end_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 11         | W1<br>C     | 0x0                | frame1_dma_end_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 10         | W1<br>C     | 0x0                | frame0_dma_end_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 9          | W1<br>C     | 0x0                | frame1_dma_end_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 8          | W1<br>C     | 0x0                | frame0_dma_end_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 7          | W1<br>C     | 0x0                | frame1_start_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt     |
| 6          | W1<br>C     | 0x0                | frame0_start_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt     |
| 5          | W1<br>C     | 0x0                | frame1_start_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt     |
| 4          | W1<br>C     | 0x0                | frame0_start_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 3          | W1<br>C     | 0x0                | frame1_start_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 2          | W1<br>C     | 0x0                | frame0_start_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 1          | W1<br>C     | 0x0                | frame1_start_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 0          | W1<br>C     | 0x0                | frame0_start_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |

**VICAP MIPIO LVDS0 LINE INT NUM ID0\_1**

Address: Operational Base + offset (0x017C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | line_int_mode_id1<br>1'b0: One-time mode<br>1'b1: Circular mode                                                                                                                                                                                                     |
| 30         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |
| 29:16      | RW          | 0x0040             | line_int_num_id1<br>For one-time mode,if line_int_num_id1=100,then channel 1 receive 100th line,the line_id1_intst will be 1.<br>For circular mode ,if line_int_num_id1=100,then channel 1 receive 100th line200th line300th line.....the line_id1_intst will be 1. |
| 15         | RW          | 0x0                | line_int_mode_id0<br>1'b0: One-time mode<br>1'b1: Circular mode                                                                                                                                                                                                     |
| 14         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |
| 13:0       | RW          | 0x0040             | line_int_num_id0<br>For one-time mode,if line_int_num_id0=100,then channel 0 receive 100th line,the line_id0_intst will be 1.<br>For circular mode ,if line_int_num_id0=100,then channel 0 receive 100th line200th line300th line.....the line_id0_intst will be 1. |

**VICAP MIPIO LVDS0 LINE INT NUM ID2\_3**

Address: Operational Base + offset (0x0180)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | line_int_mode_id3<br>1'b0: One-time mode<br>1'b1: Circular mode                                                                                                                                                                                                     |
| 30         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |
| 29:16      | RW          | 0x0040             | line_int_num_id3<br>For one-time mode,if line_int_num_id3=100,then channel 3 receive 100th line,the line_id3_intst will be 1.<br>For circular mode ,if line_int_num_id3=100,then channel 3 receive 100th line200th line300th line.....the line_id3_intst will be 1. |
| 15         | RW          | 0x0                | line_int_mode_id2<br>1'b0: One-time mode<br>1'b1: Circular mode                                                                                                                                                                                                     |
| 14         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0       | RW          | 0x0040             | line_int_num_id2<br>For one-time mode,if line_int_num_id2=100,then channel 2 receive 100th line,the line_id2_intst will be 1.<br>For circular mode ,if line_int_num_id2=100,then channel 2 receive 100th line200th line300th line.....the line_id2_intst will be 1. |

**VICAP MIPI0 LVDS0 LINE CNT ID0 1**

Address: Operational Base + offset (0x0184)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                       |
| 29:16      | RO          | 0x0000             | ro_line_cnt_id1<br>Current line count for id1. |
| 15:14      | RO          | 0x0                | reserved                                       |
| 13:0       | RO          | 0x0000             | ro_line_cnt_id0<br>Current line count for id0. |

**VICAP MIPI0 LVDS0 LINE CNT ID2 3**

Address: Operational Base + offset (0x0188)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                       |
| 29:16      | RO          | 0x0000             | ro_line_cnt_id3<br>Current line count for id3. |
| 15:14      | RO          | 0x0                | reserved                                       |
| 13:0       | RO          | 0x0000             | ro_line_cnt_id2<br>Current line count for id2. |

**VICAP MIPI0 LVDS0 ID0\_CROP\_START**

Address: Operational Base + offset (0x018C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 29:16      | RW          | 0x0000             | sw_start_y_id0<br>The start y coordinate for id0.                                                                                                                                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 13:0       | RW          | 0x0000             | sw_start_x_id0<br>The start x coordinate for id0,if sw_wrddr_type is rgb888,then the start x is measured in byte.<br>The start x value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12,and must be 24 aligned when sw_wrddy_type is rgb888. |

**VICAP MIPI0 LVDS0 ID1\_CROP\_START**

Address: Operational Base + offset (0x0190)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                          |
| 29:16      | RW          | 0x0000             | sw_start_y_id1<br>The start y coordinate for id1. |
| 15:14      | RO          | 0x0                | reserved                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0       | RW          | 0x0000             | sw_start_x_id1<br>The start x coordinate for id1,if sw_wrddr_type is rgb888,then the start x is measured in byte.<br>The start x value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12,and must be 24 aligned when sw_wrddy_type is rgb888. |

**VICAP MIPIO LVDS0 ID2 CROP START**

Address: Operational Base + offset (0x0194)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 29:16      | RW          | 0x0000             | sw_start_y_id2<br>The start y coordinate for id2.                                                                                                                                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 13:0       | RW          | 0x0000             | sw_start_x_id2<br>The start x coordinate for id2,if sw_wrddr_type is rgb888,then the start x is measured in byte.<br>The start x value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12,and must be 24 aligned when sw_wrddy_type is rgb888. |

**VICAP MIPIO LVDS0 ID3 CROP START**

Address: Operational Base + offset (0x0198)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 29:16      | RW          | 0x0000             | sw_start_y_id3<br>The start y coordinate for id3.                                                                                                                                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 13:0       | RW          | 0x0000             | sw_start_x_id3<br>The start x coordinate for id3,if sw_wrddr_type is rgb888,then the start x is measured in byte.<br>The start x value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12,and must be 24 aligned when sw_wrddy_type is rgb888. |

**VICAP MIPIO FRAME NUM VC0**

Address: Operational Base + offset (0x019C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | ro_frame_num_end_vc0<br>The frame number of frame end of virtual channel 0.     |
| 15:0       | RO          | 0x0000             | ro_frame_num_start_vc0<br>The frame number of frame start of virtual channel 0. |

**VICAP MIPIO FRAME NUM VC1**

Address: Operational Base + offset (0x01A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | ro_frame_num_end_vc1<br>The frame number of frame end of virtual channel 1.     |
| 15:0       | RO          | 0x0000             | ro_frame_num_start_vc1<br>The frame number of frame start of virtual channel 1. |

**VICAP MIPIO FRAME NUM VC2**

Address: Operational Base + offset (0x01A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | ro_frame_num_end_vc2<br>The frame number of frame end of virtual channel 2.     |
| 15:0       | RO          | 0x0000             | ro_frame_num_start_vc2<br>The frame number of frame start of virtual channel 2. |

**VICAP MIPIO FRAME NUM VC3**

Address: Operational Base + offset (0x01A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | ro_frame_num_end_vc3<br>The frame number of frame end of virtual channel 3.     |
| 15:0       | RO          | 0x0000             | ro_frame_num_start_vc3<br>The frame number of frame start of virtual channel 3. |

**VICAP MIPIO ID0 EFFECT CODE**

Address: Operational Base + offset (0x01AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                        |
| 29:16      | RW          | 0x0000             | sw_sony_effect_code1_id0<br>Effect code of id0 for sony sensor. |
| 15:14      | RO          | 0x0                | reserved                                                        |
| 13:0       | RW          | 0x0000             | sw_sony_effect_code0_id0<br>Effect code of id0 for sony sensor. |

**VICAP MIPIO ID1 EFFECT CODE**

Address: Operational Base + offset (0x01B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                        |
| 29:16      | RW          | 0x0000             | sw_sony_effect_code1_id1<br>Effect code of id1 for sony sensor. |
| 15:14      | RO          | 0x0                | reserved                                                        |
| 13:0       | RW          | 0x0000             | sw_sony_effect_code0_id1<br>Effect code of id1 for sony sensor. |

**VICAP MIPIO ID2 EFFECT CODE**

Address: Operational Base + offset (0x01B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                        |
| 29:16      | RW          | 0x0000             | sw_sony_effect_code1_id2<br>Effect code of id2 for sony sensor. |
| 15:14      | RO          | 0x0                | reserved                                                        |
| 13:0       | RW          | 0x0000             | sw_sony_effect_code0_id2<br>Effect code of id2 for sony sensor. |

**VICAP MIPIO ID3 EFFECT CODE**

Address: Operational Base + offset (0x01B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                        |
| 29:16      | RW          | 0x0000             | sw_sony_effect_code1_id3<br>Effect code of id3 for sony sensor. |
| 15:14      | RO          | 0x0                | reserved                                                        |
| 13:0       | RW          | 0x0000             | sw_sony_effect_code0_id3<br>Effect code of id3 for sony sensor. |

**VICAP MIPIO ON PAD VALUE**

Address: Operational Base + offset (0x01BC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:14      | RO          | 0x00000            | reserved                                        |
| 13:0       | RW          | 0x0000             | sw_on_pad_value<br>Padding value for ON sensor. |

**VICAP MIPIO LVDS0 SIZE NUM ID0**

Address: Operational Base + offset (0x01C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                             |
| 29:16      | RO          | 0x0000             | ro_line_num_id0<br>The id0 line number in one frame. |
| 15:14      | RO          | 0x0                | reserved                                             |
| 13:0       | RO          | 0x0000             | ro_pix_num_id0<br>The id0 pixel number in one line.  |

**VICAP MIPIO LVDS0 SIZE NUM ID1**

Address: Operational Base + offset (0x01C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                             |
| 29:16      | RO          | 0x0000             | ro_line_num_id1<br>The id1 line number in one frame. |
| 15:14      | RO          | 0x0                | reserved                                             |
| 13:0       | RO          | 0x0000             | ro_pix_num_id1<br>The id1 pixel number in one line.  |

**VICAP MIPIO LVDS0 SIZE NUM ID2**

Address: Operational Base + offset (0x01C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                             |
| 29:16      | RO          | 0x0000             | ro_line_num_id2<br>The id2 line number in one frame. |
| 15:14      | RO          | 0x0                | reserved                                             |
| 13:0       | RO          | 0x0000             | ro_pix_num_id2<br>The id2 pixel number in one line.  |

**VICAP MIPIO LVDS0 SIZE NUM ID3**

Address: Operational Base + offset (0x01CC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                             |
| 29:16      | RO          | 0x0000             | ro_line_num_id3<br>The id3 line number in one frame. |
| 15:14      | RO          | 0x0                | reserved                                             |
| 13:0       | RO          | 0x0000             | ro_pix_num_id3<br>The id3 pixel number in one line.  |

**VICAP LVDS0 ID0 CTRL0**

Address: Operational Base + offset (0x01D0)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28:27      | RW          | 0x0                | sw_lvds_yuv_out_order_id0<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                       |
| 26:25      | RW          | 0x0                | sw_lvds_yuv_in_order_id0<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                        |
| 24:22      | RW          | 0x0                | sw_lvds_wrddr_type_id0<br>The write ddr type of id0.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved |
| 21:19      | RW          | 0x0                | sw_lvds_parse_type_id0<br>The parse type of id0.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: Reserved<br>3'b100: For yuv422 8bit<br>Others: Reserved                    |
| 18:17      | RW          | 0x0                | sw_lvds_hdr_id_main_id0<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_protect=1'b1.                                                                                   |
| 16         | RW          | 0x0                | sw_lvds_hdr_protect_id0<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.                                                       |
| 15         | RW          | 0x0                | sw_lvds_dma_en_id0<br>Enable dma transport id0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                            |
| 14         | RW          | 0x0                | sw_lvds_align_id0<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                    |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                    |
| 12         | RW          | 0x0                | sw_lvds_hdr_frame_id0<br>Only be used when the sw_lvds_mode_id0=3'b010.<br>1'b0: 2 frames hdr<br>1'b1: 3 frames hdr                                                                                         |
| 11:10      | RW          | 0x0                | sw_lvds_fid_id0<br>Only be used when the sw_lvds_mode_id0=3'b011.<br>Choose the fid for id0.                                                                                                                |
| 9:8        | RW          | 0x0                | sw_lvds_main_lane_id0<br>Choose the lane to parse the sync code                                                                                                                                             |
| 7:4        | RW          | 0x0                | sw_lvds_lane_en_id0<br>Lane enable for id0.<br>eg : 4'b0011 represent lane 0/1 is enable.                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1        | RW          | 0x0                | sw_lvds_mode_id0<br>There are 4 modes.<br>3'b000: Ls-le...fs-fe or sav_act-eav_act...sav_blk-eav_blk<br>3'b001: Fs-le...ls-fe<br>3'b010: Sony dol hdr pattern 1<br>3'b011: Sony dol hdr pattern 2<br>other: Reserverd |
| 0          | RW          | 0x0                | sw_lvds_cap_en_id0<br>Enable to capture lvds id0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                    |

**VICAP\_LVDS0\_ID1\_CTRL0**

Address: Operational Base + offset (0x01D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                    |
| 28:27      | RW          | 0x0                | sw_lvds_yuv_out_order_id1<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                       |
| 26:25      | RW          | 0x0                | sw_lvds_yuv_in_order_id1<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                        |
| 24:22      | RW          | 0x0                | sw_lvds_wrddr_type_id1<br>The write ddr type of id1.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved |
| 21:19      | RW          | 0x0                | sw_lvds_parse_type_id1<br>The parse type of id1.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: Reserved<br>3'b100: For yuv422 8bit<br>Others: Reserved                    |
| 18:17      | RW          | 0x0                | sw_lvds_hdr_id_main_id1<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_protect=1'b1.                                                                                   |
| 16         | RW          | 0x0                | sw_lvds_hdr_protect_id1<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.                                                       |
| 15         | RW          | 0x0                | sw_lvds_dma_en_id1<br>Enable dma transport id1.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | sw_lvds_align_id1<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                             |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                             |
| 12         | RW          | 0x0                | sw_lvds_hdr_frame_id1<br>Only be used when the sw_lvds_mode_id1=3'b010.<br>1'b0: 2 frames hdr<br>1'b1: 3 frames hdr                                                                                                  |
| 11:10      | RW          | 0x0                | sw_lvds_fid_id1<br>Only be used when the sw_lvds_mode_id0=3'b011.<br>Choose the fid for id1.                                                                                                                         |
| 9:8        | RW          | 0x0                | sw_lvds_main_lane_id1<br>Choose the lane to parse the sync code                                                                                                                                                      |
| 7:4        | RW          | 0x0                | sw_lvds_lane_en_id1<br>Lane enable for id1.<br>eg : 4'b0011 represent lane 0/1 is enable.                                                                                                                            |
| 3:1        | RW          | 0x0                | sw_lvds_mode_id1<br>There are 4 modes.<br>3'b000: Ls-le...fs-fe or sav_act-eav_act...sav_blk-eav_blk<br>3'b001: Fs-le...ls-fe<br>3'b010: Sony dol hdr pattern 1<br>3'b011: Sony dol hdr pattern 2<br>other: Reserved |
| 0          | RW          | 0x0                | sw_lvds_cap_en_id1<br>Enable to capture lvds id1.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                   |

**VICAP LVDS0 ID2 CTRL0**

Address: Operational Base + offset (0x01D8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                    |
| 28:27      | RW          | 0x0                | sw_lvds_yuv_out_order_id2<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                       |
| 26:25      | RW          | 0x0                | sw_lvds_yuv_in_order_id2<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                        |
| 24:22      | RW          | 0x0                | sw_lvds_wrddr_type_id2<br>The write ddr type of id2.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:19      | RW          | 0x0                | sw_lvds_parse_type_id2<br>The parse type of id2.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: Reserved<br>3'b100: For yuv422 8bit<br>Others: Reserved                             |
| 18:17      | RW          | 0x0                | sw_lvds_hdr_id_main_id2<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_protect=1'b1.                                                                                            |
| 16         | RW          | 0x0                | sw_lvds_hdr_protect_id2<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.                                                                |
| 15         | RW          | 0x0                | sw_lvds_dma_en_id2<br>Enable dma transport id2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                     |
| 14         | RW          | 0x0                | sw_lvds_align_id2<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                             |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                             |
| 12         | RW          | 0x0                | sw_lvds_hdr_frame_id2<br>Only be used when the sw_lvds_mode_id2=3'b010.<br>1'b0: 2 frames hdr<br>1'b1: 3 frames hdr                                                                                                  |
| 11:10      | RW          | 0x0                | sw_lvds_fid_id2<br>Only be used when the sw_lvds_mode_id0=3'b011.<br>Choose the fid for id2.                                                                                                                         |
| 9:8        | RW          | 0x0                | sw_lvds_main_lane_id2<br>Choose the lane to parse the sync code                                                                                                                                                      |
| 7:4        | RW          | 0x0                | sw_lvds_lane_en_id2<br>Lane enable for id2.<br>eg : 4'b0011 represent lane 0/1 is enable.                                                                                                                            |
| 3:1        | RW          | 0x0                | sw_lvds_mode_id2<br>There are 4 modes.<br>3'b000: Ls-le...fs-fe or sav_act-eav_act...sav_blk-eav_blk<br>3'b001: Fs-le...ls-fe<br>3'b010: Sony dol hdr pattern 1<br>3'b011: Sony dol hdr pattern 2<br>other: Reserved |
| 0          | RW          | 0x0                | sw_lvds_cap_en_id2<br>Enable to capture lvds id2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                   |

**VICAP LVDS0 ID3 CTRL0**

Address: Operational Base + offset (0x01DC)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28:27      | RW          | 0x0                | sw_lvds_yuv_out_order_id3<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                       |
| 26:25      | RW          | 0x0                | sw_lvds_yuv_in_order_id3<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                        |
| 24:22      | RW          | 0x0                | sw_lvds_wrddr_type_id3<br>The write ddr type of id3.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved |
| 21:19      | RW          | 0x0                | sw_lvds_parse_type_id3<br>The parse type of id3.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: Reserved<br>3'b100: For yuv422 8bit<br>Others: Reserved                    |
| 18:17      | RW          | 0x0                | sw_lvds_hdr_id_main_id3<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_protect=1'b1.                                                                                   |
| 16         | RW          | 0x0                | sw_lvds_hdr_protect_id3<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.                                                       |
| 15         | RW          | 0x0                | sw_lvds_dma_en_id3<br>Enable dma transport id3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                            |
| 14         | RW          | 0x0                | sw_lvds_align_id3<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                    |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                    |
| 12         | RW          | 0x0                | sw_lvds_hdr_frame_id3<br>Only be used when the sw_lvds_mode_id3=3'b010.<br>1'b0: 2 frames hdr<br>1'b1: 3 frames hdr                                                                                         |
| 11:10      | RW          | 0x0                | sw_lvds_fid_id3<br>Only be used when the sw_lvds_mode_id3=3'b011.<br>Choose the fid for id3.                                                                                                                |
| 9:8        | RW          | 0x0                | sw_lvds_main_lane_id3<br>Choose the lane to parse the sync code                                                                                                                                             |
| 7:4        | RW          | 0x0                | sw_lvds_lane_en_id3<br>Lane enable for id3.<br>eg : 4'b0011 represent lane 0/1 is enable.                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1        | RW          | 0x0                | sw_lvds_mode_id3<br>There are 4 modes.<br>3'b000: Ls-le...fs-fe or sav_act-eav_act...sav_blk-eav_blk<br>3'b001: Fs-le...ls-fe<br>3'b010: Sony dol hdr pattern 1<br>3'b011: Sony dol hdr pattern 2<br>other: Reserverd |
| 0          | RW          | 0x0                | sw_lvds_cap_en_id3<br>Enable to capture lvds id3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                    |

**VICAP LVDS0 SAV EAV ACT0 ID0**

Address: Operational Base + offset (0x01E0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act0_id0<br>LVDS path sync code of eav_act0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act0_id0<br>LVDS path sync code of sav_act0. |

**VICAP LVDS0 SAV EAV BLK0 ID0**

Address: Operational Base + offset (0x01E4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk0_id0<br>LVDS path sync code of eav_blk0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk0_id0<br>LVDS path sync code of sav_blk0. |

**VICAP LVDS0 SAV EAV ACT1 ID0**

Address: Operational Base + offset (0x01E8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act1_id0<br>LVDS path sync code of eav_act1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act1_id0<br>LVDS path sync code of sav_act1. |

**VICAP LVDS0 SAV EAV BLK1 ID0**

Address: Operational Base + offset (0x01EC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk1_id0<br>LVDS path sync code of eav_blk1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk1_id0<br>LVDS path sync code of sav_blk1. |

**VICAP LVDS0 SAV EAV ACT0 ID1**

Address: Operational Base + offset (0x01F0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act0_id1<br>LVDS path sync code of eav_act0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act0_id1<br>LVDS path sync code of sav_act0. |

**VICAP LVDS0 SAV EAV BLK0 ID1**

Address: Operational Base + offset (0x01F4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk0_id1<br>LVDS path sync code of eav_blk0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk0_id1<br>LVDS path sync code of sav_blk0. |

**VICAP LVDS0 SAV EAV ACT1 ID1**

Address: Operational Base + offset (0x01F8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act1_id1<br>LVDS path sync code of eav_act1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act1_id1<br>LVDS path sync code of sav_act1. |

**VICAP LVDS0 SAV EAV BLK1 ID1**

Address: Operational Base + offset (0x01FC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk1_id1<br>LVDS path sync code of eav_blk1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk1_id1<br>LVDS path sync code of sav_blk1. |

**VICAP LVDS0 SAV EAV ACT0 ID2**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act0_id2<br>LVDS path sync code of eav_act0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act0_id2<br>LVDS path sync code of sav_act0. |

**VICAP LVDS0 SAV EAV BLK0 ID2**

Address: Operational Base + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk0_id2<br>LVDS path sync code of eav_blk0. |
| 15:12      | RO          | 0x0                | reserved                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk0_id2<br>LVDS path sync code of sav_blk0. |

**VICAP LVDS0 SAV EAV ACT1 ID2**

Address: Operational Base + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act1_id2<br>LVDS path sync code of eav_act1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act1_id2<br>LVDS path sync code of sav_act1. |

**VICAP LVDS0 SAV EAV BLK1 ID2**

Address: Operational Base + offset (0x020C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk1_id2<br>LVDS path sync code of eav_blk1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk1_id2<br>LVDS path sync code of sav_blk1. |

**VICAP LVDS0 SAV EAV ACT0 ID3**

Address: Operational Base + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act0_id3<br>LVDS path sync code of eav_act0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act0_id3<br>LVDS path sync code of sav_act0. |

**VICAP LVDS0 SAV EAV BLK0 ID3**

Address: Operational Base + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk0_id3<br>LVDS path sync code of eav_blk0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk0_id3<br>LVDS path sync code of sav_blk0. |

**VICAP LVDS0 SAV EAV ACT1 ID3**

Address: Operational Base + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act1_id3<br>LVDS path sync code of eav_act1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act1_id3<br>LVDS path sync code of sav_act1. |

**VICAP LVDS0 SAV EAV BLK1 ID3**

Address: Operational Base + offset (0x021C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk1_id3<br>LVDS path sync code of eav_blk1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk1_id3<br>LVDS path sync code of sav_blk1. |

**VICAP MIPI1 ID0 CTRL0**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RW          | 0x0                | sw_vc_hdr_id_main_id0<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_mode_idx=2'b00 and sw_vc_hdr_protect=1'b1.                                                                                                                                         |
| 29         | RW          | 0x0                | sw_vc_hdr_protect_id0<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.<br>Note: This register is available when sw_hdr_mode_idx=2'b00. And sw_vc_hdr_id_main must be configured correctly(the first coming id). |
| 28         | RW          | 0x0                | sw_dma_en_id0<br>Enable dma transport id0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                  |
| 27         | RW          | 0x0                | sw_align_id0<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                                                                                                          |
| 26         | RW          | 0x0                | sw_command_mode_en_id0<br>Select command mode for id0.<br>1'b0: Not command mode<br>1'b1: Command mode                                                                                                                                                                                       |
| 25:24      | RW          | 0x0                | sw_on_hdr_line_cnt_id0<br>If sw_mipi0_on_hdr_mode_id0=1(2),the line count value will circulate between 0~1(2).And if sw_mipi0_on_hdr_line_cnt_id0=1, id0 channel will capture the line which line count value equal to 1.                                                                    |
| 23:22      | RW          | 0x0                | sw_on_hdr_mode_id0<br>2'b00: Normal mode(no HDR)<br>2'b01: 2 frames HDR<br>2'b10: 3 frames HDR<br>2'b11: Reserved                                                                                                                                                                            |
| 21:20      | RW          | 0x0                | sw_hdr_mode_id0<br>2'b00: HDR distinguished by virtual channel<br>2'b01: HDR distinguished by line number(ON HDR mode)<br>2'b10: HDR distinguished by first 4pixel(SONY HDR mode)<br>2'b11: Reserved                                                                                         |
| 19:18      | RW          | 0x0                | sw_yuyv_out_order_id0<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16      | RW          | 0x0                | sw_yuyv_in_order_id0<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                    |
| 15:10      | RW          | 0x00               | sw_dt_id0<br>Data type for id0.                                                                                                                                                                                     |
| 9:8        | RW          | 0x0                | sw_vc_id0<br>Virtual channel for id0.                                                                                                                                                                               |
| 7:5        | RW          | 0x0                | sw_wrddr_type_id0<br>The write ddr type of id0.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved              |
| 4          | RW          | 0x0                | sw_crop_en_id0<br>Enable to crop for id0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                          |
| 3:1        | RW          | 0x0                | sw_parse_type_id0<br>The parse type of id0.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: For raw14(data will be clipped to 12bit)<br>3'b100: For yuv422 8bit<br>Others: Reserved |
| 0          | RW          | 0x0                | sw_cap_en_id0<br>Enable to capture id0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                            |

**VICAP MIPI1 LVDS1 ID0 CTRL1**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 29:16      | RW          | 0x0000             | sw_height_id0<br>Height for id0.                                                                                                                                                                                                                                                                                                  |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 13:0       | RW          | 0x0000             | sw_width_id0<br>Width for id0.if sw_wrddr_type is rgb888,then the width is equal to the number of bytes(not pixel).<br>If sw_crop_en_id0 is enable the width value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12, and must be 24 aligned when sw_wrddr_type is rgb888. |

**VICAP MIPI1 ID1 CTRL0**

Address: Operational Base + offset (0x0308)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RW          | 0x0                | sw_vc_hdr_id_main_id1<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_mode_idx=2'b00 and sw_vc_hdr_protect=1'b1.                                                                                                                                         |
| 29         | RW          | 0x0                | sw_vc_hdr_protect_id1<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.<br>Note: This register is available when sw_hdr_mode_idx=2'b00. And sw_vc_hdr_id_main must be configured correctly(the first coming id). |
| 28         | RW          | 0x0                | sw_dma_en_id1<br>Enable dma transport id1.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                  |
| 27         | RW          | 0x0                | sw_align_id1<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                                                                                                          |
| 26         | RW          | 0x0                | sw_command_mode_en_id1<br>Select command mode for id1.<br>1'b0: Not command mode<br>1'b1: Command mode                                                                                                                                                                                       |
| 25:24      | RW          | 0x0                | sw_on_hdr_line_cnt_id1<br>If sw_mipi0_on_hdr_mode_id1=1(2),the line count value will circulate between 0~1(2).And if sw_mipi0_on_hdr_line_cnt_id1=1, id1 channel will capture the line which line count value equal to 1.                                                                    |
| 23:22      | RW          | 0x0                | sw_on_hdr_mode_id1<br>2'b00: Normal mode(no HDR)<br>2'b01: 2 frames HDR<br>2'b10: 3 frames HDR<br>2'b11: Reserved                                                                                                                                                                            |
| 21:20      | RW          | 0x0                | sw_hdr_mode_id1<br>2'b00: HDR distinguished by virtual channel<br>2'b01: HDR distinguished by line number(ON HDR mode)<br>2'b10: HDR distinguished by first 4pixel(SONY HDR mode)<br>2'b11: Reserved                                                                                         |
| 19:18      | RW          | 0x0                | sw_yuyv_out_order_id1<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                                                                                            |
| 17:16      | RW          | 0x0                | sw_yuyv_in_order_id1<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                                                                                             |
| 15:10      | RW          | 0x00               | sw_dt_id1<br>Data type for id1.                                                                                                                                                                                                                                                              |
| 9:8        | RW          | 0x0                | sw_vc_id1<br>Virtual channel for id1.                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5        | RW          | 0x0                | sw_wrddr_type_id1<br>The write ddr type of id1.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved              |
| 4          | RW          | 0x0                | sw_crop_en_id1<br>Enable to crop for id1.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                          |
| 3:1        | RW          | 0x0                | sw_parse_type_id1<br>The parse type of id1.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: For raw14(data will be clipped to 12bit)<br>3'b100: For yuv422 8bit<br>Others: Reserved |
| 0          | RW          | 0x0                | sw_cap_en_id1<br>Enable to capture id1.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                            |

**VICAP MIPI1 LVDS1 ID1 CTRL1**

Address: Operational Base + offset (0x030C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 29:16      | RW          | 0x0000             | sw_height_id1<br>Height for id1.                                                                                                                                                                                                                                                                                                  |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 13:0       | RW          | 0x0000             | sw_width_id1<br>Width for id1.if sw_wrddr_type is rgb888,then the width is equal to the number of bytes(not pixel).<br>If sw_crop_en_id1 is enable the width value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12, and must be 24 aligned when sw_wrddr_type is rgb888. |

**VICAP MIPI1 ID2 CTRL0**

Address: Operational Base + offset (0x0310)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RW          | 0x0                | sw_vc_hdr_id_main_id2<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_mode_idx=2'b00 and sw_vc_hdr_protect=1'b1.                                                                                                                                         |
| 29         | RW          | 0x0                | sw_vc_hdr_protect_id2<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.<br>Note: This register is available when sw_hdr_mode_idx=2'b00. And sw_vc_hdr_id_main must be configured correctly(the first coming id). |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28         | RW          | 0x0                | sw_dma_en_id2<br>Enable dma transport id2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                               |
| 27         | RW          | 0x0                | sw_align_id2<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: Hign alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                                       |
| 26         | RW          | 0x0                | sw_command_mode_en_id2<br>Select command mode for id2.<br>1'b0: Not command mode<br>1'b1: Command mode                                                                                                                    |
| 25:24      | RW          | 0x0                | sw_on_hdr_line_cnt_id2<br>If sw_mipi0_on_hdr_mode_id2=1(2),the line count value will circulate between 0~1(2).And if sw_mipi0_on_hdr_line_cnt_id2=1, id2 channel will capture the line which line count value equal to 1. |
| 23:22      | RW          | 0x0                | sw_on_hdr_mode_id2<br>2'b00: Normal mode(no HDR)<br>2'b01: 2 frames HDR<br>2'b10: 3 frames HDR<br>2'b11: Reserved                                                                                                         |
| 21:20      | RW          | 0x0                | sw_hdr_mode_id2<br>2'b00: HDR distinguished by virtual channel<br>2'b01: HDR distinguished by line number(ON HDR mode)<br>2'b10: HDR distinguished by first 4pixel(SONY HDR mode)<br>2'b11: Reserved                      |
| 19:18      | RW          | 0x0                | sw_yuyv_out_order_id2<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                         |
| 17:16      | RW          | 0x0                | sw_yuyv_in_order_id2<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                          |
| 15:10      | RW          | 0x00               | sw_dt_id2<br>Data type for id2.                                                                                                                                                                                           |
| 9:8        | RW          | 0x0                | sw_vc_id2<br>Virtual channel for id2.                                                                                                                                                                                     |
| 7:5        | RW          | 0x0                | sw_wrddr_type_id2<br>The write ddr type of id2.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved                    |
| 4          | RW          | 0x0                | sw_crop_en_id2<br>Enable to crop for id2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:1        | RW          | 0x0                | sw_parse_type_id2<br>The parse type of id2.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: For raw14(data will be clipped to 12bit)<br>3'b100: For yuv422 8bit<br>Others: Reserved |
| 0          | RW          | 0x0                | sw_cap_en_id2<br>Enable to capture id2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                            |

**VICAP MIPI1 LVDS1 ID2 CTRL1**

Address: Operational Base + offset (0x0314)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 29:16      | RW          | 0x0000             | sw_height_id2<br>Height for id2.                                                                                                                                                                                                                                                                                                  |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 13:0       | RW          | 0x0000             | sw_width_id2<br>Width for id2.if sw_wrddr_type is rgb888,then the width is equal to the number of bytes(not pixel).<br>If sw_crop_en_id2 is enable the width value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12, and must be 24 aligned when sw_wrddr_type is rgb888. |

**VICAP MIPI1 ID3 CTRL0**

Address: Operational Base + offset (0x0318)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RW          | 0x0                | sw_vc_hdr_id_main_id3<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_mode_idx=2'b00 and sw_vc_hdr_protect=1'b1.                                                                                                                                         |
| 29         | RW          | 0x0                | sw_vc_hdr_protect_id3<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.<br>Note: This register is available when sw_hdr_mode_idx=2'b00. And sw_vc_hdr_id_main must be configured correctly(the first coming id). |
| 28         | RW          | 0x0                | sw_dma_en_id3<br>Enable dma transport id3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                  |
| 27         | RW          | 0x0                | sw_align_id3<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                                                                                                          |
| 26         | RW          | 0x0                | sw_command_mode_en_id3<br>Select command mode for id3.<br>1'b0: Not command mode<br>1'b1: Command mode                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:24      | RW          | 0x0                | sw_on_hdr_line_cnt_id3<br>If sw_mipi0_on_hdr_mode_id3=1(2),the line count value will circulate between 0~1(2).And if sw_mipi0_on_hdr_line_cnt_id3=1, id3 channel will capture the line which line count value equal to 1. |
| 23:22      | RW          | 0x0                | sw_on_hdr_mode_id3<br>2'b00: Normal mode(no HDR)<br>2'b01: 2 frames HDR<br>2'b10: 3 frames HDR<br>2'b11: Reserved                                                                                                         |
| 21:20      | RW          | 0x0                | sw_hdr_mode_id3<br>2'b00: HDR distinguished by virtual channel<br>2'b01: HDR distinguished by line number(ON HDR mode)<br>2'b10: HDR distinguished by first 4pixel(SONY HDR mode)<br>2'b11: Reserved                      |
| 19:18      | RW          | 0x0                | sw_yuyv_out_order_id3<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                         |
| 17:16      | RW          | 0x0                | sw_yuyv_in_order_id3<br>2'b00 :UYVY(CSI-2 standard)<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                          |
| 15:10      | RW          | 0x00               | sw_dt_id3<br>Data type for id3.                                                                                                                                                                                           |
| 9:8        | RW          | 0x0                | sw_vc_id3<br>Virtual channel for id3.                                                                                                                                                                                     |
| 7:5        | RW          | 0x0                | sw_wrddr_type_id3<br>The write ddr type of id3.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved                    |
| 4          | RW          | 0x0                | sw_crop_en_id3<br>Enable to crop for id3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                |
| 3:1        | RW          | 0x0                | sw_parse_type_id3<br>The parse type of id3.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: For raw14(data will be clipped to 12bit)<br>3'b100: For yuv422 8bit<br>Others: Reserved       |
| 0          | RW          | 0x0                | sw_cap_en_id3<br>Enable to capture id3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                  |

**VICAP MIPI1 LVDS1 ID3 CTRL1**

Address: Operational Base + offset (0x031C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 29:16      | RW          | 0x0000             | sw_height_id3<br>Height for id3.                                                                                                                                                                                                                                                                                                  |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                          |
| 13:0       | RW          | 0x0000             | sw_width_id3<br>Width for id3.if sw_wrddr_type is rgb888,then the width is equal to the number of bytes(not pixel).<br>If sw_crop_en_id3 is enable the width value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12, and must be 24 aligned when sw_wrddy_type is rgb888. |

**VICAP MIPI1 LVDS1 CTRL**

Address: Operational Base + offset (0x0320)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RW          | 0x0                | sw_drop_frame_main_id<br>The id that is the last coming in HDR mode.                                                                                                                                                                |
| 29:24      | RW          | 0x00               | sw_drop_frame_m<br>Receive m frames, and drop n frames.(m>0,n>0)                                                                                                                                                                    |
| 23:21      | RW          | 0x0                | sw_drop_frame_n<br>Receive m frames, and drop n frames.(m>0,n>0)                                                                                                                                                                    |
| 20         | RW          | 0x0                | sw_drop_frame_en_all<br>1'b0: Disable drop all id frame<br>1'b1: Enable drop all id frame.                                                                                                                                          |
| 19:18      | RW          | 0x0                | sw_soft_RST_mode<br>2'b00: Soft reset and protect toisp path frame integrity;<br>2'b01: Soft reset and protect toisp path frame integrity and pull down sw_cap_en automatically;<br>2'b10: Soft reset directly;<br>2'b11: Reserved. |
| 17         | RW          | 0x0                | sw_soft_RST<br>1'b0: Not reset<br>1'b1: Reset the VICAP MIPI1 path(except MMU/AXI MASTER/REG FILE)                                                                                                                                  |
| 16         | RW          | 0x0                | sw_dma_RST<br>Write 1 will reset VICAP MIPI1 path dma.<br>When this bit change to 0, dma is reseted completely.                                                                                                                     |
| 15:13      | RW          | 0x0                | sw_press_value<br>Press value.                                                                                                                                                                                                      |
| 12         | RW          | 0x0                | sw_press_en<br>1'b0: Disable press<br>1'b1: Enable press                                                                                                                                                                            |
| 11         | RW          | 0x0                | sw_drop_frame_en_id3<br>1'b0: Disable drop id3 frame<br>1'b1: Enable drop id3 frame.                                                                                                                                                |
| 10         | RW          | 0x0                | sw_drop_frame_en_id2<br>1'b0: Disable drop id2 frame<br>1'b1: Enable drop id2 frame.                                                                                                                                                |
| 9          | RW          | 0x0                | sw_drop_frame_en_id1<br>1'b0: Disable drop id1 frame<br>1'b1: Enable drop id1 frame.                                                                                                                                                |
| 8          | RW          | 0x0                | sw_drop_frame_en_id0<br>1'b0: Disable drop id0 frame<br>1'b1: Enable drop id0 frame.                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 7:5        | RW          | 0x0                | sw_hurry_value<br>Hurry value.                                            |
| 4          | RW          | 0x0                | sw_hurry_en<br>1'b0: Disable hurry<br>1'b1: Enable hurry                  |
| 3          | RW          | 0x0                | sw_mipi_lvds_sel<br>1'b0: MIPI path<br>1'b1: LVDS path                    |
| 2:1        | RW          | 0x0                | sw_water_line<br>2'b00: 75%<br>2'b01: 50%<br>2'b10: 25%<br>2'b11: 0%      |
| 0          | RW          | 0x0                | sw_cap_en<br>1'b0: Disable capture all id<br>1'b1: Enable capture all id. |

**VICAP MIPI1 LVDS1 FRAME0 ADDR Y ID0**

Address: Operational Base + offset (0x0324)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_y_id0<br>First address of even frame for ID0 Y/Raw/RGB path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME1 ADDR Y ID0**

Address: Operational Base + offset (0x0328)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_y_id0<br>First address of odd frame for ID0 Y path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME0 ADDR UV ID0**

Address: Operational Base + offset (0x032C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_uv_id0<br>First address of even frame for ID0 UV path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME1 ADDR UV ID0**

Address: Operational Base + offset (0x0330)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_uv_id0<br>First address of odd frame for ID0 UV path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 VLW ID0**

Address: Operational Base + offset (0x0334)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                     |
| 19:0       | RW          | 0x00000            | sw_vlw_id0<br>Virtual line width of even frame for ID0 path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME0 ADDR Y ID1**

Address: Operational Base + offset (0x0338)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_y_id1<br>First address of even frame for ID1 Y/RAW/RGB path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME1 ADDR Y ID1**

Address: Operational Base + offset (0x033C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_y_id1<br>First address of odd frame for ID1 Y/RAW/RGB path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME0 ADDR UV ID1**

Address: Operational Base + offset (0x0340)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_uv_id1<br>First address of even frame for ID1 UV path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME1 ADDR UV ID1**

Address: Operational Base + offset (0x0344)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_uv_id1<br>First address of odd frame for ID1 UV path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 VLW ID1**

Address: Operational Base + offset (0x0348)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                               |
| 19:0       | RW          | 0x00000            | sw_vlw_id1<br>Virtual line width of even frame for ID1 Y/RAW/RGB path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME0 ADDR Y ID2**

Address: Operational Base + offset (0x034C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_y_id2<br>First address of even frame for ID2 Y/RAW/RGB path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME1 ADDR Y ID2**

Address: Operational Base + offset (0x0350)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_y_id2<br>First address of odd frame for ID2 Y/RAW/RGB path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME0 ADDR UV ID2**

Address: Operational Base + offset (0x0354)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_uv_id2<br>First address of even frame for ID2 UV path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME1 ADDR UV ID2**

Address: Operational Base + offset (0x0358)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_uv_id0<br>First address of odd frame for ID2 UV path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 VLW ID2**

Address: Operational Base + offset (0x035C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                     |
| 19:0       | RW          | 0x00000            | sw_vlw_id2<br>Virtual line width of even frame for ID2 path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME0 ADDR Y ID3**

Address: Operational Base + offset (0x0360)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_y_id3<br>First address of even frame for ID3 Y/Raw/RGB path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME1 ADDR Y ID3**

Address: Operational Base + offset (0x0364)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_y_id3<br>First address of odd frame for ID3 Y/Raw/RGB path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME0 ADDR UV ID3**

Address: Operational Base + offset (0x0368)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_uv_id3<br>First address of even frame for ID3 UV path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 FRAME1 ADDR UV ID3**

Address: Operational Base + offset (0x036C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_uv_id3<br>First address of odd frame for ID3 UV path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 VLW ID3**

Address: Operational Base + offset (0x0370)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                     |
| 19:0       | RW          | 0x00000            | sw_vlw_id3<br>Virtual line width of even frame for ID3 path(must be aligned to double word). |

**VICAP MIPI1 LVDS1 INTEN**

Address: Operational Base + offset (0x0374)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 27         | RW          | 0x0                | size_err_id3_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                        |
| 26         | RW          | 0x0                | size_err_id2_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                        |
| 25         | RW          | 0x0                | size_err_id1_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                        |
| 24         | RW          | 0x0                | size_err_id0_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                        |
| 23         | RW          | 0x0                | line_id3_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                            |
| 22         | RW          | 0x0                | line_id2_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                            |
| 21         | RW          | 0x0                | line_id1_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                            |
| 20         | RW          | 0x0                | line_id0_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                            |
| 19         | RW          | 0x0                | csi2rx_fifo_overflow_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                |
| 18         | RW          | 0x0                | bandwidth_lack_inten<br>1'b0: Disable<br>1'b1: Enable                                                                                      |
| 17         | RW          | 0x0                | dma_uv_fifo_overflow_inten<br>Enable the interrupt of dma fifo overflow of MIPI uv path or LVDS id1 path.<br>1'b0: Disable<br>1'b1: Enable |
| 16         | RW          | 0x0                | dma_y_fifo_overflow_inten<br>Enable the interrupt of dma fifo overflow of MIPI y path or LVDS id0 path.<br>1'b0: Disable<br>1'b1: Enable   |
| 15         | RW          | 0x0                | frame1_dma_end_id3_inten<br>Enable the interrupt of end of odd frame for ID1.<br>1'b0: Disable<br>1'b1: Enable                             |
| 14         | RW          | 0x0                | frame0_dma_end_id3_inten<br>Enable the interrupt of end of even frame for ID3.<br>1'b0: Disable<br>1'b1: Enable                            |
| 13         | RW          | 0x0                | frame1_dma_end_id2_inten<br>Enable the interrupt of end of odd frame for ID1.<br>1'b0: Disable<br>1'b1: Enable                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | frame0_dma_end_id2_inten<br>Enable the interrupt of end of even frame for ID2.<br>1'b0: Disable<br>1'b1: Enable |
| 11         | RW          | 0x0                | frame1_dma_end_id1_inten<br>Enable the interrupt of end of odd frame for ID1.<br>1'b0: Disable<br>1'b1: Enable  |
| 10         | RW          | 0x0                | frame0_dma_end_id1_inten<br>Enable the interrupt of end of even frame for ID1.<br>1'b0: Disable<br>1'b1: Enable |
| 9          | RW          | 0x0                | frame1_dma_end_id0_inten<br>Enable the interrupt of end of odd frame for ID0.<br>1'b0: Disable<br>1'b1: Enable  |
| 8          | RW          | 0x0                | frame0_dma_end_id0_inten<br>Enable the interrupt of end of even frame for ID0.<br>1'b0: Disable<br>1'b1: Enable |
| 7          | RW          | 0x0                | frame1_start_id3_inten<br>Enable the interrupt of start of odd frame for ID3.<br>1'b0: Disable<br>1'b1: Enable  |
| 6          | RW          | 0x0                | frame0_start_id3_inten<br>Enable the interrupt of start of even frame for ID3.<br>1'b0: Disable<br>1'b1: Enable |
| 5          | RW          | 0x0                | frame1_start_id2_inten<br>Enable the interrupt of start of odd frame for ID2.<br>1'b0: Disable<br>1'b1: Enable  |
| 4          | RW          | 0x0                | frame0_start_id2_inten<br>Enable the interrupt of start of even frame for ID2.<br>1'b0: Disable<br>1'b1: Enable |
| 3          | RW          | 0x0                | frame1_start_id1_inten<br>Enable the interrupt of start of odd frame for ID1.<br>1'b0: Disable<br>1'b1: Enable  |
| 2          | RW          | 0x0                | frame0_start_id1_inten<br>Enable the interrupt of start of even frame for ID1.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | frame1_start_id0_inten<br>Enable the interrupt of start of odd frame for ID0.<br>1'b0: Disable<br>1'b1: Enable  |
| 0          | RW          | 0x0                | frame0_start_id0_inten<br>Enable the interrupt of start of even frame for ID0.<br>1'b0: Disable<br>1'b1: Enable |

**VICAP MIPI1 LVDS1 INTSTAT**

Address: Operational Base + offset (0x0378)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                            |
| 27         | W1<br>C     | 0x0                | size_err_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt         |
| 26         | W1<br>C     | 0x0                | size_err_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt         |
| 25         | W1<br>C     | 0x0                | size_err_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt         |
| 24         | W1<br>C     | 0x0                | size_err_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt         |
| 23         | W1<br>C     | 0x0                | line_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt             |
| 22         | W1<br>C     | 0x0                | line_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt             |
| 21         | W1<br>C     | 0x0                | line_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt             |
| 20         | W1<br>C     | 0x0                | line_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt             |
| 19         | W1<br>C     | 0x0                | csi2rx_fifo_overflow_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 18         | W1<br>C     | 0x0                | bandwidth_lack_intst<br>1'b0: No interrupt<br>1'b1: Interrupt       |
| 17         | W1<br>C     | 0x0                | dma_uv_fifo_overflow_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 16         | W1<br>C     | 0x0                | dma_y_fifo_overflow_intst<br>1'b0: No interrupt<br>1'b1: Interrupt  |
| 15         | W1<br>C     | 0x0                | frame1_dma_end_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 14         | W1<br>C     | 0x0                | frame0_dma_end_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 13         | W1<br>C     | 0x0                | frame1_dma_end_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 12         | W1<br>C     | 0x0                | frame0_dma_end_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 11         | W1<br>C     | 0x0                | frame1_dma_end_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 10         | W1<br>C     | 0x0                | frame0_dma_end_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 9          | W1<br>C     | 0x0                | frame1_dma_end_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 8          | W1<br>C     | 0x0                | frame0_dma_end_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt |
| 7          | W1<br>C     | 0x0                | frame1_start_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 6          | W1<br>C     | 0x0                | frame0_start_id3_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 5          | W1<br>C     | 0x0                | frame1_start_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 4          | W1<br>C     | 0x0                | frame0_start_id2_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 3          | W1<br>C     | 0x0                | frame1_start_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 2          | W1<br>C     | 0x0                | frame0_start_id1_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 1          | W1<br>C     | 0x0                | frame1_start_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |
| 0          | W1<br>C     | 0x0                | frame0_start_id0_intst<br>1'b0: No interrupt<br>1'b1: Interrupt   |

**VICAP MIPI1 LVDS1 LINE INT NUM ID0\_1**

Address: Operational Base + offset (0x037C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | line_int_mode_id1<br>1'b0: One-time mode<br>1'b1: Circular mode                                                                                                                                                                                                     |
| 30         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |
| 29:16      | RW          | 0x0040             | line_int_num_id1<br>For one-time mode,if line_int_num_id1=100,then channel 1 receive 100th line,the line_id1_intst will be 1.<br>For circular mode ,if line_int_num_id1=100,then channel 1 receive 100th line200th line300th line.....the line_id1_intst will be 1. |
| 15         | RW          | 0x0                | line_int_mode_id0<br>1'b0: One-time mode<br>1'b1: Circular mode                                                                                                                                                                                                     |
| 14         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |
| 13:0       | RW          | 0x0040             | line_int_num_id0<br>For one-time mode,if line_int_num_id0=100,then channel 0 receive 100th line,the line_id0_intst will be 1.<br>For circular mode ,if line_int_num_id0=100,then channel 0 receive 100th line200th line300th line.....the line_id0_intst will be 1. |

**VICAP MIPI1 LVDS1 LINE INT NUM ID2 3**

Address: Operational Base + offset (0x0380)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | line_int_mode_id3<br>1'b0: One-time mode<br>1'b1: Circular mode                                                                                                                                                                                                     |
| 30         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |
| 29:16      | RW          | 0x0040             | line_int_num_id3<br>For one-time mode,if line_int_num_id3=100,then channel 3 receive 100th line,the line_id3_intst will be 1.<br>For circular mode ,if line_int_num_id3=100,then channel 3 receive 100th line200th line300th line.....the line_id3_intst will be 1. |
| 15         | RW          | 0x0                | line_int_mode_id2<br>1'b0: One-time mode<br>1'b1: Circular mode                                                                                                                                                                                                     |
| 14         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                            |
| 13:0       | RW          | 0x0040             | line_int_num_id2<br>For one-time mode,if line_int_num_id2=100,then channel 2 receive 100th line,the line_id2_intst will be 1.<br>For circular mode ,if line_int_num_id2=100,then channel 2 receive 100th line200th line300th line.....the line_id2_intst will be 1. |

**VICAP MIPI1 LVDS1 LINE CNT ID0 1**

Address: Operational Base + offset (0x0384)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                       |
| 29:16      | RO          | 0x0000             | ro_line_cnt_id1<br>Current line count for id1. |
| 15:14      | RO          | 0x0                | reserved                                       |
| 13:0       | RO          | 0x0000             | ro_line_cnt_id0<br>Current line count for id0. |

**VICAP MIPI1 LVDS1 LINE CNT ID2 3**

Address: Operational Base + offset (0x0388)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                          |
|------------|-------------|--------------------|---------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                    |
| 29:16      | RW          | 0x0000             | line_cnt_id3<br>Current line count for id3. |
| 15:14      | RO          | 0x0                | reserved                                    |
| 13:0       | RW          | 0x0000             | line_cnt_id2<br>Current line count for id2. |

**VICAP MIPI1 LVDS1 ID0 CROP START**

Address: Operational Base + offset (0x038C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                          |
| 29:16      | RW          | 0x0000             | sw_start_y_id0<br>The start y coordinate for id0. |
| 15:14      | RO          | 0x0                | reserved                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0       | RW          | 0x0000             | sw_start_x_id0<br>The start x coordinate for id0,if sw_wrddr_type is rgb888,then the start x is measured in byte.<br>The start x value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12,and must be 24 aligned when sw_wrddy_type is rgb888. |

**VICAP MIPI1 LVDS1 ID1 CROP START**

Address: Operational Base + offset (0x0390)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 29:16      | RW          | 0x0000             | sw_start_y_id1<br>The start y coordinate for id1.                                                                                                                                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 13:0       | RW          | 0x0000             | sw_start_x_id1<br>The start x coordinate for id1,if sw_wrddr_type is rgb888,then the start x is measured in byte.<br>The start x value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12,and must be 24 aligned when sw_wrddy_type is rgb888. |

**VICAP MIPI1 LVDS1 ID2 CROP START**

Address: Operational Base + offset (0x0394)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 29:16      | RW          | 0x0000             | sw_start_y_id2<br>The start y coordinate for id2.                                                                                                                                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 13:0       | RW          | 0x0000             | sw_start_x_id2<br>The start x coordinate for id2,if sw_wrddr_type is rgb888,then the start x is measured in byte.<br>The start x value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12,and must be 24 aligned when sw_wrddy_type is rgb888. |

**VICAP MIPI1 LVDS1 ID3 CROP START**

Address: Operational Base + offset (0x0398)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 29:16      | RW          | 0x0000             | sw_start_y_id3<br>The start y coordinate for id3.                                                                                                                                                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                             |
| 13:0       | RW          | 0x0000             | sw_start_x_id3<br>The start x coordinate for id3,if sw_wrddr_type is rgb888,then the start x is measured in byte.<br>The start x value must be 8 aligned when sw_wrddr_type is raw8/yuv422, must be 4 aligned when sw_wrddr_type is raw10/raw12,and must be 24 aligned when sw_wrddy_type is rgb888. |

**VICAP MIPI1 FRAME NUM VCO**

Address: Operational Base + offset (0x039C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | ro_frame_num_end_vc0<br>The frame number of frame end of virtual channel 0.     |
| 15:0       | RO          | 0x0000             | ro_frame_num_start_vc0<br>The frame number of frame start of virtual channel 0. |

**VICAP MIPI1 FRAME NUM VC1**

Address: Operational Base + offset (0x03A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | ro_frame_num_end_vc1<br>The frame number of frame end of virtual channel 1.     |
| 15:0       | RO          | 0x0000             | ro_frame_num_start_vc1<br>The frame number of frame start of virtual channel 1. |

**VICAP MIPI1 FRAME NUM VC2**

Address: Operational Base + offset (0x03A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | ro_frame_num_end_vc2<br>The frame number of frame end of virtual channel 2.     |
| 15:0       | RO          | 0x0000             | ro_frame_num_start_vc2<br>The frame number of frame start of virtual channel 2. |

**VICAP MIPI1 FRAME NUM VC3**

Address: Operational Base + offset (0x03A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | ro_frame_num_end_vc3<br>The frame number of frame end of virtual channel 3.     |
| 15:0       | RO          | 0x0000             | ro_frame_num_start_vc3<br>The frame number of frame start of virtual channel 3. |

**VICAP MIPI1 ID0 EFFECT CODE**

Address: Operational Base + offset (0x03AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                        |
| 29:16      | RW          | 0x0000             | sw_sony_effect_code1_id0<br>Effect code of id0 for sony sensor. |
| 15:14      | RO          | 0x0                | reserved                                                        |
| 13:0       | RW          | 0x0000             | sw_sony_effect_code0_id0<br>Effect code of id0 for sony sensor. |

**VICAP MIPI1 ID1 EFFECT CODE**

Address: Operational Base + offset (0x03B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                        |
| 29:16      | RW          | 0x0000             | sw_sony_effect_code1_id1<br>Effect code of id1 for sony sensor. |
| 15:14      | RO          | 0x0                | reserved                                                        |
| 13:0       | RW          | 0x0000             | sw_sony_effect_code0_id1<br>Effect code of id1 for sony sensor. |

**VICAP MIPI1 ID2 EFFECT CODE**

Address: Operational Base + offset (0x03B4)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 29:16      | RW          | 0x0000             | sw_sony_effect_code1_id2<br>Effect code of id2 for sony sensor. |
| 15:14      | RO          | 0x0                | reserved                                                        |
| 13:0       | RW          | 0x0000             | sw_sony_effect_code0_id2<br>Effect code of id2 for sony sensor. |

**VICAP MIPI1 ID3 EFFECT CODE**

Address: Operational Base + offset (0x03B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                        |
| 29:16      | RW          | 0x0000             | sw_sony_effect_code1_id3<br>Effect code of id3 for sony sensor. |
| 15:14      | RO          | 0x0                | reserved                                                        |
| 13:0       | RW          | 0x0000             | sw_sony_effect_code0_id3<br>Effect code of id3 for sony sensor. |

**VICAP MIPI1 ON PAD VALUE**

Address: Operational Base + offset (0x03BC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 31:14      | RO          | 0x00000            | reserved                                        |
| 13:0       | RW          | 0x0000             | sw_on_pad_value<br>Padding value for ON sensor. |

**VICAP MIPI1 LVDS1 SIZE NUM ID0**

Address: Operational Base + offset (0x03C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                             |
| 29:16      | RO          | 0x0000             | ro_line_num_id0<br>The id0 line number in one frame. |
| 15:14      | RO          | 0x0                | reserved                                             |
| 13:0       | RO          | 0x0000             | ro_pix_num_id0<br>The id0 pixel number in one line.  |

**VICAP MIPI1 LVDS1 SIZE NUM ID1**

Address: Operational Base + offset (0x03C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                             |
| 29:16      | RO          | 0x0000             | ro_line_num_id1<br>The id1 line number in one frame. |
| 15:14      | RO          | 0x0                | reserved                                             |
| 13:0       | RO          | 0x0000             | ro_pix_num_id1<br>The id1 pixel number in one line.  |

**VICAP MIPI1 LVDS1 SIZE NUM ID2**

Address: Operational Base + offset (0x03C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                             |
| 29:16      | RO          | 0x0000             | ro_line_num_id2<br>The id2 line number in one frame. |
| 15:14      | RO          | 0x0                | reserved                                             |
| 13:0       | RO          | 0x0000             | ro_pix_num_id2<br>The id2 pixel number in one line.  |

**VICAP MIPI1 LVDS1 SIZE NUM ID3**

Address: Operational Base + offset (0x03CC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                             |
| 29:16      | RO          | 0x0000             | ro_line_num_id3<br>The id3 line number in one frame. |
| 15:14      | RO          | 0x0                | reserved                                             |
| 13:0       | RO          | 0x0000             | ro_pix_num_id3<br>The id3 pixel number in one line.  |

**VICAP LVDS1 ID0 CTRL0**

Address: Operational Base + offset (0x03D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                    |
| 28:27      | RW          | 0x0                | sw_lvds_yuv_out_order_id0<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                       |
| 26:25      | RW          | 0x0                | sw_lvds_yuv_in_order_id0<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                        |
| 24:22      | RW          | 0x0                | sw_lvds_wrddr_type_id0<br>The write ddr type of id0.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved |
| 21:19      | RW          | 0x0                | sw_lvds_parse_type_id0<br>The parse type of id0.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: Reserved<br>3'b100: For yuv422 8bit<br>Others: Reserved                    |
| 18:17      | RW          | 0x0                | sw_lvds_hdr_id_main_id0<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_protect=1'b1.                                                                                   |
| 16         | RW          | 0x0                | sw_lvds_hdr_protect_id0<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.                                                       |
| 15         | RW          | 0x0                | sw_lvds_dma_en_id0<br>Enable dma transport id0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                            |
| 14         | RW          | 0x0                | sw_lvds_align_id0<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                    |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | sw_lvds_hdr_frame_id0<br>Only be used when the sw_lvds_mode_id0=3'b010.<br>1'b0: 2 frames hdr<br>1'b1: 3 frames hdr                                                                                                   |
| 11:10      | RW          | 0x0                | sw_lvds_fid_id0<br>Only be used when the sw_lvds_mode_id0=3'b011.<br>Choose the fid for id0.                                                                                                                          |
| 9:8        | RW          | 0x0                | sw_lvds_main_lane_id0<br>Choose the lane to parse the sync code                                                                                                                                                       |
| 7:4        | RW          | 0x0                | sw_lvds_lane_en_id0<br>Lane enable for id0.<br>eg : 4'b0011 represent lane 0/1 is enable.                                                                                                                             |
| 3:1        | RW          | 0x0                | sw_lvds_mode_id0<br>There are 4 modes.<br>3'b000: Ls-le...fs-fe or sav_act-eav_act...sav_blk-eav_blk<br>3'b001: Fs-le...ls-fe<br>3'b010: Sony dol hdr pattern 1<br>3'b011: Sony dol hdr pattern 2<br>other: Reserverd |
| 0          | RW          | 0x0                | sw_lvds_cap_en_id0<br>Enable to capture lvds id0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                    |

**VICAP LVDS1 ID1 CTRL0**

Address: Operational Base + offset (0x03D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                    |
| 28:27      | RW          | 0x0                | sw_lvds_yuv_out_order_id1<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                       |
| 26:25      | RW          | 0x0                | sw_lvds_yuv_in_order_id1<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                        |
| 24:22      | RW          | 0x0                | sw_lvds_wrddr_type_id1<br>The write ddr type of id1.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved |
| 21:19      | RW          | 0x0                | sw_lvds_parse_type_id1<br>The parse type of id1.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: Reserved<br>3'b100: For yuv422 8bit<br>Others: Reserved                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:17      | RW          | 0x0                | sw_lvds_hdr_id_main_id1<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_protect=1'b1.                                                                                            |
| 16         | RW          | 0x0                | sw_lvds_hdr_protect_id1<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.                                                                |
| 15         | RW          | 0x0                | sw_lvds_dma_en_id1<br>Enable dma transport id1.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                     |
| 14         | RW          | 0x0                | sw_lvds_align_id1<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                             |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                             |
| 12         | RW          | 0x0                | sw_lvds_hdr_frame_id1<br>Only be used when the sw_lvds_mode_id1=3'b010.<br>1'b0: 2 frames hdr<br>1'b1: 3 frames hdr                                                                                                  |
| 11:10      | RW          | 0x0                | sw_lvds_fid_id1<br>Only be used when the sw_lvds_mode_id0=3'b011.<br>Choose the fid for id1.                                                                                                                         |
| 9:8        | RW          | 0x0                | sw_lvds_main_lane_id1<br>Choose the lane to parse the sync code                                                                                                                                                      |
| 7:4        | RW          | 0x0                | sw_lvds_lane_en_id1<br>Lane enable for id1.<br>eg : 4'b0011 represent lane 0/1 is enable.                                                                                                                            |
| 3:1        | RW          | 0x0                | sw_lvds_mode_id1<br>There are 4 modes.<br>3'b000: Ls-le...fs-fe or sav_act-eav_act...sav_blk-eav_blk<br>3'b001: Fs-le...ls-fe<br>3'b010: Sony dol hdr pattern 1<br>3'b011: Sony dol hdr pattern 2<br>other: Reserved |
| 0          | RW          | 0x0                | sw_lvds_cap_en_id1<br>Enable to capture lvds id1.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                   |

**VICAP LVDS1 ID2 CTRL0**

Address: Operational Base + offset (0x03D8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                              |
| 28:27      | RW          | 0x0                | sw_lvds_yuv_out_order_id2<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU |
| 26:25      | RW          | 0x0                | sw_lvds_yuv_in_order_id2<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:22      | RW          | 0x0                | sw_lvds_wrddr_type_id2<br>The write ddr type of id2.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved          |
| 21:19      | RW          | 0x0                | sw_lvds_parse_type_id2<br>The parse type of id2.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: Reserved<br>3'b100: For yuv422 8bit<br>Others: Reserved                             |
| 18:17      | RW          | 0x0                | sw_lvds_hdr_id_main_id2<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_protect=1'b1.                                                                                            |
| 16         | RW          | 0x0                | sw_lvds_hdr_protect_id2<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.                                                                |
| 15         | RW          | 0x0                | sw_lvds_dma_en_id2<br>Enable dma transport id2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                     |
| 14         | RW          | 0x0                | sw_lvds_align_id2<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                             |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                             |
| 12         | RW          | 0x0                | sw_lvds_hdr_frame_id2<br>Only be used when the sw_lvds_mode_id2=3'b010.<br>1'b0: 2 frames hdr<br>1'b1: 3 frames hdr                                                                                                  |
| 11:10      | RW          | 0x0                | sw_lvds_fid_id2<br>Only be used when the sw_lvds_mode_id0=3'b011.<br>Choose the fid for id2.                                                                                                                         |
| 9:8        | RW          | 0x0                | sw_lvds_main_lane_id2<br>Choose the lane to parse the sync code                                                                                                                                                      |
| 7:4        | RW          | 0x0                | sw_lvds_lane_en_id2<br>Lane enable for id2.<br>eg : 4'b0011 represent lane 0/1 is enable.                                                                                                                            |
| 3:1        | RW          | 0x0                | sw_lvds_mode_id2<br>There are 4 modes.<br>3'b000: Ls-le...fs-fe or sav_act-eav_act...sav_blk-eav_blk<br>3'b001: Fs-le...ls-fe<br>3'b010: Sony dol hdr pattern 1<br>3'b011: Sony dol hdr pattern 2<br>other: Reserved |
| 0          | RW          | 0x0                | sw_lvds_cap_en_id2<br>Enable to capture lvds id2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                   |

**VICAP LVDS1 ID3 CTRL0**

Address: Operational Base + offset (0x03DC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                    |
| 28:27      | RW          | 0x0                | sw_lvds_yuv_out_order_id3<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                       |
| 26:25      | RW          | 0x0                | sw_lvds_yuv_in_order_id3<br>2'b00 :UYVY<br>2'b01 :VYUY<br>2'b10 :YUYV<br>2'b11 :YVYU                                                                                                                        |
| 24:22      | RW          | 0x0                | sw_lvds_wrddr_type_id3<br>The write ddr type of id3.<br>3'b000: Raw-compact<br>3'b001: Raw-uncompact<br>3'b010: YUV packet<br>3'b011: YUV 400<br>3'b100: YUV 422sp<br>3'b101: YUV 420sp<br>Others: Reserved |
| 21:19      | RW          | 0x0                | sw_lvds_parse_type_id3<br>The parse type of id3.<br>3'b000: For raw8/rgb888<br>3'b001: For raw10<br>3'b010: For raw12<br>3'b011: Reserved<br>3'b100: For yuv422 8bit<br>Others: Reserved                    |
| 18:17      | RW          | 0x0                | sw_lvds_hdr_id_main_id3<br>The id that is the first coming.<br>Note: This register is available when sw_hdr_protect=1'b1.                                                                                   |
| 16         | RW          | 0x0                | sw_lvds_hdr_protect_id3<br>1'b0: Not ensure hdr long exposure frame is captured firstly;<br>1'b1: Ensure hdr long exposure frame is captured firstly.                                                       |
| 15         | RW          | 0x0                | sw_lvds_dma_en_id3<br>Enable dma transport id3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                            |
| 14         | RW          | 0x0                | sw_lvds_align_id3<br>1'b0: Low alignment(raw10/12 will in [9:0]/[11:0])<br>1'b1: High alignment(raw10/12 will in [15:6]/[15:4])<br>Only be used when non-compacted mode.                                    |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                    |
| 12         | RW          | 0x0                | sw_lvds_hdr_frame_id3<br>Only be used when the sw_lvds_mode_id3=3'b010.<br>1'b0: 2 frames hdr<br>1'b1: 3 frames hdr                                                                                         |
| 11:10      | RW          | 0x0                | sw_lvds_fid_id3<br>Only be used when the sw_lvds_mode_id3=3'b011.<br>Choose the fid for id3.                                                                                                                |
| 9:8        | RW          | 0x0                | sw_lvds_main_lane_id3<br>Choose the lane to parse the sync code                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x0                | sw_lvds_lane_en_id3<br>Lane enable for id3.<br>eg : 4'b0011 represent lane 0/1 is enable.                                                                                                                             |
| 3:1        | RW          | 0x0                | sw_lvds_mode_id3<br>There are 4 modes.<br>3'b000: Ls-le...fs-fe or sav_act-eav_act...sav_blk-eav_blk<br>3'b001: Fs-le...ls-fe<br>3'b010: Sony dol hdr pattern 1<br>3'b011: Sony dol hdr pattern 2<br>other: Reserverd |
| 0          | RW          | 0x0                | sw_lvds_cap_en_id3<br>Enable to capture lvds id3.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                    |

**VICAP LVDS1 SAV EAV ACT0 ID0**

Address: Operational Base + offset (0x03E0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act0_id0<br>LVDS path sync code of eav_act0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act0_id0<br>LVDS path sync code of sav_act0. |

**VICAP LVDS1 SAV EAV BLK0 ID0**

Address: Operational Base + offset (0x03E4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk0_id0<br>LVDS path sync code of eav_blk0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk0_id0<br>LVDS path sync code of sav_blk0. |

**VICAP LVDS1 SAV EAV ACT1 ID0**

Address: Operational Base + offset (0x03E8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act1_id0<br>LVDS path sync code of eav_act1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act1_id0<br>LVDS path sync code of sav_act1. |

**VICAP LVDS1 SAV EAV BLK1 ID0**

Address: Operational Base + offset (0x03EC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk1_id0<br>LVDS path sync code of eav_blk1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk1_id0<br>LVDS path sync code of sav_blk1. |

**VICAP LVDS1 SAV EAV ACT0 ID1**

Address: Operational Base + offset (0x03F0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act0_id1<br>LVDS path sync code of eav_act0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act0_id1<br>LVDS path sync code of sav_act0. |

**VICAP LVDS1 SAV EAV BLK0 ID1**

Address: Operational Base + offset (0x03F4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk0_id1<br>LVDS path sync code of eav_blk0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk0_id1<br>LVDS path sync code of sav_blk0. |

**VICAP LVDS1 SAV EAV ACT1 ID1**

Address: Operational Base + offset (0x03F8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act1_id1<br>LVDS path sync code of eav_act1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act1_id1<br>LVDS path sync code of sav_act1. |

**VICAP LVDS1 SAV EAV BLK1 ID1**

Address: Operational Base + offset (0x03FC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk1_id1<br>LVDS path sync code of eav_blk1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk1_id1<br>LVDS path sync code of sav_blk1. |

**VICAP LVDS1 SAV EAV ACT0 ID2**

Address: Operational Base + offset (0x0400)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act0_id2<br>LVDS path sync code of eav_act0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act0_id2<br>LVDS path sync code of sav_act0. |

**VICAP LVDS1 SAV EAV BLK0 ID2**

Address: Operational Base + offset (0x0404)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk0_id2<br>LVDS path sync code of eav_blk0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk0_id2<br>LVDS path sync code of sav_blk0. |

**VICAP LVDS1 SAV EAV ACT1 ID2**

Address: Operational Base + offset (0x0408)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act1_id2<br>LVDS path sync code of eav_act1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act1_id2<br>LVDS path sync code of sav_act1. |

**VICAP LVDS1 SAV EAV BLK1 ID2**

Address: Operational Base + offset (0x040C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk1_id2<br>LVDS path sync code of eav_blk1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk1_id2<br>LVDS path sync code of sav_blk1. |

**VICAP LVDS1 SAV EAV ACT0 ID3**

Address: Operational Base + offset (0x0410)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act0_id3<br>LVDS path sync code of eav_act0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_act0_id3<br>LVDS path sync code of sav_act0. |

**VICAP LVDS1 SAV EAV BLK0 ID3**

Address: Operational Base + offset (0x0414)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk0_id3<br>LVDS path sync code of eav_blk0. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk0_id3<br>LVDS path sync code of sav_blk0. |

**VICAP LVDS1 SAV EAV ACT1 ID3**

Address: Operational Base + offset (0x0418)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_act1_id3<br>LVDS path sync code of eav_act1. |
| 15:12      | RO          | 0x0                | reserved                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 11:0       | RW          | 0x000              | sw_lvds_sav_act1_id3<br>LVDS path sync code of sav_act1. |

**VICAP LVDS1 SAV EAV BLK1 ID3**

Address: Operational Base + offset (0x041C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                 |
| 27:16      | RW          | 0x000              | sw_lvds_eav_blk1_id3<br>LVDS path sync code of eav_blk1. |
| 15:12      | RO          | 0x0                | reserved                                                 |
| 11:0       | RW          | 0x000              | sw_lvds_sav_blk1_id3<br>LVDS path sync code of sav_blk1. |

**VICAP SCL CH CTRL**

Address: Operational Base + offset (0x0700)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                |
| 7:3        | RW          | 0x00               | sw_scl_mux_ch0<br>5'd0: Select MIPI0 ID0<br>5'd1: Select MIPI0 ID1<br>5'd2: Select MIPI0 ID2<br>5'd3: Select MIPI0 ID3<br>5'd4: Select MIPI1 ID0<br>5'd5: Select MIPI1 ID1<br>5'd6: Select MIPI1 ID2<br>5'd7: Select MIPI1 ID3<br>5'd24: Select DVP<br>Others: Reserved |
| 2:1        | RW          | 0x0                | sw_scl_mode_ch0<br>Scale mode for channel 0.<br>2'b00: 8 times scale<br>2'b01: 16 times scale<br>2'b10: 32 times scale<br>Others: Reserved                                                                                                                              |
| 0          | RW          | 0x0                | sw_scl_en_ch0<br>Enable scale channel0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                |

**VICAP SCL CTRL**

Address: Operational Base + offset (0x0704)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                     |
| 16         | RW          | 0x0                | sw_soft_RST_ch0<br>Write 1 will reset VICAP SCALE channel 0 path.<br>When this bit change to 0, scale is reseted completely. |
| 15:13      | RW          | 0x0                | sw_press_value<br>Press value.                                                                                               |
| 12         | RW          | 0x0                | sw_press_en<br>1'b0: Disable press<br>1'b1: Enable press                                                                     |
| 11:8       | RO          | 0x0                | reserved                                                                                                                     |
| 7:5        | RW          | 0x0                | sw_hurry_value<br>Hurry value.                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 4          | RW          | 0x0                | sw_hurry_en<br>1'b0: Disable hurry<br>1'b1: Enable hurry             |
| 3          | RO          | 0x0                | reserved                                                             |
| 2:1        | RW          | 0x0                | sw_water_line<br>2'b00: 75%<br>2'b01: 50%<br>2'b10: 25%<br>2'b11: 0% |
| 0          | RO          | 0x0                | reserved                                                             |

**VICAP SCL FRAME0 ADDR CH0**

Address: Operational Base + offset (0x0708)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame0_addr_ch0<br>First address of even frame for CH0 path(must be aligned to double word). |

**VICAP SCL FRAME1 ADDR CH0**

Address: Operational Base + offset (0x070C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sw_frame1_addr_ch0<br>First address of odd frame for CH0 path(must be aligned to double word). |

**VICAP SCL VLW CH0**

Address: Operational Base + offset (0x0710)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                     |
| 19:0       | RW          | 0x00000            | sw_vlw_ch0<br>Virtual line width of even frame for CH0 path(must be aligned to double word). |

**VICAP SCL CH0 BLACK LEVEL**

Address: Operational Base + offset (0x0738)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 31:24      | RW          | 0x00               | sw_scl_ch0_black_11<br>The black level for scale channel0 bayer pattern 11 position. |
| 23:16      | RW          | 0x00               | sw_scl_ch0_black_10<br>The black level for scale channel0 bayer pattern 10 position. |
| 15:8       | RW          | 0x00               | sw_scl_ch0_black_01<br>The black level for scale channel0 bayer pattern 01 position. |
| 7:0        | RW          | 0x00               | sw_scl_ch0_black_00<br>The black level for scale channel0 bayer pattern 00 position. |

**VICAP TOISP0 CH CTRL**

Address: Operational Base + offset (0x0780)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                                                                   |
| 26:25      | RW          | 0x0                | sw_toisp0_vc_hdr_ch_main<br>Toisp0 vc hdr main channel.                                    |
| 24         | RW          | 0x0                | sw_toisp0_vc_hdr_protect<br>Enable toisp0 vc hdr protect.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:19      | RW          | 0x00               | sw_toisp0_mux_ch2<br>5'd0: Select MIPI0 ID0<br>5'd1: Select MIPI0 ID1<br>5'd2: Select MIPI0 ID2<br>5'd3: Select MIPI0 ID3<br>5'd4: Select MIPI1 ID0<br>5'd5: Select MIPI1 ID1<br>5'd6: Select MIPI1 ID2<br>5'd7: Select MIPI1 ID3<br>5'd24: Select DVP<br>Others: Reserved |
| 18:17      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                   |
| 16         | RW          | 0x0                | sw_toisp0_en_ch2<br>Enable toisp0 channel2.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                               |
| 15:11      | RW          | 0x00               | sw_toisp0_mux_ch1<br>5'd0: Select MIPI0 ID0<br>5'd1: Select MIPI0 ID1<br>5'd2: Select MIPI0 ID2<br>5'd3: Select MIPI0 ID3<br>5'd4: Select MIPI1 ID0<br>5'd5: Select MIPI1 ID1<br>5'd6: Select MIPI1 ID2<br>5'd7: Select MIPI1 ID3<br>5'd24: Select DVP<br>Others: Reserved |
| 10:9       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                   |
| 8          | RW          | 0x0                | sw_toisp0_en_ch1<br>Enable toisp0 channel1.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                               |
| 7:3        | RW          | 0x00               | sw_toisp0_mux_ch0<br>5'd0: Select MIPI0 ID0<br>5'd1: Select MIPI0 ID1<br>5'd2: Select MIPI0 ID2<br>5'd3: Select MIPI0 ID3<br>5'd4: Select MIPI1 ID0<br>5'd5: Select MIPI1 ID1<br>5'd6: Select MIPI1 ID2<br>5'd7: Select MIPI1 ID3<br>5'd24: Select DVP<br>Others: Reserved |
| 2:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                   |
| 0          | RW          | 0x0                | sw_toisp0_en_ch0<br>Enable toisp0 channel0.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                               |

**VICAP TOISP0 CROP SIZE**

Address: Operational Base + offset (0x0784)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                            |
| 29:16      | RW          | 0x01e0             | sw_height<br>The expected height of received image. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 15:14      | RO          | 0x0                | reserved                                          |
| 13:0       | RW          | 0x02d0             | sw_width<br>The expected width of received image. |

**VICAP\_TOISP0\_CROP\_START**

Address: Operational Base + offset (0x0788)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                  |
| 29:16      | RW          | 0x0000             | sw_start_y<br>The vertical ordinate of the start point.   |
| 15:14      | RO          | 0x0                | reserved                                                  |
| 13:0       | RW          | 0x0000             | sw_start_x<br>The horizontal ordinate of the start point. |

**26.5 Interface Description**

Table 26-2 VICAP Interface Description

| <b>Module Pin</b> | <b>Dir</b> | <b>Pad Name</b>                                                                             | <b>IOMUX Setting</b>                   |
|-------------------|------------|---------------------------------------------------------------------------------------------|----------------------------------------|
| vicap_clkout      | O          | MIPI_REFCLK_OUT0/VICAP_CLKOUT_M0/GPIO3_C4_d                                                 | VIIIOC_GPIO3C_IOMUX_SEL_H[2:0]=3'h1    |
|                   |            | DSMAUDIO_N//PWM11_IR_M2/UART5_TX_M1/I2C3_SCL_M1/VICAP_CLKOUT_M1/LCD_CLK/GPIO1_D3_d          | VENCIOC_GPIO1D_IOMUX_SEL_L[14:12]=3'h2 |
| vicap_clkin       | I          | MIPI/LVDS_D0N/VICAP_CLKIN_M0/GPIO3_C2_d                                                     | VIIIOC_GPIO3C_IOMUX_SEL_L[10:8]=3'h1   |
|                   |            | UART3_TX_M1/UART5_RTSN_M1/PWM3_IR_M2/VICAP_CLKIN_M1/LCD_DEN/GPIO1_D0_d                      | VENCIOC_GPIO1D_IOMUX_SEL_L[2:0]=3'h2   |
| vicap_href        | I          | MIPI/LVDS_D0P/VICAP_HSYNC_M0/GPIO3_C3_d                                                     | VIIIOC_GPIO3C_IOMUX_SEL_L[14:12]=3'h1  |
|                   |            | UART3_RX_M1/UART5_CTSN_M1/PWM10_M2/VICAP_HSYNC_M1/LCD_HSYNC/GPIO1_D1_d                      | VENCIOC_GPIO1D_IOMUX_SEL_L[6:4]=3'h2   |
| vicap_vsync       | I          | VICAP_VSYNC_M0/GPIO3_C5_d                                                                   | VIIIOC_GPIO3C_IOMUX_SEL_H[6:4]=3'h1    |
|                   |            | DSMAUDIO_P/PWM0_M1/SPI0_CS1n_M0/UART5_RX_M1/I2C3_SDA_M1/VICAP_VSYNC_M1/LCD_VSYNC/GPIO1_D2_d | VENCIOC_GPIO1D_IOMUX_SEL_L[10:8]=3'h2  |
| vicap_data0       | I          | MIPI/LVDS_D3N/VICAP_D0_M0/GPIO3_B0_d                                                        | VIIIOC_GPIO3B_IOMUX_SEL_L[2:0]=3'h1    |
|                   |            | VICAP_D0_M1/AVS_ARM/PWM0_M0/GPIO1_A2_d                                                      | VENCIOC_GPIO1A_IOMUX_SEL_L[10:8]=3'h3  |
| vicap_data1       | I          | MIPI/LVDS_D3P/VICAP_D1_M0/GPIO3_B1_d                                                        | VIIIOC_GPIO3B_IOMUX_SEL_L[6:4]=3'h1    |
|                   |            | VICAP_D1_M1/SPI1_CS1n_M0/PWM7_IR_M1/UART4_TX_M0/GPIO1_B1_d                                  | VENCIOC_GPIO1B_IOMUX_SEL_L[6:4]=3'h4   |
| vicap_data2       | I          | MIPI/LVDS_CK1N/VICAP_D2_M0/GPIO3_B2_d                                                       | VIIIOC_GPIO3B_IOMUX_SEL_L[10:8]=3'h1   |
|                   |            | SDMMC1_D1_M1/SPI0_CS0n_M0/PWM2_M2/VICAP_D2_M1/LCD_D7/GPIO1_C0_d                             | VENCIOC_GPIO1C_IOMUX_SEL_L[2:0]=3'h2   |
| vicap_data3       | I          | MIPI/LVDS_CK1P/VICAP_D3_M0/GPIO3_B3_d                                                       | VIIIOC_GPIO3B_IOMUX_SEL_L[14:12]=3'h1  |
|                   |            | SDMMC1_D0_M1/SPI0_CLK_M0/PWM4_M2/VICAP_D3_M1/LCD_D6/GPIO1_C1_d                              | VENCIOC_GPIO1C_IOMUX_SEL_L[6:4]=3'h2   |
| vicap_data4       | I          | MIPI/LVDS_D2N/VICAP_D4_M0/GPIO3_B4_d                                                        | VIIIOC_GPIO3B_IOMUX_SEL_H[2:0]=3'h1    |
|                   |            | SPI0_MOSI_M0/SDMMC1_CLK_M1/I2C4_SCL_M1/PWM5_M2/VICAP_D4_M1/LCD_D5/GPIO1_C2_d                | VENCIOC_GPIO1C_IOMUX_SEL_L[10:8]=3'h2  |
| vicap_data5       | I          | MIPI/LVDS_D2P/VICAP_D5_M0/GPIO3_B5_d                                                        | VIIIOC_GPIO3B_IOMUX_SEL_H[6:4]=3'h1    |

| Module Pin   | Dir | Pad Name                                                                         | IOMUX Setting                              |
|--------------|-----|----------------------------------------------------------------------------------|--------------------------------------------|
|              |     | SPI0_MISO_M0/SDMMC1_CMD_M1/I2C4_SDA_M1/<br>PWM6_M2/VICAP_D5_M1/LCD_D4(GPIO1_C3_d | VENCIOC_GPIO1C_IOMUX<br>_SEL_L[14:12]=3'h2 |
| vicap_data6  | I   | MIPI/LVDS_D1N/VICAP_D6_M0(GPIO3_B6_d                                             | VIIOC_GPIO3B_IOMUX_SE<br>L_H[10:8]=3'h1    |
|              |     | SDMMC1_D3_M1/UART4_RX_M1/PWM8_M1/VICAP_<br>D6_M1/LCD_D3(GPIO1_C4_d               | VENCIOC_GPIO1C_IOMUX<br>_SEL_H[2:0]=3'h2   |
| vicap_data7  | I   | MIPI/LVDS_D1P/VICAP_D7_M0(GPIO3_B7_d                                             | VIIOC_GPIO3B_IOMUX_SE<br>L_H[14:12]=3'h1   |
|              |     | SDMMC1_D2_M1/UART4_TX_M1/PWM9_M1/VICAP_<br>D7_M1/LCD_D2(GPIO1_C5_d               | VENCIOC_GPIO1C_IOMUX<br>_SEL_H[6:4]=3'h2   |
| vicap_data8  | I   | MIPI/LVDS_CK0N/VICAP_D8_M0(GPIO3_C0_d                                            | VIIOC_GPIO3C_IOMUX_SE<br>L_L[2:0]=3'h1     |
|              |     | UART4_RTSN_M1/PWM10_M1/VICAP_D8_M1/LCD_<br>D1(GPIO1_C6_d                         | VENCIOC_GPIO1C_IOMUX<br>_SEL_H[10:8]=3'h2  |
| vicap_data9  | I   | MIPI/LVDS_CK0P/VICAP_D9_M0(GPIO3_C1_d                                            | VIIOC_GPIO3C_IOMUX_SE<br>L_L[6:4]=3'h1     |
|              |     | UART4_CTSN_M1/PWM11_IR_M1/VICAP_D9_M1/LC<br>D_D0(GPIO1_C7_d                      | VENCIOC_GPIO1C_IOMUX<br>_SEL_H[14:12]=3'h2 |
| vicap_data10 | I   | MIPI_REFCLK_OUT1/PWM7_IR_M2/VICAP_D10/GPI<br>O3_C6_d                             | VIIOC_GPIO3C_IOMUX_SE<br>L_H[10:8]=3'h1    |
| vicap_data11 | I   | I2C4_SCL_M2/UART5_TX_M2/VICAP_D11(GPIO3_C<br>7_d                                 | VIIOC_GPIO3C_IOMUX_SE<br>L_H[14:12]=3'h1   |
| vicap_data12 | I   | I2C4_SDA_M2/UART5_RX_M2/VICAP_D12(GPIO3_D<br>0_d                                 | VIIOC_GPIO3D_IOMUX_SE<br>L_L[2:0]=3'h1     |
| vicap_data13 | I   | I2C3_SCL_M2/UART5_RTSN_M2/VICAP_D13(GPIO3<br>D1_d                                | VIIOC_GPIO3D_IOMUX_SE<br>L_L[6:4]=3'h1     |
| vicap_data14 | I   | I2C3_SDA_M2/UART5_CTSN_M2/VICAP_D14(GPIO3<br>D2_d                                | VIIOC_GPIO3D_IOMUX_SE<br>L_L[10:8]=3'h1    |
| vicap_data15 | I   | PWM1_M2/VICAP_D15(GPIO3_D3_d                                                     | VIIOC_GPIO3D_IOMUX_SE<br>L_L[14:12]=3'h1   |

Notes: I=input, O=output, I/O=input/output, bidirectional

Furthermore, different IOs are selected and connected to different flash interface, which is shown as follows.

## 26.6 Application Notes

### 26.6.1 DVP Interface

- The MSB 4 bits of SAV/EAV of BT.656/BT.1120 are configurable, and the default values of SAV/EAV abide by the agreement.
- The sw\_only\_sav\_mode for BT.656/BT.1120 is more robust for the case that the EAV is wrong.
- User can read the register of ro\_sync\_header\_0~ro\_sync\_header\_7 to obtain the recent 8 SAV/EAV.
- The register sw\_yuyv\_in\_order should be configured correctly. In the BT.1120 case 2'h0/2'h2 are the same for UV sequence and 2'h1/2'h3 are the same for VU sequence.
- In the dual-edge sampling case, the GRF\_VI\_CIF\_CON[2] must be set to 1, and the register sw\_dualedge\_en must be set to 1. The clock phase could be adjusted by setting the GRF\_VI\_CIF\_CON[10:3].
- User can select the M1 by setting the register GRF\_VI\_CIF\_CON[0]=1.

User can invert the ckinm0 by setting the register GRF\_VI\_CIF\_CON[1]=1. User can invert the ckinm1 by setting the register VENC\_CIF\_IO\_WRAPPER[0]=1.

### 26.6.2 MIPI Interface

- The register sw\_crop\_en is suggested to be set to 1. The register sw\_width/sw\_start\_x should be aligned to 4.
- In the sony identification code hdr mode, the register sw\_sony\_effect\_code0/1 should be configured correctly according to the camera manual.
- In the line counter hdr mode, the register sw\_on\_pad\_value should be configured correctly according to the camera manual.

- In the VC hdr mode, the register sw\_vc\_hdr\_protect is suggested to be set to 1, and the register sw\_vc\_hdr\_id\_main should be configured as the first coming id that is the long exposure frame id.
- The register sw\_cap\_en\_idx is recommended for static configuration, and the register sw\_cap\_en is recommended for dynamic configuration.
- The MIPI interface can receive DSI data, but there are following restrictions on DSI TX: (1) one row of data could not be split into multiple long packets; (2) multiple packets could not be concatenated within a single HS transmission.

### **26.6.3 LVDS Interface**

- The sync code register (sw\_lvds\_sav\_act0\_id0,sw\_lvds\_eav\_act0\_id0...) must be configured correctly by the user.
- There are four LVDS sync mode can be selected by sw\_lvds\_mode\_idx. Mode0: ls-le...fs-fe or sav\_act-eav\_act...sav\_blk-eav\_blk. Mode1:fs-le...ls-fe. Mode2: sony dol hdr pattern 1. Mode3:sony dol hdr pattern 2. And if the mode is mode2, the user also need configure the register sw\_lvds\_hdr\_frame\_idx. If the mode is mode3, the user also need configure the register sw\_lvds\_fid\_idx.

### **26.6.4 Scale down**

- The register sw\_scl\_chx\_black\_00/01/10/11 is the black level value for bayer pattern 00/01/10/11 position.
- The bit width of scale down output data is 16. When the max bit width of the scale down output data exceed 16, output data will be clipped. For example, 8 times scale down for RAW12, the bit width is 18, then the result will be clipped to 16 bits.
- When the width is not a multiple of double scale down times, then the result will be rounded up to an integer. For example, the image width is 4656 and 32 times scaling down is performed, the result width equals to  $(\text{ceil}(4656/64)*64)/32$ .
- When the height is not a multiple of double scale down times, then the result will be rounded down to an integer. For example, the image height is 1080 and 8 times scaling down is performed, the result height equals to  $(\text{floor}(1080/16)*16)/8$ .

### **26.6.5 TOISP**

- The register sw\_width/sw\_start\_x should be aligned to 4.
- Although there are three channels to ISP, user just need enable channel 0 and select the short exposure frame id.

### **26.6.6 DMA**

- The start address/virtual stride should be aligned to 8 at least. And being aligned to 64 is good for DDR.
- User could shut down DMA transferring by setting the register sw\_dma\_en to 0.
- User could set sw\_hurry\_en/sw\_press\_en to 1 for dynamic adjusting the priority of VICAP. And the register sw\_water\_line is the triggering condition of pulling up hurry/press signal.
- The register sw\_yuv\_out\_order is effective when the register sw\_wrddr\_type is NV16/NV12/YUYV. And in the NV16/NV12 case, 2'h0/2'h2 are the same for UV sequence and 2'h1/2'h3 are the same for VU sequence.
- There are two modes for line counter interrupt. In one-time mode, if line\_int\_num =100, the line\_intst will be 1 when receive 100th line. In circular mode, if line\_int\_num =100, the line\_intst will be 1 when receive 100th line200th line300th line.....
- The DMA has two transfer strategies :1. transfer image according to the actual height of reception. 2. transfer image according to the configured height. Which strategy you choose depends the register sw\_dma\_adapt\_en.

### **26.6.7 Reset**

- DMA will be auto-reset when DMA goes wrong, for example fifo overflow. And DMA will transfer data from the next frame.
- DMA also could be soft-reset by the register sw\_dma\_RST.
- User could reset the entire data path (interface/dma) by setting the register sw\_soft\_RST to 1. And the scale/toisp module will be reset if the sw\_scl\_mux/sw\_toisp\_mux is setted to choose the path.

## Chapter 27 Mailbox

### 27.1 Overview

The Mailbox module is a simple APB peripheral that allows CPU, MCU core to communicate with each other by writing operation to generate interrupt. The registers are accessible via APB interface.

The Mailbox has the following main features:

- Support APB interface
- Support four mailbox elements, each element includes one data word, one command word register and one flag bit that can represent one interrupt
- Support interrupts to CPU, and MCU core
- Provide 32 lock registers for software to use to indicate whether mailbox is occupied

### 27.2 Block Diagram



Fig. 27-1 Mailbox Block Diagram

### 27.3 Function Description

#### 27.3.1 Mailbox

- Regard CPU as the “AP” side of the Mailbox. The four elements interrupt to CPU is:
  - Enabled when MAILBOX\_B2A\_INTEN is set to 1 and the responding IRQs is enabled in GIC.
  - Generated when there are writing operation to corresponding MAILBOX\_B2A\_CMD\_i and MAILBOX\_B2A\_DAT\_i orderly.
  - Cleared when writing 1 to corresponding MAILBOX\_B2A\_STATUS.
- Regard MCU core as the “BB” side of the Mailbox. The four elements interrupt to MCU core is:
  - Enabled when MAILBOX\_A2B\_INTEN is set to 1 and the responding IRQs is enabled in INTC of MCU.
  - Generated when there are writing operation to corresponding MAILBOX\_A2B\_CMD\_i and MAILBOX\_A2B\_DAT\_i orderly.
  - Cleared when writing 1 to corresponding MAILBOX\_A2B\_STATUS.
- You can also regard CPU as the “BB” side of the Mailbox and regard MCU core as the “AP” side of the Mailbox. The configuration flow is similar.

### 27.4 Register Description

#### 27.4.1 Registers Summary

| Name               | Offset | Size | Reset Value | Description                        |
|--------------------|--------|------|-------------|------------------------------------|
| MAILBOX_A2B_INTEN  | 0x0000 | W    | 0x00000000  | AP to BB Interrupt Enable Register |
| MAILBOX_A2B_STATUS | 0x0004 | W    | 0x00000000  | AP to BB Interrupt Status Register |
| MAILBOX_A2B_CMD_0  | 0x0008 | W    | 0x00000000  | AP to BB Command 0 Register        |
| MAILBOX_A2B_DAT_0  | 0x000C | W    | 0x00000000  | AP to BB Data 0 Register           |
| MAILBOX_A2B_CMD_1  | 0x0010 | W    | 0x00000000  | AP to BB Command 1 Register        |
| MAILBOX_A2B_DAT_1  | 0x0014 | W    | 0x00000000  | AP to BB Data 1 Register           |
| MAILBOX_A2B_CMD_2  | 0x0018 | W    | 0x00000000  | AP to BB Command 2 Register        |
| MAILBOX_A2B_DAT_2  | 0x001C | W    | 0x00000000  | AP to BB Data 2 Register           |

| Name               | Offset | Size | Reset Value | Description                        |
|--------------------|--------|------|-------------|------------------------------------|
| MAILBOX A2B CMD 3  | 0x0020 | W    | 0x00000000  | AP to BB Command 3 Register        |
| MAILBOX A2B DAT 3  | 0x0024 | W    | 0x00000000  | AP to BB Data 3 Register           |
| MAILBOX B2A INTEN  | 0x0028 | W    | 0x00000000  | BB to AP Interrupt Enable Register |
| MAILBOX B2A STATUS | 0x002C | W    | 0x00000000  | BB to AP Interrupt Status Register |
| MAILBOX B2A CMD 0  | 0x0030 | W    | 0x00000000  | BB to AP Command 0 Register        |
| MAILBOX B2A DAT 0  | 0x0034 | W    | 0x00000000  | BB to AP Data 0 Register           |
| MAILBOX B2A CMD 1  | 0x0038 | W    | 0x00000000  | BB to AP Command 1 Register        |
| MAILBOX B2A DAT 1  | 0x003C | W    | 0x00000000  | BB to AP Data 1 Register           |
| MAILBOX B2A CMD 2  | 0x0040 | W    | 0x00000000  | BB to AP Command 2 Register        |
| MAILBOX B2A DAT 2  | 0x0044 | W    | 0x00000000  | BB to AP Data 2 Register           |
| MAILBOX B2A CMD 3  | 0x0048 | W    | 0x00000000  | BB to AP Command 3 Register        |
| MAILBOX B2A DAT 3  | 0x004C | W    | 0x00000000  | BB to AP Data 3 Register           |

Notes: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 27.4.2 Detail Register Description

### MAILBOX A2B INTEN

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                         |
|------|------|-------------|---------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                            |
| 3    | RW   | 0x0         | int3<br>Interrupt enable for int3.<br>1'b0: Disable<br>1'b1: Enable |
| 2    | RW   | 0x0         | int2<br>Interrupt enable for int2.<br>1'b0: Disable<br>1'b1: Enable |
| 1    | RW   | 0x0         | int1<br>Interrupt enable for int1.<br>1'b0: Disable<br>1'b1: Enable |
| 0    | RW   | 0x0         | int0<br>Interrupt enable for int0.<br>1'b0: Disable<br>1'b1: Enable |

### MAILBOX A2B STATUS

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                     |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                        |
| 3    | W1C  | 0x0         | int3<br>Interrupt status for int3.<br>Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |
| 2    | W1C  | 0x0         | int2<br>Interrupt status for int2.<br>Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | W1<br>C     | 0x0                | int1<br>Interrupt status for int1.<br>Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |
| 0          | W1<br>C     | 0x0                | int0<br>Interrupt status for int0.<br>Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |

**MAILBOX A2B CMD 0**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | command<br>Command register. |

**MAILBOX A2B DAT 0**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:0       | RW          | 0x00000000         | data<br>Data register. |

**MAILBOX A2B CMD 1**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | command<br>Command register. |

**MAILBOX A2B DAT 1**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:0       | RW          | 0x00000000         | data<br>Data register. |

**MAILBOX A2B CMD 2**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | command<br>Command register. |

**MAILBOX A2B DAT 2**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:0       | RW          | 0x00000000         | data<br>Data register. |

**MAILBOX A2B CMD 3**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | command<br>Command register. |

**MAILBOX A2B DAT 3**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:0       | RW          | 0x00000000         | data<br>Data register. |

**MAILBOX\_B2A\_INTEN**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                            |
| 3          | RW          | 0x0                | int3<br>Interrupt enable for int3.<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x0                | int2<br>Interrupt enable for int2.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | int1<br>Interrupt enable for int1.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | int0<br>Interrupt enable for int0.<br>1'b0: Disable<br>1'b1: Enable |

**MAILBOX\_B2A\_STATUS**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                        |
| 3          | W1<br>C     | 0x0                | int3<br>Interrupt status for int3.<br>Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |
| 2          | W1<br>C     | 0x0                | int2<br>Interrupt status for int2.<br>Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |
| 1          | W1<br>C     | 0x0                | int1<br>Interrupt status for int1.<br>Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |
| 0          | W1<br>C     | 0x0                | int0<br>Interrupt status for int0.<br>Clear the interrupt by writing 1 to this bit.<br>1'b0: Interrupt is inactive<br>1'b1: Interrupt is active |

**MAILBOX\_B2A\_CMD\_0**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | command<br>Command register. |

**MAILBOX B2A DAT 0**

Address: Operational Base + offset (0x0034)

| Bit  | Attr | Reset Value | Description            |
|------|------|-------------|------------------------|
| 31:0 | RW   | 0x00000000  | data<br>Data register. |

**MAILBOX B2A CMD 1**

Address: Operational Base + offset (0x0038)

| Bit  | Attr | Reset Value | Description                  |
|------|------|-------------|------------------------------|
| 31:0 | RW   | 0x00000000  | command<br>Command register. |

**MAILBOX B2A DAT 1**

Address: Operational Base + offset (0x003C)

| Bit  | Attr | Reset Value | Description            |
|------|------|-------------|------------------------|
| 31:0 | RW   | 0x00000000  | data<br>Data register. |

**MAILBOX B2A CMD 2**

Address: Operational Base + offset (0x0040)

| Bit  | Attr | Reset Value | Description                  |
|------|------|-------------|------------------------------|
| 31:0 | RW   | 0x00000000  | command<br>Command register. |

**MAILBOX B2A DAT 2**

Address: Operational Base + offset (0x0044)

| Bit  | Attr | Reset Value | Description            |
|------|------|-------------|------------------------|
| 31:0 | RW   | 0x00000000  | data<br>Data register. |

**MAILBOX B2A CMD 3**

Address: Operational Base + offset (0x0048)

| Bit  | Attr | Reset Value | Description                  |
|------|------|-------------|------------------------------|
| 31:0 | RW   | 0x00000000  | command<br>Command register. |

**MAILBOX B2A DAT 3**

Address: Operational Base + offset (0x004C)

| Bit  | Attr | Reset Value | Description            |
|------|------|-------------|------------------------|
| 31:0 | RW   | 0x00000000  | data<br>Data register. |

**27.5 Application Notes**

- It is recommended to read one ATOMIC\_LOCK register first when using the Mailbox. The read value is 0 means it is available, and 1 means it has been automatically locked. Writing to the ATOMIC\_LOCK register will clear this bit.
- Write to the CMD register before writing to the DAT register. If wrong order is used, then the interrupt cannot be generated successfully.
- If you want to clear the interrupt, you can read out the STATUS register and writing 1 to corresponding bit.

## Chapter 28 Watchdog Timer (WDT)

### 28.1 Overview

Watchdog Timer (WDT) is an APB slave peripheral that can be used to prevent system lockup that caused by conflicting parts or programs in a SOC. The WDT would generate interrupt or reset signal when its counter reaches zero, then a reset controller would reset the system.

WDT supports the following features:

- 32 bits APB bus width
- WDT counter's clock can be chosen from 24MHz or 32KHz clock
- 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
- There are 3 WDTs: WDT, WDTS, WDT\_PMU
- All the five WDTs can drive CRU to generate global software reset

### 28.2 Block Diagram



Fig. 28-1 WDT Block Diagram

WDT comprises with:

- 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.

### 28.3 Function Description

#### 28.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.

### **28.3.2 Programming Sequence**



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. 28-2 WDT Operation Flow (RMOD=1)

## 28.4 Register Description

#### **28.4.1 Registers Summary**

| Name     | Offset | Size | Reset Value | Description                    |
|----------|--------|------|-------------|--------------------------------|
| WDT_CR   | 0x0000 | W    | 0x00000008  | Control Register               |
| WDT_TORR | 0x0004 | W    | 0x00000000  | Timeout Range Register         |
| WDT_CCVR | 0x0008 | W    | 0x0000FFFF  | Current Counter Value Register |

| Name     | Offset | Size | Reset Value | Description               |
|----------|--------|------|-------------|---------------------------|
| WDT_CRR  | 0x000C | W    | 0x00000000  | Counter Restart Register  |
| WDT_STAT | 0x0010 | W    | 0x00000000  | Interrupt Status Register |
| WDT_FOI  | 0x0014 | W    | 0x00000000  | Interrupt Clear Register  |

Notes: **S**-ize: **B**- Byte (8 bits) access, **H**W- Half WORD (16 bits) access, **W**-WORD (32 bits) access, **DW**- Double WORD (64 bits) access

## 28.4.2 Detail Registers Description

### WDT\_CR

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4:2  | RW   | 0x2         | <p>rst_pluse_length<br/>           This is used to select the number of pclk cycles for which the system reset stays asserted.<br/>           3'b000: 2 pclk cycles<br/>           3'b001: 4 pclk cycles<br/>           3'b010: 8 pclk cycles<br/>           3'b011: 16 pclk cycles<br/>           3'b100: 32 pclk cycles<br/>           3'b101: 64 pclk cycles<br/>           3'b110: 128 pclk cycles<br/>           3'b111: 256 pclk cycles</p> |
| 1    | RW   | 0x0         | <p>resp_mode<br/>           Selects the output response generated to a timeout.<br/>           1'b0: Generate a system reset.<br/>           1'b1: First generate an interrupt and if it is not cleared by the time a second timeout occurs then generate a system reset.</p>                                                                                                                                                                     |
| 0    | RW   | 0x0         | <p>en<br/>           This bit is used to enable and disable the WDT. When disabled, the counter dose not decrement .Thus, no interrupt or system reset are generated. Once this bit has been enabled, it can be cleared only by a system reset.<br/>           1'b0: WDT disabled.<br/>           1'b1: WDT enabled.</p>                                                                                                                          |

### WDT\_TORR

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3:0  | RW   | 0x0         | <p>timeout_period<br/>           This field is used to select the timeout period from which the watchdog counter restarts. A change of the timeout period takes effect only after the next counter restart (kick).<br/>           The range of values available for a 32-bit watchdog counter are:<br/>           4'b0000: 0x0000ffff<br/>           4'b0001: 0x0001ffff<br/>           4'b0010: 0x0003ffff<br/>           4'b0011: 0x0007ffff<br/>           4'b0100: 0x000fffff<br/>           4'b0101: 0x001fffff<br/>           4'b0110: 0x003fffff<br/>           4'b0111: 0x007fffff<br/>           4'b1000: 0x00ffffff<br/>           4'b1001: 0x01ffffff<br/>           4'b1010: 0x03ffffff<br/>           4'b1011: 0x07ffffff</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
|            |             |                    | 4'b1100: 0x0fffffff<br>4'b1101: 0x1fffffff<br>4'b1110: 0x3fffffff<br>4'b1111: 0x7fffffff |

**WDT\_CCSR**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x0000ffff         | cur_cnt<br>This register, when read, is the current value of the internal counter. This value is read coherently whenever it is read. |

**WDT\_CRR**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                          |
| 7:0        | WO          | 0x00               | cnt_restart<br>This register is used to restart the WDT counter. As a safety feature to prevent accidental restarts, the value 0x76 must be written. A restart also clears the WDT interrupt. Reading this register returns zero. |

**WDT\_STAT**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                            |
| 0          | RO          | 0x0                | status<br>This register shows the interrupt status of the WDT.<br>1'b1: Interrupt is active regardless of polarity.<br>1'b0: Interrupt is inactive. |

**WDT\_EOI**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                    |
| 0          | RO          | 0x0                | int_clr<br>This can be used to clear the interrupt without restarting the watchdog counter. |