

***Rockchip***  
***RV1109/RV1126***  
***Technical Reference Manual***  
***Part1***

Revision 1.0  
June. 2020

## **Revision History**

| <b>Date</b> | <b>Revision</b> | <b>Description</b> |
|-------------|-----------------|--------------------|
| 2020-6-5    | 1.0             | Initial Release    |

## **Table of Content**

|                                                  |     |
|--------------------------------------------------|-----|
| Table of Content .....                           | 3   |
| Figure Index .....                               | 8   |
| Table Index .....                                | 11  |
| Warranty Disclaimer .....                        | 13  |
| Appendix.....                                    | 14  |
| Chapter 1 System Overview.....                   | 20  |
| 1.1 Address Mapping.....                         | 20  |
| 1.2 System Boot.....                             | 21  |
| 1.3 System Interrupt Connection.....             | 23  |
| 1.4 System DMA Hardware Request Connection ..... | 26  |
| Chapter 2 Cortex-A7 .....                        | 27  |
| 2.1 Overview .....                               | 27  |
| 2.2 Block Diagram .....                          | 27  |
| 2.3 Function Description.....                    | 27  |
| 2.4 Register Description .....                   | 27  |
| Chapter 3 RISC-V .....                           | 28  |
| 3.1 Overview .....                               | 28  |
| 3.2 Block Diagram .....                          | 28  |
| 3.3 Function Description.....                    | 28  |
| 3.4 Register Description .....                   | 30  |
| 3.5 Interface Description .....                  | 44  |
| 3.6 Application Notes .....                      | 45  |
| 3.7 Referenced documents .....                   | 45  |
| Chapter 4 Embedded SRAM .....                    | 46  |
| 4.1 Overview .....                               | 46  |
| 4.2 Block Diagram .....                          | 46  |
| 4.3 Function Description.....                    | 46  |
| Chapter 5 Clock & Reset Unit (CRU) .....         | 48  |
| 5.1 Overview .....                               | 48  |
| 5.2 Block Diagram .....                          | 48  |
| 5.3 Function Description.....                    | 48  |
| 5.4 CRU_PMU Register Description.....            | 51  |
| 5.5 CRU Register Description .....               | 63  |
| 5.6 Application Notes .....                      | 154 |
| Chapter 6 General Register Files (GRF).....      | 159 |
| 6.1 Overview .....                               | 159 |
| 6.2 Function Description.....                    | 159 |
| 6.3 GRF Register Description.....                | 159 |
| 6.4 DDRGRF Register Description .....            | 269 |
| 6.5 PMUGRF Register Description.....             | 288 |
| Chapter 7 Timer .....                            | 314 |
| 7.1 Overview .....                               | 314 |
| 7.2 Block Diagram .....                          | 314 |
| 7.3 Function Description.....                    | 314 |
| 7.4 Register Description .....                   | 315 |
| 7.5 Application Notes .....                      | 317 |
| Chapter 8 Watchdog Timer(WDT) .....              | 318 |
| 8.1 Overview .....                               | 318 |

|                                                  |     |
|--------------------------------------------------|-----|
| 8.2 Block Diagram .....                          | 318 |
| 8.3 Function Description.....                    | 318 |
| 8.4 Register Description .....                   | 319 |
| 8.5 Application Notes .....                      | 322 |
| Chapter 9 Power Management Unit (PMU).....       | 323 |
| 9.1 Overview .....                               | 323 |
| 9.2 Block Diagram .....                          | 323 |
| 9.3 Function Description.....                    | 324 |
| 9.4 Register Description .....                   | 326 |
| 9.5 Timing Diagram .....                         | 356 |
| 9.6 Application Notes .....                      | 356 |
| Chapter 10 System Debug .....                    | 358 |
| 10.1 Overview.....                               | 358 |
| 10.2 Block Diagram .....                         | 358 |
| 10.3 Function Description .....                  | 358 |
| 10.4 Register Description.....                   | 358 |
| 10.5 Interface Description .....                 | 358 |
| Chapter 11 SPINLOCK.....                         | 360 |
| 11.1 Overview.....                               | 360 |
| 11.2 Block Diagram .....                         | 360 |
| 11.3 Function Description .....                  | 360 |
| 11.4 Register Description.....                   | 360 |
| 11.5 Application Notes .....                     | 361 |
| Chapter 12 Mailbox.....                          | 362 |
| 12.1 Overview.....                               | 362 |
| 12.2 Block Diagram .....                         | 362 |
| 12.3 Function Description .....                  | 362 |
| 12.4 Register Description.....                   | 362 |
| 12.5 Application Notes .....                     | 372 |
| Chapter 13 DECOM.....                            | 373 |
| 13.1 Overview.....                               | 373 |
| 13.2 Block Diagram .....                         | 373 |
| 13.3 Function Description .....                  | 373 |
| 13.4 Register Description.....                   | 375 |
| 13.5 Application Notes .....                     | 387 |
| Chapter 14 Temperature-Sensor ADC (TS-ADC) ..... | 388 |
| 14.1 Overview.....                               | 388 |
| 14.2 Block Diagram .....                         | 388 |
| 14.3 Function Description .....                  | 388 |
| 14.4 Register Description.....                   | 389 |
| 14.5 Application Notes .....                     | 394 |
| Chapter 15 SAR-ADC .....                         | 397 |
| 15.1 Overview.....                               | 397 |
| 15.2 Block Diagram .....                         | 397 |
| 15.3 Function Description .....                  | 397 |
| 15.4 Register Description.....                   | 397 |
| 15.5 Timing Diagram .....                        | 399 |
| 15.6 Application Notes .....                     | 399 |

|                                                               |     |
|---------------------------------------------------------------|-----|
| Chapter 16 DMA Controller (DMAC).....                         | 401 |
| 16.1 Overview.....                                            | 401 |
| 16.2 Block Diagram .....                                      | 401 |
| 16.3 Function Description .....                               | 402 |
| 16.4 Register Description.....                                | 403 |
| 16.5 Timing Diagram .....                                     | 458 |
| 16.6 Interface Description .....                              | 458 |
| 16.7 Application Notes .....                                  | 460 |
| Chapter 17 I2S_TDM .....                                      | 466 |
| 17.1 Overview.....                                            | 466 |
| 17.2 Controller Block Diagram.....                            | 467 |
| 17.3 Function description .....                               | 468 |
| 17.4 Register description .....                               | 473 |
| 17.5 Interface Description .....                              | 496 |
| 17.6 Application Notes .....                                  | 499 |
| Chapter 18 Digital Audio Codec .....                          | 500 |
| 18.1 Overview.....                                            | 500 |
| 18.2 Block Diagram .....                                      | 501 |
| 18.3 Function description .....                               | 501 |
| 18.4 Register Description.....                                | 503 |
| 18.5 Interface Description .....                              | 527 |
| 18.6 Application Notes .....                                  | 527 |
| Chapter 19 Audio PWM.....                                     | 530 |
| 19.1 Overview.....                                            | 530 |
| 19.2 Block Diagram .....                                      | 530 |
| 19.3 Function Description .....                               | 530 |
| 19.4 Register Description.....                                | 531 |
| 19.5 Interface Description .....                              | 535 |
| 19.6 Application Notes .....                                  | 536 |
| Chapter 20 Pulse Density Modulation Interface Controller..... | 537 |
| 20.1 Overview.....                                            | 537 |
| 20.2 Block Diagram .....                                      | 537 |
| 20.3 Function Description .....                               | 538 |
| 20.4 Register Description.....                                | 540 |
| 20.5 Interface Description .....                              | 547 |
| 20.6 Application Notes .....                                  | 547 |
| Chapter 21 CAN .....                                          | 549 |
| 21.1 Overview.....                                            | 549 |
| 21.2 Block Diagram .....                                      | 549 |
| 21.3 Function Description .....                               | 550 |
| 21.4 Register Description.....                                | 554 |
| 21.5 Application Notes .....                                  | 562 |
| Chapter 22 Pulse Width Modulation (PWM).....                  | 565 |
| 22.1 Overview.....                                            | 565 |
| 22.2 Block Diagram .....                                      | 566 |
| 22.3 Function Description .....                               | 566 |
| 22.4 Register Description.....                                | 567 |
| 22.5 Interface Description .....                              | 586 |

|                                                              |     |
|--------------------------------------------------------------|-----|
| 22.6 Application Notes .....                                 | 587 |
| Chapter 23 I2C Interface.....                                | 589 |
| 23.1 Overview.....                                           | 589 |
| 23.2 Block Diagram .....                                     | 589 |
| 23.3 Function Description .....                              | 589 |
| 23.4 Register Description.....                               | 592 |
| 23.5 Interface Description .....                             | 599 |
| 23.6 Application Notes .....                                 | 600 |
| 24.1 Overview.....                                           | 604 |
| 24.2 Block Diagram .....                                     | 604 |
| 24.3 Function Description .....                              | 605 |
| 24.4 Register Description.....                               | 607 |
| 24.5 Interface Description .....                             | 630 |
| 24.6 Application Notes .....                                 | 633 |
| Chapter 25 Serial Peripheral Interface (SPI) .....           | 636 |
| 25.1 Overview.....                                           | 636 |
| 25.2 Block Diagram .....                                     | 636 |
| 25.3 Function Description .....                              | 637 |
| 25.4 Register Description.....                               | 639 |
| 25.5 Interface Description .....                             | 649 |
| 25.6 Application Notes .....                                 | 650 |
| Chapter 26 Flexible Serial Peripheral Interface (FSPI) ..... | 653 |
| 26.1 Overview.....                                           | 653 |
| 26.2 Block Diagram .....                                     | 653 |
| 26.3 Function Description .....                              | 654 |
| 26.4 Register Description.....                               | 654 |
| 26.5 Interface Description .....                             | 673 |
| 26.6 Application Notes .....                                 | 674 |
| Chapter 27 Mobile Storage Host Controller.....               | 678 |
| 27.1 Overview.....                                           | 678 |
| 27.2 Block Diagram .....                                     | 678 |
| 27.3 Function Description .....                              | 679 |
| 27.4 Register Description.....                               | 699 |
| 27.5 Interface Description .....                             | 720 |
| 27.6 Application Notes .....                                 | 721 |
| Chapter 28 USB2.0 OTG Controller .....                       | 742 |
| 28.1 Overview.....                                           | 742 |
| 28.2 Block Diagram .....                                     | 743 |
| 28.3 Function Description .....                              | 743 |
| 28.4 Register Description.....                               | 743 |
| 28.5 Interface Description .....                             | 781 |
| 28.6 Application Notes .....                                 | 781 |
| Chapter 29 USB2.0 Host.....                                  | 788 |
| 29.1 Overview.....                                           | 788 |
| 29.2 Block Diagram .....                                     | 788 |
| 29.3 Function Description .....                              | 788 |
| 29.4 Register Description.....                               | 789 |
| 29.5 Interface Description .....                             | 789 |

|                                                         |     |
|---------------------------------------------------------|-----|
| 29.6 Application Notes .....                            | 789 |
| Chapter 30 Gigabit Media Access Controller (GMAC) ..... | 794 |
| 30.1 Overview.....                                      | 794 |
| 30.2 Block Diagram .....                                | 796 |
| 30.3 Function Description .....                         | 797 |
| 30.4 Register Description.....                          | 802 |
| 30.5 Interface Description .....                        | 907 |
| 30.6 Application Note .....                             | 909 |
| Chapter 31 GPIO .....                                   | 934 |
| 31.1 Overview.....                                      | 934 |
| 31.2 Block Diagram .....                                | 934 |
| 31.3 Function Description .....                         | 934 |
| 31.4 Register Description.....                          | 935 |
| 31.5 Interface Description .....                        | 943 |
| 31.6 Application Notes .....                            | 944 |

## Figure Index

|                                                                                |     |
|--------------------------------------------------------------------------------|-----|
| Fig. 1-1 RV1109/RV1126 Boot Procedure Flow .....                               | 22  |
| Fig. 2-1 Core Subsystem Architecture .....                                     | 27  |
| Fig. 3-1 Block Diagram of RISC-V Core .....                                    | 28  |
| Fig. 3-2 Block Diagram of IPIC .....                                           | 29  |
| Fig. 3-3 Block Diagram of Debug Sub-system .....                               | 30  |
| Fig. 4-1 Embedded SRAM block diagram .....                                     | 46  |
| Fig. 4-2 SYSTEM_SRAM Security Configuration .....                              | 46  |
| Fig. 5-1 CRU Block Diagram .....                                               | 48  |
| Fig. 5-2 Reset Architecture Diagram .....                                      | 49  |
| Fig. 5-3 PLL Block Diagram .....                                               | 50  |
| Fig. 5-4 PLL Offset Calibration .....                                          | 50  |
| Fig. 7-1 Timer Block Diagram .....                                             | 314 |
| Fig. 7-2 Timer Usage Flow .....                                                | 315 |
| Fig. 7-3 Timing between timer_en and timer_clk .....                           | 317 |
| Fig. 8-1 WDT Block Diagram .....                                               | 318 |
| Fig. 8-2 WDTOperation Flow (RMOD=1) .....                                      | 319 |
| Fig. 9-1 PMU Bock Diagram .....                                                | 323 |
| Fig. 9-2 RV1109/RV1126 Voltage Domain and Power Domain Partition .....         | 324 |
| Fig. 9-3 Each Domain Power Switch Timing .....                                 | 356 |
| Fig. 9-4 External Wakeup Source PAD Timing .....                               | 356 |
| Fig. 10-1Debug system structure .....                                          | 358 |
| Fig. 10-2 DAP SWJ interface .....                                              | 359 |
| Fig. 10-3 SW-DP acknowledgement timing .....                                   | 359 |
| Fig. 11-1 Spinlock Block Diagram .....                                         | 360 |
| Fig. 12-1 Mailbox Block Diagram .....                                          | 362 |
| Fig. 13-1 DECOM Block Diagram .....                                            | 373 |
| Fig. 13-2 DECOM Data Flow .....                                                | 375 |
| Fig. 14-1 TS-ADC Controller Block Diagram .....                                | 388 |
| Fig. 14-2 Start Flow to Enable the Sensor and ADC .....                        | 395 |
| Fig. 14-3 TS-ADC Timing Diagram in Bypass Mode .....                           | 395 |
| Fig. 14-4 TS-ADC Timing Diagram in Normal Mode with tsadc_clk_sel = 1'b0 ..... | 395 |
| Fig. 14-5 TS-ADC Timing Diagram in Normal Mode with tsadc_clk_sel = 1'b1 ..... | 395 |
| Fig. 15-1 SAR-ADC Block Diagram .....                                          | 397 |
| Fig. 15-2 SAR-ADC Timing Diagram in Single-sample Conversion Mode .....        | 399 |
| Fig. 16-1 Block Diagram of DMAC .....                                          | 402 |
| Fig. 16-2 DMAC Operation State .....                                           | 403 |
| Fig. 16-3 DMAC Request and Acknowledge Timing .....                            | 458 |
| Fig. 17-1 I2S/PCM/TDM Controller (8-channel) Block Diagram .....               | 467 |
| Fig. 17-2 I2S/PCM Controller (2-channel) Block Diagram .....                   | 467 |
| Fig. 17-3 I2S Transmitter-Master & Receiver-Slave Condition .....              | 468 |
| Fig. 17-4 I2S Transmitter-Slave & Receiver-Master Condition .....              | 468 |
| Fig. 17-5 I2S Normal Mode Timing Format .....                                  | 468 |
| Fig. 17-6 I2S Left Justified Mode Timing Format .....                          | 469 |
| Fig. 17-7 I2S Right Justified Mode Timing Format .....                         | 469 |
| Fig. 17-8 PCM Early Mode Timing Format .....                                   | 469 |
| Fig. 17-9 PCM Late1 Mode Timing Format .....                                   | 469 |
| Fig. 17-10 PCM Late2 Mode Timing Format .....                                  | 470 |
| Fig. 17-11 PCM Late3 Mode Timing Format .....                                  | 470 |
| Fig. 17-12 TDM Normal Mode Timing Format (PCM Format) .....                    | 470 |
| Fig. 17-13 TDM Left Shift Mode 0 Timing Format (PCM Format) .....              | 471 |
| Fig. 17-14 TDM Left Shift Mode 1 Timing Format (PCM Format) .....              | 471 |
| Fig. 17-15 TDM Left Shift Mode 2 Timing Format (PCM Format) .....              | 471 |
| Fig. 17-16 TDM Left Shift Mode 3 Timing Format (PCM Format) .....              | 472 |
| Fig. 17-17 TDM Normal Mode Timing Format (I2S Format) .....                    | 472 |
| Fig. 17-18 TDM Left Justified Mode Timing Format (I2S Format) .....            | 472 |
| Fig. 17-19 TDM Right Justified Mode Timing Format (I2S Format) .....           | 473 |

|                                                                     |     |
|---------------------------------------------------------------------|-----|
| Fig.17-20 I2S/PCM/TDM Controller Transmit Operation Flow Chart..... | 499 |
| Fig.18-1 Digital Audio Codec Block Diagram .....                    | 501 |
| Fig. 19-1 Block Diagram of Audio PWM .....                          | 530 |
| Fig.20-1 PDM Block Diagram.....                                     | 537 |
| Fig.20-2 PDM with Eight Mono MIC .....                              | 538 |
| Fig.20-3 PDM with Four Stereo MIC.....                              | 539 |
| Fig.20-4 PDM interface diagram with external MIC .....              | 539 |
| Fig.20-5 PDM Clock Structure.....                                   | 540 |
| Fig.20-6 PDM Operation Flow .....                                   | 548 |
| Fig. 21-1 CAN Controller Block Diagram.....                         | 549 |
| Fig. 21-2 Bit timing FSM.....                                       | 551 |
| Fig. 21-3 Bit timing waveform diagram.....                          | 551 |
| Fig. 21-4 Three sampling diagram .....                              | 551 |
| Fig. 21-5 Hard_sync waveform diagram.....                           | 552 |
| Fig. 21-6 Resynchronization.....                                    | 552 |
| Fig. 21-7 Receive data state diagram .....                          | 553 |
| Fig. 21-8 Bit Stuffing .....                                        | 554 |
| Fig. 21-9 Initialization Flow.....                                  | 563 |
| Fig. 21-10 Loop-back Mode.....                                      | 563 |
| Fig. 21-11 Silent Mode .....                                        | 564 |
| Fig. 30-1 PWM Block Diagram .....                                   | 566 |
| Fig. 30-2 PWM Capture Mode .....                                    | 566 |
| Fig. 30-3 PWM Continuous Left-aligned Output Mode .....             | 567 |
| Fig. 30-4 PWM Continuous Center-aligned Output Mode .....           | 567 |
| Fig. 30-5 PWM One-shot Center-aligned Output Mode.....              | 567 |
| Fig. 22-1 I2C Architecture .....                                    | 589 |
| Fig. 22-2 I2C DATA Validity .....                                   | 591 |
| Fig. 22-3 I2C Start and Stop Conditions.....                        | 591 |
| Fig. 22-4 I2C Acknowledge .....                                     | 592 |
| Fig. 22-5 I2C Byte Transfer.....                                    | 592 |
| Fig. 22-6 I2C Flow Chat for Transmit Only Mode.....                 | 601 |
| Fig. 22-7 I2C Flow Chat for Receive Only Mode .....                 | 602 |
| Fig. 22-8 I2C Flow Chat for Mix Mode .....                          | 603 |
| Fig. 22-9 UART Architecture.....                                    | 604 |
| Fig. 22-10 UART Serial protocol .....                               | 605 |
| Fig. 22-11 IrDA 1.0 .....                                           | 605 |
| Fig. 22-12 UART baud rate.....                                      | 605 |
| Fig. 22-13 UART Auto flow control block diagram .....               | 606 |
| Fig. 22-14 UART AUTO RTS TIMING .....                               | 607 |
| Fig. 22-15 UART AUTO CTS TIMING .....                               | 607 |
| Fig. 22-16 UART none fifo mode .....                                | 633 |
| Fig. 22-17 UART fifo mode .....                                     | 634 |
| Fig. 22-18 UART clock generation .....                              | 635 |
| Fig. 24-1 SPI Controller Block Diagram.....                         | 637 |
| Fig. 24-2 SPI Master and Slave Interconnection .....                | 637 |
| Fig. 24-3 SPI Format (SCPH=0 SCPOL=0).....                          | 638 |
| Fig. 24-4 SPI Format (SCPH=0 SCPOL=1).....                          | 638 |
| Fig. 24-5 SPI Format (SCPH=1 SCPOL=0).....                          | 639 |
| Fig. 24-6 SPI Format (SCPH=1 SCPOL=1).....                          | 639 |
| Fig. 24-7 SPI Master transfer flow diagram .....                    | 651 |
| Fig. 24-8 SPI Slave transfer flow diagram .....                     | 652 |
| Fig. 25-1 FSPI Architecture .....                                   | 653 |
| Fig. 25-2 Program Flow .....                                        | 674 |
| Fig. 25-3 Read Flow .....                                           | 675 |
| Fig. 25-4 Command with DMA Flow .....                               | 676 |
| Fig. 25-5 SPI mode.....                                             | 677 |
| Fig. 25-6 Idle cycles .....                                         | 677 |

|                                                                              |     |
|------------------------------------------------------------------------------|-----|
| Fig. 26-1 Mobile Storage Host Control Block Diagram .....                    | 679 |
| Fig. 26-2 SD/MMC Card-Detect Signal .....                                    | 683 |
| Fig. 26-3 Host Controller Command Path State Machine.....                    | 685 |
| Fig. 26-4 Host Controller Data Transmit State Machine .....                  | 687 |
| Fig. 26-5 Host Controller Data Receive State Machine.....                    | 689 |
| Fig. 26-6 Dual-Buffer Descriptor Structure .....                             | 695 |
| Fig. 26-7 Chain Descriptor Structure .....                                   | 695 |
| Fig. 26-8 Descriptor Formats for 32-bit AHB Address Bus Width .....          | 695 |
| Fig. 26-9 Clock Generation Unit.....                                         | 699 |
| Fig. 26-10 SD/MMC Card-Detect and Write-Protect.....                         | 722 |
| Fig. 26-11 SD/MMC Card Termination .....                                     | 722 |
| Fig. 26-12 Host Controller Initialization Sequence .....                     | 724 |
| Fig. 26-13 Voltage Switching Command Flow Diagram .....                      | 733 |
| Fig. 26-14 ACMD41 Argument .....                                             | 733 |
| Fig. 26-15 ACMD41 Response(R3) .....                                         | 734 |
| Fig. 26-16 Voltage Switch Normal Scenario .....                              | 734 |
| Fig. 26-17 Voltage Switch Error Scenario .....                               | 735 |
| Fig. 26-18 Card Detection Method 2 .....                                     | 740 |
| Fig. 26-19 Card Detection Method 4 .....                                     | 741 |
| Fig. 27-1 USB2.0 OTG Block Diagram .....                                     | 743 |
| Fig. 27-2 USB2.0 OTG reset sequence .....                                    | 786 |
| Fig. 27-3 USB2.0 OTG charge sequence.....                                    | 787 |
| Fig. 28-1 USB2.0 Host Controller Block Diagram .....                         | 788 |
| Fig. 28-2 USB2.0 Host reset sequence.....                                    | 792 |
| Fig. 28-3 USB2.0 Host charge sequence .....                                  | 793 |
| Fig. 31-1 GMAC Block Diagram.....                                            | 796 |
| Fig. 31-2 GMAC in SOC .....                                                  | 797 |
| Fig. 31-3 Frame Format.....                                                  | 797 |
| Fig. 31-4 RMII Transmission Bit Ordering .....                               | 798 |
| Fig. 31-5 Start of MII and RMII Transmission in 100-Mbps Mode .....          | 798 |
| Fig. 31-6 End of MII and RMII Transmission in 100-Mbps Mode .....            | 798 |
| Fig. 31-7 Start of MII and RMII Transmission in 10-Mbps Mode .....           | 798 |
| Fig. 31-8 End of MII and RMII Transmission in 10-Mbps Mode.....              | 799 |
| Fig. 31-9 RMII Receive Bit Ordering .....                                    | 799 |
| Fig. 31-10 Descriptor Ring Structure .....                                   | 909 |
| Fig. 31-11 RMII Clock Architecture When Clock Source From CRU .....          | 932 |
| Fig. 31-12 RMII Clock Architecture When Clock Source From External OSC ..... | 932 |
| Fig. 31-13 RGMII Clock Architecture When Clock Source From CRU .....         | 932 |
| Fig. 31-14 RGMII Clock Architecture When Clock Source From External OSC..... | 933 |
| Fig. 32-1 GPIO Block Diagram .....                                           | 934 |

## Table Index

|                                                                                                         |     |
|---------------------------------------------------------------------------------------------------------|-----|
| Table 1-1 Address Mapping .....                                                                         | 20  |
| Table 1-2 Address Remapping .....                                                                       | 21  |
| Table 1-3 RV1109/RV1126 Interrupt Connection List .....                                                 | 23  |
| Table 1-4 RV1109/RV1126 DMAC Hardware Request Connection List .....                                     | 26  |
| Table 3-1 Serial Wire Debug Interface Description .....                                                 | 44  |
| Table 7-1 Register Base Address .....                                                                   | 317 |
| Table 9-1 RV1109/RV1126 Voltage Domain and Power Domain Summary .....                                   | 324 |
| Table 9-2 Debug IO for PMU FSM state .....                                                              | 356 |
| Table 10-1 DAP-Lite Interface Description .....                                                         | 359 |
| Table 14-1 Temperature Code Mapping .....                                                               | 396 |
| Table 15-1 SAR-ADC Timing Parameters List.....                                                          | 399 |
| Table 16-1 DMAC Request Mapping Table .....                                                             | 401 |
| Table 17-1 I2S0 Group 0 Interface Description .....                                                     | 496 |
| Table 17-2 I2S0 Group 1 Interface Description .....                                                     | 496 |
| Table 17-3 I2S1 Group 0 Interface Description .....                                                     | 497 |
| Table 17-4 I2S1 Group 1 Interface Description .....                                                     | 497 |
| Table 17-5 I2S1 Group 2 Interface Description .....                                                     | 498 |
| Table 17-6 I2S2 Group 0Interface Description .....                                                      | 498 |
| Table 17-7 I2S2 Group 1Interface Description .....                                                      | 498 |
| Table 18-1 Equivalent Parameters of Digital ADC Filters .....                                           | 502 |
| Table 18-2 Digital Audio Codec Interface Description for Audio DAC Mode.....                            | 527 |
| Table 18-3 Digital Audio Codec Interface Description for Audio PWM Mode .....                           | 527 |
| Table 18-4 Relationship of ACDC_ADC_CLK, D2A_ADC_CLK, D2A_ADC_SYNC and Sample Rates in Normal Mode..... | 528 |
| Table 18-5 Relationship of ACDC_ADC_CLK, D2A_ADC_CLK, D2A_ADC_SYNC .....                                | 528 |
| Table 18-6 Relationship of ACDC_ADC_CLK, D2A_ADC_CLK, D2A_ADC_SYNC .....                                | 528 |
| Table 18-7 Relationship of ACDC_DAC_CLK, D2A_DAC_CLK, D2A_DAC_SYNC and Sample Rates .....               | 528 |
| Table 19-1 Duty Cycle Resolution of the Audio PWM.....                                                  | 530 |
| Table 19-2 Audio PWM Interface Description.....                                                         | 535 |
| Table 20-1 Relation between PDM_CLK and Sample Rate.....                                                | 540 |
| Table 20-2 Group 0 PDM IO Interface Description.....                                                    | 547 |
| Table 20-3 Group 1 PDM IO Interface Description.....                                                    | 547 |
| Table 30-1 PWM Interface Description .....                                                              | 586 |
| Table 22-1 I2C Interface Description .....                                                              | 599 |
| Table 22-2UART Interface Description.....                                                               | 630 |
| Table 22-3 UART baud rate configuration .....                                                           | 635 |
| Table 24-1 SPI interface description .....                                                              | 649 |
| Table 25-1 FSPI Address Mapping Table .....                                                             | 654 |
| Table 25-2 FSPI(SFC) interface description.....                                                         | 673 |
| Table 26-1 Bits in Interrupt Status Register .....                                                      | 681 |
| Table 26-2 Auto-Stop Generation .....                                                                   | 690 |
| Table 26-3 Non-data Transfer Commands and Requirements.....                                             | 691 |
| Table 26-4 Bits in IDMAC DES0 Element .....                                                             | 695 |
| Table 26-5 Bits in IDMAC DES1 Element .....                                                             | 696 |
| Table 26-6 Bits in IDMAC DES2 Element .....                                                             | 696 |
| Table 26-7 Bits in IDMAC DES3 Element .....                                                             | 697 |
| Table 26-8 SDMMC Interface Description.....                                                             | 720 |
| Table 26-9 SDIO Interface Description.....                                                              | 720 |
| Table 26-10 EMMC Interface Description .....                                                            | 721 |
| Table 26-11 Recommended Usage of use_hold_reg .....                                                     | 723 |
| Table 26-12 Command Settings for No-Data Command .....                                                  | 726 |
| Table 26-13 Command Setting for Single or Multiple-Block Read .....                                     | 728 |
| Table 26-14 Command Settings for Single or Multiple-Block Write .....                                   | 729 |
| Table 26-15 PBL and Watermark Levels .....                                                              | 737 |
| Table 26-16 Configuration for SDMMC Variable Delay Usage .....                                          | 737 |

|                                                              |     |
|--------------------------------------------------------------|-----|
| Table 26-17 Configuration for SDIO Variable Delay Usage..... | 738 |
| Table 26-18 Configuration for EMMC Variable Delay Usage..... | 738 |
| Table 26-19 Register for SDMMC Card Detection Method 3 ..... | 740 |
| Table 27-1 USB2 Address Mapping .....                        | 743 |
| Table 27-2 USB2.0 PHY Interface Description .....            | 781 |
| Table 27-3 GRF_USBPHY_CON0 Description .....                 | 781 |
| Table 27-4 GRF_USBPHY_CON1 Description .....                 | 784 |
| Table 27-5 Charge Description in device model .....          | 787 |
| Table 28-1 USB2.0 Host Controller Address Mapping.....       | 789 |
| Table 28-2 USB2.0 PHY Interface Description .....            | 789 |
| Table 28-3 GRF_USBPHY_CON2 Description .....                 | 789 |
| Table 28-4 Charge Description in host model .....            | 793 |
| Table 31-1 MDIO Clause 45 Frame Structure .....              | 800 |
| Table 31-2 MDIO Clause 22 Frame Structure .....              | 800 |
| Table 31-3 EQOS Interface M0 .....                           | 907 |
| Table 31-4 EQOS Interface M1 .....                           | 908 |
| Table 31-5 TDES0 Normal Descriptor (Read Format).....        | 910 |
| Table 31-6 TDES1 Normal Descriptor (Read Format).....        | 910 |
| Table 31-7 TDES2 Normal Descriptor (Read Format).....        | 910 |
| Table 31-8 TDES3 Normal Descriptor (Read Format).....        | 911 |
| Table 31-9 TDES0 Normal Descriptor (Write-Back Format).....  | 914 |
| Table 31-10 TDES1 Normal Descriptor (Write-Back Format)..... | 914 |
| Table 31-11 TDES2 Normal Descriptor (Write-Back Format)..... | 914 |
| Table 31-12 TDES2 Normal Descriptor (Write-Back Format)..... | 914 |
| Table 31-13 TDES0 Context Descriptor .....                   | 917 |
| Table 31-14 TDES1 Context Descriptor .....                   | 917 |
| Table 31-15 TDES2 Context Descriptor .....                   | 917 |
| Table 31-16 TDES3 Context Descriptor .....                   | 918 |
| Table 31-17 TDES0 Normal Descriptor(Read Format) .....       | 919 |
| Table 31-18 TDES1 Normal Descriptor(Read Format) .....       | 920 |
| Table 31-19 TDES2 Normal Descriptor(Read Format) .....       | 920 |
| Table 31-20 TDES3 Normal Descriptor(Read Format) .....       | 920 |
| Table 31-21 TDES0 Normal Descriptor(Write-Back Format) ..... | 920 |
| Table 31-22 TDES1 Normal Descriptor(Write-Back Format) ..... | 921 |
| Table 31-23 TDES2 Normal Descriptor(Write-Back Format) ..... | 923 |
| Table 31-24 TDES3 Normal Descriptor(Write-Back Format) ..... | 925 |
| Table 31-25 TDES0 Context Descriptor .....                   | 927 |
| Table 31-26 TDES1 Context Descriptor .....                   | 927 |
| Table 31-27 TDES2 Context Descriptor .....                   | 928 |
| Table 31-28 TDES3 Context Descriptor .....                   | 928 |
| Table 32-1 GPIO Interface Description .....                  | 943 |

## **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 © 2020 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.

## Appendix

| <b>Abbreviation</b> | <b>Full Name</b>                         | <b>Instruction</b>                                                                                                                                                                                                                                                                   |
|---------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACA                 | Accessory Charger Adapter                | An adaptor which allows a single USB port to be attached to both a charger and another device at the same time.                                                                                                                                                                      |
| ADC                 | Analog-to-Digital Converter              | Used to convert analog signal to digital signal.                                                                                                                                                                                                                                     |
| AE                  | Automatic Exposure                       | Realizes the function of automatic exposure processing.                                                                                                                                                                                                                              |
| AF                  | Auto Focus                               | Realizes the measurement of image definition.                                                                                                                                                                                                                                        |
| AGC                 | Automatic Gain Control                   | An adaptive system found in electronic devices that automatically controls the gain of a signal: the average output signal level is fed back to adjust the gain to an appropriate level for a range of input signal levels.                                                          |
| AI                  | Artificial Intelligence                  | A new technical science to study and develop theories, methods, techniques and application systems for simulating, extending and extending human intelligence.                                                                                                                       |
| AVC                 | Advanced Video Coding                    | One video agreement, also can be called H.264                                                                                                                                                                                                                                        |
| AVS                 | Audio Video coding Standard              | One video agreement                                                                                                                                                                                                                                                                  |
| AWB                 | Automatic White Balance                  | Provides the white balance function, and configures the gains of the R, Gr, Gb, and B components.                                                                                                                                                                                    |
| BCSH                | Brightness, Contrast, Saturation and Hue | BCSH is used for brightness, contrast, saturation and hue adjustment.                                                                                                                                                                                                                |
| BLC                 | Black Level Correction                   | A function to subtract a DC offset from picture data.                                                                                                                                                                                                                                |
| BLE                 | Blending                                 | Gather many source data to final output data                                                                                                                                                                                                                                         |
| CC                  | Combining Check                          | Can correction wrong ME and MC.                                                                                                                                                                                                                                                      |
| CCM                 | Color Correction Matrix                  | Used to correct the color crosstalk because of three channel response of sensor when only one channel color input.                                                                                                                                                                   |
| CDP                 | Charging Downstream Port                 | A Charging Downstream Port (CDP) is a downstream port on a device that complies with the USB 2.0 definition of a host or a hub, except that it shall support the Charging Downstream Port features specified herein.                                                                 |
| CMD                 | Command                                  | Command                                                                                                                                                                                                                                                                              |
| CMOS                | Complementary Metal Oxide Semiconductor  | Use for CMOS sensor                                                                                                                                                                                                                                                                  |
| CSC                 | Color Space Convert                      | RGB2YUV, YUV2RGB                                                                                                                                                                                                                                                                     |
| CSI                 | Camera Serial Interface                  | A standard interface between a camera and a host processor for mobile applications.                                                                                                                                                                                                  |
| DAC                 | Digital-to-Analog Converter              | A system that converts a digital signal into an analog signal.                                                                                                                                                                                                                       |
| DAP                 | Debug Access Port                        | A TAP block that acts as an AMBA (AHB or AHB-Lite) master for access to a system bus. The DAP is the term used to encompass a set of modular blocks that support system wide debug. The DAP is a modular component, intended to be extendable to support optional access to multiple |

| <b>Abbreviation</b> | <b>Full Name</b>                   | <b>Instruction</b>                                                                                                                                                                                                           |
|---------------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |                                    | systems such as memory mapped AHB and CoreSight APB through a single debug interface.                                                                                                                                        |
| DCP                 | Dedicated Charging Port            | A downstream port on a device that outputs power through a USB connector, but is not capable of enumerating a downstream device                                                                                              |
| DCT                 | Discrete Cosine Transform          | One video encoder tool.                                                                                                                                                                                                      |
| DDR                 | Double Data Rate                   | A kind of dynamic memory.                                                                                                                                                                                                    |
| DDR3                | Double Data Rate 3                 | A kind of dynamic memory.                                                                                                                                                                                                    |
| DDR3L               | Double Data Rate 3 Low Voltage     | A kind of dynamic memory.                                                                                                                                                                                                    |
| DDR4                | Double Data Rate 4                 | A kind of dynamic memory.                                                                                                                                                                                                    |
| DFI                 | DDR PHY Interface                  | An interface protocol that defines the signals, timing parameters, and programmable parameters required to transfer control information and data over the DFI, to and from the DRAM devices, and between the MC and the PHY. |
| DMA                 | Direct Memory Access               | A feature of computer systems that allows certain hardware subsystems to access main system memory, independent of the central processing unit (CPU).                                                                        |
| DMAC                | Direct Memory Access Controller    | A programmable controller that manages DMA transfers.                                                                                                                                                                        |
| DPCC                | Defect Pixel Cluster Correction    | Used to correct the defect pixels of the sensor, and supports both static and dynamic mode.                                                                                                                                  |
| DST                 | Destination                        | Destination Image                                                                                                                                                                                                            |
| DVP                 | Digital Video Port                 | A traditional sensor output interface. The video data are output in parallel.                                                                                                                                                |
| EEDI                | Enhanced Edge based Interpolation  | Could interpolation smaller than 10 degree.                                                                                                                                                                                  |
| EHCI                | Enhanced Host Controller Interface | The Enhanced Host Controller Interface (EHCI) for a Host Controller for the USB2.0                                                                                                                                           |
| EOI                 | End Of Interrupt                   | Indicate the completion of interrupt processing for a given interrupt.                                                                                                                                                       |
| FBC                 | Frame Buffer Compression           | A kind of method to reduce DDR bandwidth                                                                                                                                                                                     |
| FBCD                | Frame Buffer Compression Decoder   | Decode TNR and NR compression data from ddr under their respective fbcd mode.                                                                                                                                                |
| FBCE                | Frame Buffer Compression Encoder   | Encode TNR, Sharp and FEC data to ddr under their respective fbce mode.                                                                                                                                                      |
| FEC                 | Fisheye Correction                 | Implemented by backward mapping.                                                                                                                                                                                             |
| FIFO                | First In First Out                 | A method for organizing and manipulating a data buffer, where the oldest (first) entry, or head of the queue, is processed first.                                                                                            |
| FPN                 | Fixed Pattern Noise                | A function for fixed pattern noise                                                                                                                                                                                           |
| FPS                 | Frame per Second                   | It is express that how many frames can be decoded by VDPU at one second.                                                                                                                                                     |
| FRC                 | Frame Rate Control                 | An algorithm of dither                                                                                                                                                                                                       |
| FS                  | Full Speed                         | Full Speed model in USB2.0                                                                                                                                                                                                   |
| GIC                 | Green Imbalance Correction         | A method to correct the color imbalance in captured images                                                                                                                                                                   |
| GPIO                | General Purpose Input/Output       | An uncommitted digital signal pin on an integrated circuit whose behavior (including                                                                                                                                         |

| <b>Abbreviation</b> | <b>Full Name</b>                           | <b>Instruction</b>                                                                                                |
|---------------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
|                     |                                            | whether it acts as input or output) is controllable by the user at run time.                                      |
| HDR                 | High-Dynamic Range                         | Realize the function of three/two frames synthesizing one frame.                                                  |
| HEVC                | High Efficiency Video Coding               | One video agreement, also can be called H.265                                                                     |
| HNP                 | Host Negotiation Protocol                  | Host Negotiation Protocol in USB OTG Specification.                                                               |
| HS                  | High Speed                                 | High Speed model in USB2.0                                                                                        |
| I2C                 | Inter-Integrated Circuit                   | Two wired (SCL and SDA), bi-directional serial bus                                                                |
| I2S                 | Inter-IC Sound, Integrated Interchip Sound | It is one of digital audio transmission standard.                                                                 |
| IEP                 | Image Enhancement Processor                | The main function is deinterlace.                                                                                 |
| Int8                | Integer 8                                  | 8 bit integer including 1 bit sign bit                                                                            |
| ISP                 | Image Signal Processor                     | contains standard sensor picture data processing functions                                                        |
| ISPP                | Image Signal Post-Processing               | Contains image post-processing and scaling function.                                                              |
| IXOY                | Input X Fields Output Y frame              | A kind of deinterlace mode(X and Y mean a number ).                                                               |
| JFIF                | JPEG File Interchange Format               | One image file standard.                                                                                          |
| JPEG                | Joint Photographic Experts Group           | One video agreement, used for picture compress.                                                                   |
| LCD                 | Liquid Crystal Display                     | A type of display.                                                                                                |
| LDCH                | Lens-Distortion                            | Achieves distortion correction under fisheye lens.                                                                |
| LPDDR3              | Low Power Double Data Rate 3               | A kind of dynamic memory.                                                                                         |
| LPDDR4              | Low Power Double Data Rate 4               | A kind of dynamic memory.                                                                                         |
| LS                  | Low Speed                                  | Low Speed model in USB2.0                                                                                         |
| LSC                 | Lens Shading Correction                    | A function for lens shading problem                                                                               |
| LUT                 | Look Up Table                              | Look Up Table                                                                                                     |
| LVDS                | Low-Voltage Differential Signaling         | A differential signal technology with low power consumption, low bit error rate, low crosstalk and low radiation. |
| MAD                 | Multiply-add Unit                          | This is the unit designed to process multiply-add operation                                                       |
| MBAFF               | Macro-block Adaptive Field Frame           | One feature of h.264 stream.                                                                                      |
| MBPS                | Mega Bits Per Second                       | The express that how many bits can be decoded by VDPU at one second.                                              |
| MC                  | Motion Compensation                        | Filed based                                                                                                       |
| MD                  | Motion Detection                           | Frame based                                                                                                       |
| ME                  | Motion Estimate                            | Frame based                                                                                                       |
| MI                  | Memory Interface                           | Write or read back data interface                                                                                 |
| MIPI                | Mobile Industry Processor Interface        | An open standard and specification for mobile application processors initiated by the MIPI consortium             |
| MSPS                | Million sample per                         | Sample rate                                                                                                       |

| <b>Abbreviation</b> | <b>Full Name</b>                          | <b>Instruction</b>                                                                                                                                                                                                                                                                                                         |
|---------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | second                                    |                                                                                                                                                                                                                                                                                                                            |
| MTL                 | Media Access Controller Transaction Layer | The MAC Transaction Layer (MTL) provides the FIFO memory Interface to buffer and regulate the packets between the application system memory and the MAC. It also enables the data to be transferred between the application clock and MAC clock domains. The MTL layer has two data paths: Transmit path and Receive Path. |
| MV                  | Motion Vector                             | Frame based                                                                                                                                                                                                                                                                                                                |
| MVC                 | Multiview Video Coding                    | Also known as MVC 3D, it is a stereoscopic video coding standard for video compression.                                                                                                                                                                                                                                    |
| NG                  | Noise Gate                                | A module used to detect and gate the noise.                                                                                                                                                                                                                                                                                |
| BIU                 | Bus Interface Units                       | BIU convert the incoming transaction information into special internal packets.                                                                                                                                                                                                                                            |
| NN                  | Neural Network                            | Artificial Neural Network used in Deep Learning.                                                                                                                                                                                                                                                                           |
| NPU                 | Neural Process Unit                       | NPU is the process unit which is dedicated to neural network. It is designed to accelerate the neural network arithmetic in field of AI (artificial intelligence) such as machine vision and natural language processing.                                                                                                  |
| OHCI                | Open Host Controller Interface            | Open Host Controller Interface for USB.                                                                                                                                                                                                                                                                                    |
| OSD                 | On Screen Display                         | An on screen menu for making adjustments to the display                                                                                                                                                                                                                                                                    |
| OTG                 | On The Go                                 | This means USB can be host or device by configuration.                                                                                                                                                                                                                                                                     |
| OTP                 | One Time Programmable                     | One Time Programmable Non-Volatile Memory system.                                                                                                                                                                                                                                                                          |
| OTP NVM             | One Time Programmable Non-Volatile Memory | One Time Programmable Non-Volatile Memory.                                                                                                                                                                                                                                                                                 |
| PCM                 | Pulse Code Modulation                     | A method used to digitally represent sampled analog signals. In a PCM stream, the amplitude of the analog signal is sampled regularly at uniform intervals, and each sample is quantized to the nearest value within a range of digital steps.                                                                             |
| PD                  | Pull Down                                 | A kind of film.                                                                                                                                                                                                                                                                                                            |
| PDAF                | Phase Detection Auto Focus                | Replaces the PDAF points inside the raw input data                                                                                                                                                                                                                                                                         |
| PDM                 | Pulse Density Modulation                  | A 1-bit over sampled audio format                                                                                                                                                                                                                                                                                          |
| PGA                 | Programmable Gain Amplifier               | It can be controlled by software to amplify or decrease the amplitude of signal.                                                                                                                                                                                                                                           |
| PWM                 | Pulse Width Modulation                    | A method for getting analog results with digital means. Digital control is used to create a square wave, a signal switched between on and off.                                                                                                                                                                             |
| QoS                 | Quality of Service                        | The statistical allocation of throughput and delay, in terms of bandwidth and latency.                                                                                                                                                                                                                                     |
| RAWNR               | RAW Noise Reduction                       | Noise reduction on RAW domain                                                                                                                                                                                                                                                                                              |
| RGA                 | Raster Graphic Acceleration               | Include image scale, alpha, overlay, rotation and so on.                                                                                                                                                                                                                                                                   |
| RISC-V              | Reduced Instruction Set Computer Five     | RISC-V (pronounced "risk-five") is a new instruction set architecture (ISA) that was originally designed to support computer                                                                                                                                                                                               |

| <b>Abbreviation</b> | <b>Full Name</b>                                      | <b>Instruction</b>                                                                                                                                                  |
|---------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |                                                       | architecture research and education, but which we now hope will also become a standard free and open architecture for industry implementations.                     |
| ROI                 | Region Of Interest                                    | Tile based, Part of interest region in one picture                                                                                                                  |
| RSP                 | Role Swap Protocol                                    | Role Swap Protocol in USB OTG Specification.                                                                                                                        |
| RX                  | Receive                                               |                                                                                                                                                                     |
| S/s                 | sample per second                                     | Sample rate                                                                                                                                                         |
| SAR-ADC             | Successive Approximation Register (SAR) A/D Converter | Voltage scaling module                                                                                                                                              |
| SDP                 | Standard Downstream Port                              | A Standard Downstream Port (SDP) refers to a downstream port on a device that complies with the USB2.0 definition of a host or hub.                                 |
| SDRAM               | Synchronous Dynamic Random-access Memory              | A kind of dynamic memory.                                                                                                                                           |
| SLC                 | Single-Level Cell                                     | Each cell in flash can only store 1bit data                                                                                                                         |
| SOF                 | Start of Frame                                        | The first transaction in each (micro)frame. An SOF allows endpoints to identify the start of the (micro)frame and synchronize internal endpoint clocks to the host. |
| SRC                 | Source                                                | Source Image                                                                                                                                                        |
| TDM                 | Time Division Multiplexing                            | TDM uses different time periods of the same physical connection to transmit different signals                                                                       |
| TMO                 | Tone mapping                                          | Realize wide dynamic compression                                                                                                                                    |
| TNR                 | Time based Noise Reduction                            | Reduce noises to ensure that the image is quiet with the edges and details kept in YUV domain.                                                                      |
| TS-ADC              | Temperature-Sensor ADC                                | Temperature scaling module                                                                                                                                          |
| TX                  | Transmit                                              |                                                                                                                                                                     |
| USB                 | Universal Serial Bus                                  | Universal Serial Bus for peripheral.                                                                                                                                |
| UTMI                | USB 2.0 Transceiver Macrocell Interface               | Transceiver Macrocell Interface for USB2.0.                                                                                                                         |
| UVNR                | UV based Noise Reduction                              | Filter the color noise                                                                                                                                              |
| VDPU                | Video Decoder Process Unit                            | A processor that can decoder video stream to picture for display.                                                                                                   |
| VEPU                | Video Encoder Process Unit                            | A processor that can encoder picture to video stream.                                                                                                               |
| VOP                 | Video Output Processor                                | A video process engine and a display interface from memory frame buffer to display device.                                                                          |
| VPU                 | Video Process Unit                                    | Include VDPU and VEPU.                                                                                                                                              |
| WDR                 | Wide Dynamic Range                                    | Make the particularly bright and dark parts of the scene can see very clearly at the same time.                                                                     |
| xHCI                | eXtensible Host Controller Interface                  | eXtensible Host Controller Interface for Universal Serial Bus.                                                                                                      |
| YNR                 | Y based Noise Reduction                               | Filter the noise of Y component                                                                                                                                     |

**Difference between RV1109 and RV1126**

| Type    | RV1109                   | RV1126                         |
|---------|--------------------------|--------------------------------|
| CPU     | Dual A7                  | Quad A7                        |
| NPU     | 1.2Tops                  | 2.0TOPS                        |
| ISP     | 5M up to 3072-pixel wide | 14M<br>$\leq 4416 \times 3312$ |
| Encoder | 5M up to 3072-pixel wide | 4K30 H.264/H.265               |
| Decoder | 5M up to 3072-pixel wide | 4K30 H.264/H.265               |

# Chapter 1 System Overview

## 1.1 Address Mapping

RV1109/RV1126 boot from internal BootRom, which supports remap function by software programming. Remap is controlled by PMU\_SGRF\_SOC\_CON0[13]. 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     |
|-----------|---------------|----------|--------------|---------------|----------|
| GRF       | 0xFE000000    | 128KB    | SARADC       | 0xFF5E0000    | 64KB     |
| PMU_GRF   | 0xFE020000    |          | CPU_TSADC    | 0xFF5F0000    | 32KB     |
| DDR_GRF   | 0xFE030000    | 64KB     | NPU_TSADC    | 0xFF5F8000    | 32KB     |
| RESERVED  | 0xFE040000    | 64KB     | DCF          | 0xFF600000    | 64KB     |
| BUS_SGRF  | 0xFE0A0000    | 384KB    | CAN          | 0xFF610000    | 64KB     |
| PMU_SGRF  | 0xFE0B0000    | 64KB     | GPIO1        | 0xFF620000    | 64KB     |
| RESERVED  | 0xFE0C0000    | 64KB     | GPIO2        | 0xFF630000    | 64KB     |
| GIC400    | 0xFEFF0000    | 7.0625MB | I2S2_2CH     | 0xFF820000    | 64KB     |
| DEBUG     | 0xFF000000    | 64KB     | PDM          | 0xFF830000    | 64KB     |
| CORE_PVTM | 0xFF040000    | 256KB    | AUDPWM       | 0xFF840000    | 64KB     |
| RESERVED  | 0xFF060000    | 64KB     | RKACDC_DIG   | 0xFF850000    | 64KB     |
| RESERVED  | 0xFF3D0000    | 3.5MB    | RESERVED     | 0xFF860000    | 1.3125MB |
| PMU       | 0xFF3E0000    | 64KB     | DDR_STDBY    | 0xFF9B0000    | 32KB     |
| I2C0      | 0xFF3F0000    | 64KB     | RESERVED     | 0xFF9B8000    | 32KB     |
| I2C2      | 0xFF400000    | 64KB     | DDR_MONITOR  | 0xFF9C0000    | 32KB     |
| UART1     | 0xFF410000    | 64KB     | RESERVED     | 0xFF9D0000    | 550KB    |
| SCRAMBLE  | 0xFF420000    | 64KB     | UPCTL2       | 0xFFA50000    | 64KB     |
| PWM0      | 0xFF430000    | 64KB     | FIREWALL_APB | 0xFFA60000    | 64KB     |
| PWM1      | 0xFF440000    | 64KB     | RESERVED     | 0xFFA70000    | 448KB    |
| SPI0      | 0xFF450000    | 64KB     | VICAP        | 0xFFAE0000    | 64KB     |
| GPIO0     | 0xFF460000    | 64KB     | RGA          | 0xFFAF0000    | 64KB     |
| PMU_PVTM  | 0xFF470000    | 64KB     | VOP_LITE     | 0xFFB00000    | 64KB     |
| PMU_CRU   | 0xFF480000    | 64KB     | CSI_RX_CTRL  | 0xFFB10000    | 64KB     |
| CRU       | 0xFF490000    | 64KB     | IEP          | 0xFFB20000    | 64KB     |
| DDR_PHY   | 0xFF4A0000    | 64KB     | DSI_CTRL     | 0xFFB30000    | 64KB     |
| CSI_PHY0  | 0xFF4B0000    | 64KB     | RESERVED     | 0xFFB40000    | 64KB     |
| CSI_PHY1  | 0xFF4B8000    | 32KB     | ISP2.0       | 0xFFB50000    | 64KB     |
| OTG_APB   | 0xFF4C0000    | 32KB     | ISPP         | 0xFFB60000    | 128KB    |
| HOST_APB  | 0xFF4C8000    | 32KB     | VDPU343      | 0xFFB80000    | 64KB     |
| DSI_PHY   | 0xFF4D0000    | 32KB     | VPU121       | 0xFFB90000    | 64KB     |
| DMAC      | 0xFF4E0000    | 64KB     | RESERVED     | 0xFFBA0000    | 64KB     |
| SDMAC     | 0xFF4F0000    | 64KB     | VEPU52X      | 0xFFBB0000    | 64KB     |
| CRYPTO    | 0xFF500000    | 64KB     | NPU          | 0xFFBC0000    | 256KB    |
| I2C1      | 0xFF510000    | 64KB     | NPU_PVTM     | 0xFFC00000    | 64KB     |
| I2C3      | 0xFF520000    | 64KB     | RESERVED     | 0xFFC10000    | 64KB     |
| I2C4      | 0xFF530000    | 64KB     | RESERVED     | 0xFFC20000    | 128KB    |
| I2C5      | 0xFF540000    | 64KB     | GMAC         | 0xFFC40000    | 64KB     |
| PWM2      | 0xFF550000    | 64KB     | EMMC         | 0xFFC50000    | 64KB     |
| UART0     | 0xFF560000    | 64KB     | SDMMC        | 0xFFC60000    | 64KB     |

| Module | Start Address | Size | Module       | Start Address | Size  |
|--------|---------------|------|--------------|---------------|-------|
| UART2  | 0xFF570000    | 64KB | SDIO         | 0xFFC70000    | 64KB  |
| UART3  | 0xFF580000    | 64KB | NANDC        | 0xFFC80000    | 64KB  |
| UART4  | 0xFF590000    | 64KB | FSPI         | 0xFFC90000    | 64KB  |
| UART5  | 0xFF5A0000    | 64KB |              |               |       |
| SPI1   | 0xFF5B0000    | 64KB | RESERVED     | 0xFFCA0000    | 384KB |
| OTP_NS | 0xFF5C0000    | 64KB | USB2.0_OTG0  | 0xFFD00000    | 1MB   |
| OTP_S  | 0xFF5D0000    | 64KB | USB2.0_HOST0 | 0xFFE00000    | 256KB |

Notes:

PMU\_SRAM only has 8KB memory size.

MCU internal timer can only be accessed by access by MCU.

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'b11 |                    | remap[1:0]=2'b10 |                    |
|------------------|--------------------|------------------|--------------------|------------------|--------------------|
|                  |                    | not accessible   |                    | BootRom (20KB)   |                    |
| 0xFFFF0000       | BootRom(20KB)      | 0xFFFF0000       | PMU_SRAM(8KB)      | 0xFF000000       | SYSTEM_SRAM (64KB) |
| 0xFF710000       | PMU_SRAM(8KB)      | 0xFF710000       | PMU_SRAM(8KB)      | 0xFF710000       | PMU_SRAM(8KB)      |
| 0xFF700000       | SYSTEM_SRAM (64KB) | 0xFF700000       | SYSTEM_SRAM (64KB) | 0xFF700000       | SYSTEM_SRAM (64KB) |

## 1.2 System Boot

RV1109/RV1126 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 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)
  - Asynchronous Flash Interface, 8bits data width
  - eMMC Interface, 8bits data width
  - SDMMC Card, 4bits data width
- Support system code download by USB OTG

Following figure shows RV1109/RV1126 boot procedure flow.



Fig. 1-1 RV1109/RV1126 Boot Procedure Flow

## 1.3 System Interrupt Connection

RV1109/RV1126 provides an general interrupt controller (GIC) for CPU, which has 256 SPI (shared peripheral interrupts) interrupt sources and 3 PPI(Private peripheral interrupt) interrupt source and separately generates one nIRQ and one nFIQ to CPU. The triggered type for each interrupt is high level sensitive, not programmable. The detailed interrupt sources connection is in the following table.

Table 1-3 RV1109/RV1126 Interrupt Connection List

| Number  | Source         | Polarity   |
|---------|----------------|------------|
| 0-31PPI |                | High level |
| 32      | dcf_int        | High level |
| 33      | dmac_int       | High level |
| 34      | dmac_abort_int | High level |
| 35      | crypto_int     | High level |
| 36      | i2c0_int       | High level |
| 37      | i2c1_int       | High level |
| 38      | i2c2_int       | High level |
| 39      | i2c3_int       | High level |
| 40      | i2c4_int       | High level |
| 41      | i2c5_int       | High level |
| 42      | spi0_int       | High level |
| 43      | spi1_int       | High level |
| 44      | uart0_int      | High level |
| 45      | uart1_int      | High level |
| 46      | uart2_int      | High level |
| 47      | uart3_int      | High level |
| 48      | uart4_int      | High level |
| 49      | uart5_int      | High level |
| 50      | pwm0_int       | High level |
| 51      | pwm0_int_pwr   | High level |
| 52      | pwm1_int       | High level |
| 53      | pwm1_int_pwr   | High level |
| 54      | pwm2_int       | High level |
| 55      | pwm2_int_pwr   | High level |
| 56      | timer0_int     | High level |
| 57      | timer1_int     | High level |
| 58      | timer2_int     | High level |
| 59      | timer3_int     | High level |
| 60      | timer4_int     | High level |
| 61      | timer5_int     | High level |
| 62      | stimer0_int    | High level |
| 63      | stimer1_int    | High level |
| 64      | wdt_int        | High level |
| 65      | swdt_int       | High level |
| 66      | gpio0_int      | High level |
| 67      | gpio1_int      | High level |

| Number | Source                    | Polarity   |
|--------|---------------------------|------------|
| 68     | gpio2_int                 | High level |
| 69     | gpio3_int                 | High level |
| 70     | gpio4_int                 | High level |
| 71     | cpu_tsadc_int             | High level |
| 72     | saradc_int                | High level |
| 73     | msch_alarm_irq            | High level |
| 74     | upctl_arpoison_int        | High level |
| 75     | upctl_awpoison_int        | High level |
| 76     | upctl_alert_err_int       | High level |
| 77     | ddrmon_int                | High level |
| 78     | i2s8ch_int                | High level |
| 79     | i2s2ch0_int               | High level |
| 80     | i2s2ch1_int               | High level |
| 81     | pdm_int                   | High level |
| 82     | aud pwm_int               | High level |
| 83     | irq_isp_mmu_0             | High level |
| 84     | isp_irq_isp               | High level |
| 85     | ciflite_int_out_ciflite   | High level |
| 86     | mi_irq_isp                | High level |
| 87     | mipi_irq_isp              | High level |
| 88     | intr1_csirx               | High level |
| 89     | intr2_csirx               | High level |
| 90     | cif_int_out_cif           | High level |
| 91     | vop_intr_vopm             | High level |
| 92     | vop_intr_post_lb_vopm     | High level |
| 93     | mipi_dsi_host_irq_dsihost | High level |
| 94     | rga_irq                   | High level |
| 95     | ispp_irq                  | High level |
| 96     | fec_irq                   | High level |
| 97     | ispp_mmu0_r_irq           | High level |
| 98     | ispp_mmu0_w_irq           | High level |
| 99     | ispp_mmu1_irq             | High level |
| 100    | venc_int                  | High level |
| 101    | venc_mmu0_int             | High level |
| 102    | venc_mmu2_int             | High level |
| 103    | vdec_dec_irq              | High level |
| 104    | vdec_mmu_irq              | High level |
| 105    | jpeg_dec_irq              | High level |
| 106    | jpeg_enc_irq              | High level |
| 107    | jpeg_mmu_irq              | High level |
| 108    | sdcard_int                | High level |
| 109    | sdio_int                  | High level |
| 110    | emmc_int                  | High level |
| 111    | nandc_int                 | High level |

| Number  | Source                           | Polarity   |
|---------|----------------------------------|------------|
| 112     | sfc_int                          | High level |
| 113     | decom_int                        | High level |
| 114     | usbhost_ehci_int                 | High level |
| 115     | usbhost_ohci_int                 | High level |
| 116     | usbhost_arb_int                  | High level |
| 117     | usbotg_int                       | High level |
| 118     | usbotg_host_legacy_smi_interrupt | High level |
| 119     | usbotg_host_sys_err              | High level |
| 120     | usbotg_pme_generation            | High level |
| 121     | reserved                         | High level |
| 122     | reserved                         | High level |
| 123     | reserved                         | High level |
| 124     | reserved                         | High level |
| 125     | reserved                         | High level |
| 126     | pmu_int                          | High level |
| 127     | gmac_sbd_int                     | High level |
| 128     | gmac_pmt_int                     | High level |
| 129     | gmac_sbd_perch_rx_int            | High level |
| 130     | gmac_sbd_perch_tx_int            | High level |
| 131     | gmac_lpi_int                     | High level |
| 132     | can_int                          | High level |
| 133     | otpcs_int                        | High level |
| 134     | otpcns_int                       | High level |
| 135     | otpmask_int                      | High level |
| 136     | pmic_int                         | High level |
| 137     | sdmmc_detectn_irq_grf            | High level |
| 138     | sdmmc_detectn_flt                | High level |
| 139     | xaq2_intr_nanoq                  | High level |
| 140     | pmupvtm_int                      | High level |
| 141     | npupvtm_int                      | High level |
| 142     | cpupvtm_int                      | High level |
| 143     | mailbox_irq_ap                   | High level |
| 144     | mailbox_irq_bb                   | High level |
| 145     | npu_tsadc_int                    | High level |
| 146     | iep_irq                          | High level |
| 147     | usbphy_otg_bvalid_irq            | High level |
| 148     | usbphy_otg_id_irq                | High level |
| 149     | usbphy_otg_linestate_irq         | High level |
| 150     | usbphy_host_linestate_irq        | High level |
| 151     | usbphy_host_disconnect_irq       | High level |
| 152     | usbphy_otg_disconnect_irq        | High level |
| 153-154 | reserved                         | NA         |
| 155     | ~nPMUIRQ[0]                      | High level |
| 156     | ~nPMUIRQ[1]                      | High level |

| Number | Source      | Polarity   |
|--------|-------------|------------|
| 157    | ~nPMUIRQ[2] | High level |
| 158    | ~nPMUIRQ[3] | High level |

## 1.4 System DMA Hardware Request Connection

RV1109/RV1126 provides one DMA controller (DMAC) inside the system. For detailed descriptions of DMAC, please refer to Chapter 8.

Table 1-4 RV1109/RV1126 DMAC Hardware Request Connection List

| Request Index | Source   | Polarity   |
|---------------|----------|------------|
| 0             | SPI0 RX  | High level |
| 1             | SPI0 TX  | High level |
| 2             | SPI1 RX  | High level |
| 3             | SPI1 TX  | High level |
| 4             | UART0 RX | High level |
| 5             | UART0 TX | High level |
| 6             | UART1 RX | High level |
| 7             | UART1 TX | High level |
| 8             | UART2 RX | High level |
| 9             | UART2 TX | High level |
| 10            | UART3 RX | High level |
| 11            | UART3 TX | High level |
| 12            | UART4 RX | High level |
| 13            | UART4 TX | High level |
| 14            | UART5 RX | High level |
| 15            | UART5 TX | High level |
| 16            | PWM0     | High level |
| 17            | PWM1     | High level |
| 18            | PWM2     | High level |
| 19            | I2S0 RX  | High level |
| 20            | I2S0 TX  | High level |
| 21            | I2S1 RX  | High level |
| 22            | I2S1 TX  | High level |
| 23            | I2S2 RX  | High level |
| 24            | I2S2 TX  | High level |
| 25            | PDM      | High level |
| 26            | AudioPWM | High level |

## Chapter 2 Cortex-A7

### 2.1 Overview

The Cortex-A7 subsystem of the device is based on the ARMv7-A architecture. The Cortex-A7 has four Cortex-A7 central processing units (CPUs). Each processor has 32KB of Level 1 (L1) instruction cache, 32KB of L1 data cache, NEON and FPU. The Cortex-A7 also includes 512KB 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
  - 4 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
- 512KB L2 cache
  - Fixed line length of 64 bytes
  - Physically indexed and tagged cache
  - 8-way set-associative cache structure
  - Pseudo-random cache replacement policy

### 2.2 Block Diagram



Fig. 2-1 Core Subsystem Architecture

### 2.3 Function Description

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

### 2.4 Register Description

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

## Chapter 3 RISC-V

### 3.1 Overview

It is RISC-V compatible MCU core. The core is load-store architecture, where only load and store instructions access memory and arithmetic instructions only operate on integer registers. The core provides a 32-bit user address space that is byte-addressed and little-endian. And it only implements machine levels, one of four RISC-V privilege levels.

The key features of the RISC-V core include:

- Harvard architecture (separate instruction and data buses)
- Machine privilege level
- 32 32-bit general purpose integer registers
- Instruction set is RV32I with M and C extensions
- High-performance or area-optimized multiply/divide unit
- 3 stage pipeline implementation
- 32-bit AHB-Lite external memory interface
- Integrated Programmable Interrupt Controller(IPIC), up to 128 IRQ lines with 128to16 INTMUX
- Debug Controller with JTAG interface
- Hardware Break-point Module
- 3 embedded 64bit performance counters
- Real time clock
- Cycle counter
- Instructions-retired counter

### 3.2 Block Diagram



Fig. 3-1 Block Diagram of RISC-V Core

### 3.3 Function Description

#### 3.3.1 Interrupt Multiplexer(INTMUX)

The Interrupt Multiplexer will select 16 interrupts from 128 interrupts using round robin algorithm. You need to configure corresponding enable bit for each interrupt. Also you could

read the flag register to obtain the interrupt in service.

### 3.3.2 Integrated Programmable Interrupt Controller(IPIC)

RISC-V core include Integrated Programmable Interrupt Controller (IPIC) with low latency IRQ response. IPIC can be configured using IPIC Control Status Registers.

The term Interrupt Line has the meaning of corresponding IPIC external pin where suitable source of external interrupt may be connected to.

The term Interrupt Vector has the meaning of external interrupt number which will be generated by IPIC in response to external interrupt.

IPIC supports maximum 16 Interrupt vectors [0..15] and 16 Interrupt lines [0..15], each line is statically mapped to the corresponding vector.

Interrupt Vectors are given fixed priorities. The lowest Interrupt Vector number has the highest priority. IPIC supports nested interrupts. Only one interrupt can be serviced at a time. "Void interrupt vector" is defined as a non-existent vector number 0x10. This value is used to indicate absence of a valid interrupt vector.

*NOTE: Write access to the IPIC control status registers is implemented only through the use of the CSRRW(I) instructions, the CSRRS(I) and CSRRC(I) instructions are not supported.*



Fig. 3-2 Block Diagram of IPIC

Depending on the IM (interrupt mode), INV (line inversion) values for each vector, one of four conditions for IP (interrupt pending) bit activation is selected: high level, low level, rising edge, falling edge. Of all vectors with IP and IE (interrupt enable) bits active, the lowest numbered vector has the highest priority. Software is responsible for writing the SOI and EOI registers, thus notifying IPIC of the start and end of interrupt processing, respectively.

### 3.3.3 Debug

The core's debug sub-system is implemented in compliance with the RISC-V External Debug Support specification [3]. Its block diagram is shown in Fig.1-3.



Fig. 3-3 Block Diagram of Debug Sub-system

An external debugger communicates with the core's debug sub-system via JTAG interface and TAP Controller (TAPC), playing a role of the Debug Transport Module (DTM) in terms of the RISC-V Debug Specification [3]. The TAPC implements several private TAP instructions allowing debugger to interact with internal debug units:

- DTMCS provides general control over DTM
- DMI\_ACCESS provides access to the Debug Module (DM)
- SCU\_ACCESS provides access to the System Control Unit (SCU)

Internal connection between TAPC and DM, DM and SCU, is a form of serial scan interface. Source and destination of the TAPC scan interface are in different clock domains: TAPC is fully running in JTAG's TCK clock domain, whereas DM and SCU are in the core clock domain. Therefore, the TAPC scan interface passes through the clock synchronization unit (SYNC). The System Control Unit (SCU) provides control over implementation-specific reset circuitry, and allows to monitor states of main reset signals.

Using the Debug Module Interface (DMI), the Debug Module (DM) exposes a standard register interface to the core's debug features:

- run control of the core's single hart
- access to its internal registers (GPRs, CSRs)
- access to its memory space
- capability to execute arbitrary instructions from the Program Buffer

The register interface is compliant with the RISC-V Debug Specification [3].

Implementation of this debug functionality within the hart is distributed between several units, and from external prospective the most important among them are:

- Hart Debug Unit (HDU) - provides the hart's Debug Interface, connecting the hart with the DM, and contains Debug CSRs
- Trigger Module (TM) - provides a capability of hardware breakpoints, and contains Trigger CSRs

## 3.4 Register Description

### 3.4.1 General-purpose Integer Registers

General-purpose Integer Register is the user-visible registers of the core. There are 31 general-purpose registers x1-x31, which are designed to hold integer values. Register x0 is hardwired to the constant 0 and can be used as a source of constant zero or as a don't care destination register.

Don't care destination x0 is used to ignore the result of instruction execution provided that destination register is mandatory for instruction structure.

All general-purpose registers in the core are 32-bits wide.

The core implements 32-bit pc register, which is used as program counter, meaning that it holds the address of the current instruction.

### 3.4.2 Control and Status Register

Control/status registers (CSR) of the core are accessed atomically using instructions specifically designed for CSR access. CSR access instructions are listed in Instruction set

summary section of this specification.

According to the RISC-V specification [2], the core uses 12-bit encoding space to address up to 4096 control/status registers (CSR) in the instructions which atomically read and modify CSRs. The core implements subset of CSRs according to the mapping shown in the next paragraphs. The core follows RISC-V convention, where the upper 4 bits of the CSR address [11:8] are used to encode the read and write accessibility of the CSRs according to the privilege level. The top two bits [11:10] indicate whether the register is read/write (00, 01, or 10) or read-only (11). The next two bits [9:8] indicate the lowest privilege level that can access the CSR.

The core implements the following rules for CSR access:

1. Attempts to access a non-existent CSR raise an illegal instruction exception.
2. Attempts to write a read-only CSR also raise illegal instruction exception.
3. If a read/write register contains some bits that are read-only, then writes to the read-only bits are ignored.

### 3.4.3 RISC-V Registers Summary

| Name                   | Offset | Size | Reset Value | Description                                |
|------------------------|--------|------|-------------|--------------------------------------------|
| RISC-V TIMER_CTRL      | 0x0000 | W    | 0x00000001  | Timer Control Register                     |
| RISC-V TIMER_DIV       | 0x0004 | W    | 0x00000000  | Timer Divider Register                     |
| RISC-V MTIME           | 0x0008 | W    | 0x00000000  | Machine Timer Register Low 32bit           |
| RISC-V MTIMEH          | 0x000C | W    | 0x00000000  | Machine Timer Register High 32bit          |
| RISC-V MTIMECMP        | 0x0010 | W    | 0x00000000  | Machine Timer Compare Register Low 32bit   |
| RISC-V MTIMECMHP       | 0x0014 | W    | 0x00000000  | Machine Timer Compare Register High 32bit  |
| RISC-V CSR_MVENDORID   | 0x0F11 | W    | 0x00000000  | Machine Vendor ID Register                 |
| RISC-V CSR_MARCHID     | 0x0F12 | W    | 0x00000000  | Machine Architecture ID Register           |
| RISC-V CSR_MIMPID      | 0x0F13 | W    | 0x011432A4  | Machine Implementation ID Register         |
| RISC-V CSR_MHARTID     | 0x0F14 | W    | 0x00000000  | Machine Hart ID Register                   |
| RISC-V CSR_MSTATUS     | 0x0300 | W    | 0x00001880  | Machine Status Register                    |
| RISC-V CSR_MISA        | 0x0301 | W    | 0x40001104  | Machine Base ISA Control Register          |
| RISC-V CSR_MIE         | 0x0304 | W    | 0x00000000  | Machine Interrupt Enable Register          |
| RISC-V CSR_MTVEC       | 0x0305 | W    | 0x002001C0  | Machine Trap-Vector Base-Address Register  |
| RISC-V CSR_MSCRATCH    | 0x0340 | W    | 0x00000000  | Machine Scratch Register                   |
| RISC-V CSR_MEPC        | 0x0341 | W    | 0x00000000  | Machine Exception Program Counter Register |
| RISC-V CSR_MCAUSE      | 0x0342 | W    | 0x00000000  | Machine Cause Register                     |
| RISC-V CSR_MVAL        | 0x0343 | W    | 0x00000000  | Machine Trap Value Register                |
| RISC-V CSR_MIP         | 0x0344 | W    | 0x00000000  | Machine Interrupt Pending Register         |
| RISC-V CSR_MCYCLEL     | 0x0B00 | W    | 0x00000000  | Machine Cycle Counter Low Register         |
| RISC-V CSR_MCYCLEH     | 0x0B80 | W    | 0x00000000  | Machine Cycle Counter High Register        |
| RISC-V CSR_MINSTRETL   | 0x0B02 | W    | 0x00000000  | Machine Instructions Retired Low Register  |
| RISC-V CSR_MINSTRETH   | 0x0B82 | W    | 0x00000000  | Machine Instructions Retired High Register |
| RISC-V CSR_MCOUNTEN    | 0x07E0 | W    | 0x00000005  | Machine Counter Enable Register            |
| RISC-V_CSR_DBG_SCRATCH | 0x07C8 | W    | 0x00000000  | Debug Scratch Register                     |

| Name                  | Offset | Size | Reset Value | Description                               |
|-----------------------|--------|------|-------------|-------------------------------------------|
| RISC-V CSR IPIC CISV  | 0x0BF0 | W    | 0x00000000  | Current Interrupt Vector in Service       |
| RISC-V CSR IPIC CICSR | 0x0BF1 | W    | 0x00000000  | Current Interrupt Control Status Register |
| RISC-V CSR IPIC IPR   | 0x0BF2 | W    | 0x00000000  | Interrupt Pending Register                |
| RISC-V CSR IPIC ISVR  | 0x0BF3 | W    | 0x00000000  | Interrupt Serviced Register               |
| RISC-V CSR IPIC EOI   | 0x0BF4 | W    | 0x00000000  | End Of Interrupt                          |
| RISC-V CSR IPIC SOI   | 0x0BF5 | W    | 0x00000000  | Start Of Interrupt                        |
| RISC-V CSR IPIC IDX   | 0x0BF6 | W    | 0x00000000  | Index Register                            |
| RISC-V CSR IPIC ICSR  | 0x0BF7 | W    | 0x00000000  | Interrupt Control 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

### 3.4.4 RISC-V Detail Registers Description

#### RISC-V 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                              |

#### RISC-V 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 |

#### RISC-V 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) |

#### RISC-V 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) |

#### RISC-V MTIMECMP

Address: Operational Base + offset (0x0010)

| Bit  | Attr | Reset Value | Description                                                |
|------|------|-------------|------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | MTIMECMPL<br>Machine-mode timer compare register low 32bit |

#### RISC-V MTIMECMPPH

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | MTIMECMPH<br>Machine-mode timer compare register high 32bit |

**RISC-V CSR MVENDORID**

Address: Operational Base + offset (0x0F11)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | VENDOR ID<br>The JEDEC manufacturer ID of the provider of the core |

**RISC-V CSR MARCHID**

Address: Operational Base + offset (0x0F12)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | ARCH ID<br>Encoding the base micro-architecture of the hart |

**RISC-V CSR MIMPID**

Address: Operational Base + offset (0x0F13)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x011432a4         | 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 |

**RISC-V CSR MHARTID**

Address: Operational Base + offset (0x0F14)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | HART ID<br>Containing the integer ID of the hardware thread running the code. |

**RISC-V CSR MSTATUS**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                         |
| 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                                         |

**RISC-V 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        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 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                                             |

**RISC-V CSR MIE**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 31:12      | RO          | 0x000000           | 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                                  |

**RISC-V 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) |

**RISC-V 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. |

**RISC-V 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                                                                            |

**RISC-V 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 |

**RISC-V 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. |

**RISC-V 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                                   |

**RISC-V 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. |

**RISC-V CSR MCYCLEH**

Address: Operational Base + offset (0x0B80)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | MCYCLEH<br>Represent the number of clock cycles(high 32bit) since some arbitrary point of time in the past. |

**RISC-V CSR MINSTRETL**

Address: Operational Base + offset (0x0B02)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | MINSTRETL<br>Represent the number of instructions(low 32bit) retired by the core from some arbitrary time in the past. |

**RISC-V CSR MINSTRETH**

Address: Operational Base + offset (0x0B82)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | MINSTRETH<br>Represent the number of instructions(low 32bit) retired by the core from some arbitrary time in the past. |

**RISC-V CSR MCOUNTEN**

Address: Operational Base + offset (0x07E0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                        |
|------------|-------------|--------------------|-------------------------------------------|
| 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                |

**RISC-V CSR DBG SCRATCH**

Address: Operational Base + offset (0x07C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | DSCRATCH<br>Used to exchange data between the core and the debug controller. |

**RISC-V CSR IPIC CISV**

Address: Operational Base + offset (0x0BF0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                    |
| 4:0        | RO          | 0x00               | CISV<br>Number of the interrupt vector currently in service |

**RISC-V CSR IPIC CICSR**

Address: Operational Base + offset (0x0BF1)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                          |
| 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          |

**RISC-V 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. |

**RISC-V 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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 15:0       | RO          | 0x0000             | SERVICE<br>When corresponding bit is set (1) - this interrupt vector is in service. |

**RISC-V 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. |

**RISC-V 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. |

**RISC-V 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 |

**RISC-V 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. |
| 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                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 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          |

### 3.4.5 INTMUX Registers Summary

| <b>Name</b>                       | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                |
|-----------------------------------|---------------|-------------|--------------------|-----------------------------------|
| <u>INTMUX INT ENABLE GR_OUP0</u>  | 0x0000        | W           | 0x00000000         | Interrupt Group0 Enable Register  |
| <u>INTMUX INT ENABLE GR_OUP1</u>  | 0x0004        | W           | 0x00000000         | Interrupt Group1 Enable Register  |
| <u>INTMUX INT ENABLE GR_OUP2</u>  | 0x0008        | W           | 0x00000000         | Interrupt Group2 Enable Register  |
| <u>INTMUX INT ENABLE GR_OUP3</u>  | 0x000C        | W           | 0x00000000         | Interrupt Group3 Enable Register  |
| <u>INTMUX INT ENABLE GR_OUP4</u>  | 0x0010        | W           | 0x00000000         | Interrupt Group4 Enable Register  |
| <u>INTMUX INT ENABLE GR_OUP5</u>  | 0x0014        | W           | 0x00000000         | Interrupt Group5 Enable Register  |
| <u>INTMUX INT ENABLE GR_OUP6</u>  | 0x0018        | W           | 0x00000000         | Interrupt Group6 Enable Register  |
| <u>INTMUX INT ENABLE GR_OUP7</u>  | 0x001C        | W           | 0x00000000         | Interrupt Group7 Enable Register  |
| <u>INTMUX INT ENABLE GR_OUP8</u>  | 0x0020        | W           | 0x00000000         | Interrupt Group8 Enable Register  |
| <u>INTMUX INT ENABLE GR_OUP9</u>  | 0x0024        | W           | 0x00000000         | Interrupt Group9 Enable Register  |
| <u>INTMUX INT ENABLE GR_OUP10</u> | 0x0028        | W           | 0x00000000         | Interrupt Group10 Enable Register |
| <u>INTMUX INT ENABLE GR_OUP11</u> | 0x002C        | W           | 0x00000000         | Interrupt Group11 Enable Register |
| <u>INTMUX INT ENABLE GR_OUP12</u> | 0x0030        | W           | 0x00000000         | Interrupt Group12 Enable Register |
| <u>INTMUX INT ENABLE GR_OUP13</u> | 0x0034        | W           | 0x00000000         | Interrupt Group13 Enable Register |
| <u>INTMUX INT ENABLE GR_OUP14</u> | 0x0038        | W           | 0x00000000         | Interrupt Group14 Enable Register |
| <u>INTMUX INT ENABLE GR_OUP15</u> | 0x003C        | W           | 0x00000000         | Interrupt Group15 Enable Register |
| <u>INTMUX INT FLAG GROU_P0</u>    | 0x0080        | W           | 0x00000000         | Interrupt Group0 Flag Register    |
| <u>INTMUX INT FLAG GROU_P1</u>    | 0x0084        | W           | 0x00000000         | Interrupt Group1 Flag Register    |
| <u>INTMUX INT FLAG GROU_P2</u>    | 0x0088        | W           | 0x00000000         | Interrupt Group2 Flag Register    |
| <u>INTMUX INT FLAG GROU_P3</u>    | 0x008C        | W           | 0x00000000         | Interrupt Group3 Flag Register    |
| <u>INTMUX INT FLAG GROU_P4</u>    | 0x0090        | W           | 0x00000000         | Interrupt Group4 Flag Register    |

| Name                        | Offset | Size | Reset Value | Description                     |
|-----------------------------|--------|------|-------------|---------------------------------|
| INTMUX INT FLAG GROU<br>P5  | 0x0094 | W    | 0x00000000  | Interrupt Group5 Flag Register  |
| INTMUX INT FLAG GROU<br>P6  | 0x0098 | W    | 0x00000000  | Interrupt Group6 Flag Register  |
| INTMUX INT FLAG GROU<br>P7  | 0x009C | W    | 0x00000000  | Interrupt Group7 Flag Register  |
| INTMUX INT FLAG GROU<br>P8  | 0x00A0 | W    | 0x00000000  | Interrupt Group8 Flag Register  |
| INTMUX INT FLAG GROU<br>P9  | 0x00A4 | W    | 0x00000000  | Interrupt Group9 Flag Register  |
| INTMUX INT FLAG GROU<br>P10 | 0x00A8 | W    | 0x00000000  | Interrupt Group10 Flag Register |
| INTMUX INT FLAG GROU<br>P11 | 0x00AC | W    | 0x00000000  | Interrupt Group11 Flag Register |
| INTMUX INT FLAG GROU<br>P12 | 0x00B0 | W    | 0x00000000  | Interrupt Group12 Flag Register |
| INTMUX INT FLAG GROU<br>P13 | 0x00B4 | W    | 0x00000000  | Interrupt Group13 Flag Register |
| INTMUX INT FLAG GROU<br>P14 | 0x00B8 | W    | 0x00000000  | Interrupt Group14 Flag Register |
| INTMUX INT FLAG GROU<br>P15 | 0x00BC | W    | 0x00000000  | Interrupt Group15 Flag 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

### 3.4.6 INTMUX Detail Registers Description

#### INTMUX INT ENABLE GROUP0

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                    |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x000000    | reserved                                                                                                       |
| 7:0  | RW   | 0x00        | 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:8 | RO   | 0x000000    | reserved                                                                                                       |
| 7:0  | RW   | 0x00        | 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:8 | RO   | 0x000000    | reserved                                                                                                       |
| 7:0  | RW   | 0x00        | 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP4**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP5**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP6**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP7**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP8**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP9**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP10**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP11**

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          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP12**

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          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP13**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP14**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | ENABLE<br>Each bit represents one interrupt enable bit.<br>1'b0: Interrupt disabled<br>1'b1: Interrupt enabled |

**INTMUX INT ENABLE GROUP15**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                       |
| 7:0        | RW          | 0x00               | 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP4**

Address: Operational Base + offset (0x0090)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP5**

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        | RO          | 0x00               | 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 GROUP6**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP7**

Address: Operational Base + offset (0x009C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP8**

Address: Operational Base + offset (0x00A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP9**

Address: Operational Base + offset (0x00A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP10**

Address: Operational Base + offset (0x00A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP11**

Address: Operational Base + offset (0x00AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP12**

Address: Operational Base + offset (0x00B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP13**

Address: Operational Base + offset (0x00B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP14**

Address: Operational Base + offset (0x00B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | 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 GROUP15**

Address: Operational Base + offset (0x00BC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                 |
| 7:0        | RO          | 0x00               | FLAG<br>Each bit represents one interrupt is in service.<br>1'b0: Interrupt in service<br>1'b1: Interrupt out of service |

### 3.5 Interface Description

Table 3-1 Serial Wire Debug Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pin Name</b>                                                 | <b>IOMUX Setting</b>                      |
|-------------------|------------------|-----------------------------------------------------------------|-------------------------------------------|
| TCK               | I                | SDMMC0_D2/UART3_RX_M1/A7_JTAG_TCK_M0/RISC-V_JTAG_TCK/GPIO1_A6_u | GRF_GPIO1A_IOMUX_S<br>EL_H[11:8]=4'b0100  |
| TMS               | I/O              | SDMMC0_D3/UART3_TX_M1/A7_JTAG_TMS_M0/RISC-V_JTAG_TMS/GPIO1_A7_u | GRF_GPIO1A_IOMUX_S<br>EL_H[15:12]=4'b0100 |

| <b>Module Pin</b> | <b>Direction</b> | <b>Pin Name</b>                                                  | <b>IOMUX Setting</b>                    |
|-------------------|------------------|------------------------------------------------------------------|-----------------------------------------|
| TRSTn             | I                | SDMMC0_D1/TEST_CLK0_OUT/UART2_TX_M0/RISC-V_JTAG_TRSTn/GPIO1_A5_u | GRF_GPIO1A_IOMUX_S<br>EL_H[7:4]=4'b0100 |
| TDO               | O                | SDMMC0_CLK/UART3_RTSN_M1/RISC-V_JTAG_TDO/GPIO1_B0_u              | GRF_GPIO1B_IOMUX_S<br>EL_L[3:0]=4'b0100 |
| TDI               | I                | SDMMC0_CMD/UART3_CTSN_M1/RISC-V_JTAG_TDI/GPIO1_B1_u              | GRF_GPIO1B_IOMUX_S<br>EL_L[7:4]=4'b0100 |

*Notes: Unused Module Pin is tied to zero! I=input, O=output, I/O=input/output, bidirectional*

## 3.6 Application Notes

- How to boot?  
Currently, the RISC-V core boot address is configurable, its default value is 32'h0000\_0000, and the default value of trap vector base address is 32'h0000\_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 RISC-V\_CSR\_MTVEC register by system instructions.
- Are 16 IRQ lines enough?  
Actually, there are 123 IRQ lines in full chip, and all of these IRQ lines are connected to RISC-V core, there is a 128to16 MUX for these IRQ lines before entering to IPIC of RISC-V core. Each 8 IRQ lines is regard as one group and connect to one IRQ line of RISC-V core. Not only We should configure IPIC, but also configure INTMUX before activates IRQ.

## 3.7 Referenced documents

- [\[\[\[1\]\]\] The RISC-V Instruction Set Manual Volume I: User-Level ISA](#)
- [\[\[\[2\]\]\] The RISC-V Instruction Set Manual Volume II: Privileged Architecture](#)
- [\[\[\[3\]\]\] RISC-V External Debug Support, Version 0.132](#)

## Chapter 4 Embedded SRAM

### 4.1 Overview

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

#### 4.1.1 Features supported

- SYSTEM\_SRAM
  - Provide 64KB 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

### 4.2 Block Diagram



Fig. 4-1 Embedded SRAM block diagram



Fig. 4-2 SYSTEM\_SRAM Security Configuration

### 4.3 Function Description

#### 4.3.1 AXI slave interface of SYSTEM\_SRAM

The AXI slave interface is bridge which translates AXI bus access to SRAM interface of

SYSTEM\_SRAM.

#### **4.3.2 AHB slave interface of PMU\_SRAM**

The AHB slave interface is bridge which translates AHB bus access to SRAM interface of PMU\_SRAM.

#### **4.3.3 Embedded SRAM access path**

The SYSTEM\_SRAM can only be accessed by Cortex-A7, MCU, CRYPTO, DCF, DECOM, DMAC and USB2\_OTG. The PMU\_SRAM can only be accessed by Cortex-A7, MCU, CRYPTO and DMAC.

## Chapter 5 Clock & Reset Unit (CRU)

### 5.1 Overview

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

The CRU is located at several addresses.

- CRU\_PMU, used for always on system, with base address 0xFF480000
- CRU, used for general system except always on system, with base address 0xFF490000

The CRU supports the following features:

- Compliance with AMBA APB interface
- Embedded with 5 PLLs
- Flexible selection of clock source
- Support dividing clock separately
- Support gating clock separately
- Support software reset each module separately

### 5.2 Block Diagram

The CRU comprises with:

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



Fig. 5-1 CRU Block Diagram

### 5.3 Function Description

#### 5.3.1 System Clock Solution

There are 5 PLLs in RV1109/RV1126: APLL, HPLL, DPLL, CPLL and GPLL. 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. When power on or changing PLL setting, we must program PLL into slow mode or deep slow mode.

To maximize the flexibility, some of clocks can select divider source from multiple PLLs. To provide some specific frequency, another solution is integrated: fractional divider. Divfree50 divider and divfreeNP5 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{divisor}$
- When divisor is even, the clock duty cycle of clk\_out is 50%

- When divisor is odd, the clock duty cycle of clk\_out is not 50%
- Fracdiv(Fractional divider)
- $\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{divisor}$
- When divisor 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} = 2 * \text{clk\_in\_freq} / (2 * \text{div\_con} + 3)$
- The clock duty cycle of clk\_out is not 50%

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

### 5.3.2 System Reset Solution

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



Fig. 5-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 0xfdb9
- glb\_srstn\_2: Second global software reset by programming CRU\_GLB\_SRST\_SND as 0xeaca8

### 5.3.3 PLL Introduction

The PLLs inside RV1109/RV1126 output clock's frequency up to 6.4GHz. The PLL is a general purpose, high-performance PLL-based clock generator. 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: 5MHz to 1200MHz for integer mode and 10MHz to 1200MHz for fractional mode
- PFD minimum reference frequency range: 5MHz for integer mode and 10MHz for fractional mode
- Output frequency range: 16MHz to 6.4GHz
- VCO output frequency range: 1.6GHz to 6.4GHz
- 24 bit fractional accuracy, and fractional mode jitter performance to nearly match integer mode performance.
- 4:1 VCO frequency range allows PLL to be optimized for minimum jitter or minimum

- power
  - Isolated analog supply (1.8V) allows for excellent supply rejection in noisy SoC applications
  - Lock detect signal indicates when frequency lock has been achieved
  - Offset calibration to reduce jitter
- PLL block diagram is shown below.



Fig. 5-3 PLL Block Diagram

### 5.3.3.1 PLL Offset Calibration

Offset calibration is included in PLL in order to reduce jitter resulting from systematic mismatch in the PLL's forward path.

The total systematic mismatch of the PLL consists of many contributors including device mismatch and leakage. This total mismatch is represented as  $\phi_{err}$  at the input of the PFD. This is the intrinsic offset of the PLL.  $\phi_c$  is the offset correction implemented with the offset calibration block. When settled,  $\phi_c$  will be approximately equal to  $\phi_{err}$ , resulting in minimum jitter.



Fig. 5-4 PLL Offset Calibration

CALCODE is the internal offset calibration setting and can be monitored at CALOUT. The optimal CALCODE is available at CALOUT when CALLOCK is asserted. The offset calibration is only enabled if CALEN==1. The starting condition of the calibration process is set by CALIN. CALIN provides a mechanism for initializing the calibration process. If the CALIN is preset to previously calibrated CALCODE prior to enabling the offset calibration, the system is able to start at  $\phi_c$ . The calibration process steps through CALCODE, which is the internal offset calibration setting, to find the optimal  $\phi_c$  that corrects for  $\phi_{err}$ .

The CALCNT input sets the update rate of the offset calibration. Smaller values of CALCNT result in faster CALCODE updates.

When FASTCAL=1, the offset calibration process steps through the CALCODE quickly and reaches the noise floor within  $32 \times 2^{(5+CALCNT)}$  PFD cycles. The calibration process continues to converge towards optimal  $\phi_c$ , and asserts CALLOCK when this state is reached. The state of CALCODE can be monitored at CALOUT and the optimal CALCODE is available

when CALLOCK=1.

If the CALIN is preset to previously calibrated CALCODE prior to enabling the offset calibration, the system is able to start within the noise floor region and continue to converge towards optimal  $\phi_c$ .

If CALBYPASS=1, the CALCODE is set by CALIN. If calibration has already been run, the optimal CALCODE can be stored and used as an input when the PLL is enabled in the future. Future calibration would begin with the optimal CALCODE, allowing the IP to start with no systematic contributions to the period jitter.

## 5.4 CRU\_PMU Register Description

### 5.4.1 Registers Summary

| Name                          | Offset | Size | Reset Value | Description                                    |
|-------------------------------|--------|------|-------------|------------------------------------------------|
| CRU_PMU_MODE_CON00            | 0x0000 | W    | 0x00000000  | Mode control register 0                        |
| CRU_PMU_GPLL_CON0             | 0x0010 | W    | 0x00002064  | GPLL control register 0                        |
| CRU_PMU_GPLL_CON1             | 0x0014 | W    | 0x00001081  | GPLL control register 1                        |
| CRU_PMU_GPLL_CON2             | 0x0018 | W    | 0x00000000  | GPLL control register 2                        |
| CRU_PMU_GPLL_CON3             | 0x001C | W    | 0x00000007  | GPLL control register 3                        |
| CRU_PMU_GPLL_CON4             | 0x0020 | W    | 0x00007F00  | GPLL control register 4                        |
| CRU_PMU_GPLL_CON5             | 0x0024 | W    | 0x00000000  | GPLL control register 5                        |
| CRU_PMU_GPLL_CON6             | 0x0028 | W    | 0x00000000  | GPLL control register 6                        |
| CRU_PMU_GPLL_OFFSETCAL_STATUS | 0x0030 | W    | 0x00000000  | GPLL offset calibration status register        |
| CRU_PMU_CLKSEL_CON0_0         | 0x0100 | W    | 0x00000000  | Internal clock select and division register 0  |
| CRU_PMU_CLKSEL_CON0_1         | 0x0104 | W    | 0x00000000B | Internal clock select and division register 1  |
| CRU_PMU_CLKSEL_CON0_2         | 0x0108 | W    | 0x00000000B | Internal clock select and division register 2  |
| CRU_PMU_CLKSEL_CON0_3         | 0x010C | W    | 0x00000000B | Internal clock select and division register 3  |
| CRU_PMU_CLKSEL_CON0_4         | 0x0110 | W    | 0x000000800 | Internal clock select and division register 4  |
| CRU_PMU_CLKSEL_CON0_5         | 0x0114 | W    | 0x000000000 | Internal clock select and division register 5  |
| CRU_PMU_CLKSEL_CON0_6         | 0x0118 | W    | 0x000000000 | Internal clock select and division register 6  |
| CRU_PMU_CLKSEL_CON0_7         | 0x011C | W    | 0x000063F1  | Internal clock select and division register 7  |
| CRU_PMU_CLKSEL_CON0_8         | 0x0120 | W    | 0x000000000 | Internal clock select and division register 8  |
| CRU_PMU_CLKSEL_CON0_9         | 0x0124 | W    | 0x00000000B | Internal clock select and division register 9  |
| CRU_PMU_CLKSEL_CON1_2         | 0x0130 | W    | 0x000000005 | Internal clock select and division register 12 |
| CRU_PMU_CLKSEL_CON1_3         | 0x0134 | W    | 0x000000000 | Internal clock select and division register 13 |
| CRU_PMU_GATE_CON00            | 0x0180 | W    | 0x000000000 | Internal clock gate and division register 0    |
| CRU_PMU_GATE_CON01            | 0x0184 | W    | 0x000000000 | Internal clock gate and division register 1    |
| CRU_PMU_GATE_CON02            | 0x0188 | W    | 0x000000000 | Internal clock gate and division register 2    |
| CRU_PMU_SOFTRST_CON00         | 0x0200 | W    | 0x000000000 | Internal clock reset register 0                |

| Name                  | Offset | Size | Reset Value | Description                     |
|-----------------------|--------|------|-------------|---------------------------------|
| CRU PMU SOFTRST CON01 | 0x0204 | 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

## 5.4.2 Detail Register Description

### CRU PMU MODE CON00

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:2  | RO   | 0x0000      | reserved                                                                                                                           |
| 1:0   | 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_deepsleep<br>Others: Reserved    |

### CRU PMU GPLL CON0

Address: Operational Base + offset (0x0010)

| 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   | 0x2         | postdiv1<br>First post divide value. Valid settings are [1-7].                                                                                          |
| 11:0  | RW   | 0x064       | 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 PMU GPLL CON1

Address: Operational Base + offset (0x0014)

| 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         | pllpdsel<br>PLL global power down source selection.<br>If pllpdsel=1, PLL can be power down only by pllpd1, otherwise<br>PLL is power down when any one of refdiv/fbdv/fracdiv is<br>changed or pllpd0 is asserted. |
| 14    | RW   | 0x0         | pllpd1<br>PLL global power down request 1.<br>1'b0: No power down<br>1'b1: Power down                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | pllpd0<br>PLL global power down request 0.<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. Valid settings are [1-7].                                        |
| 5:0        | RW          | 0x01               | refdiv<br>Reference clock divide value, Valid settings are [1-63].                                     |

**CRU PMU GPLL CON2**

Address: Operational Base + offset (0x0018)

| <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.<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          | 0x0000000          | fracdiv<br>Fractional part of feedback divide, fraction = fracdiv/2^24.                                           |

**CRU PMU GPLL CON3**

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 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                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | ssmod_downspread<br>Select 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 PMU GPLL CON4**

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:8       | RW          | 0x7f               | ssmod_ext_maxaddr<br>External wave table data inputs. Valid settings are [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 PMU GPLL CONS**

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:4       | RW          | 0x000              | offsetcal_in<br>offsetcal_byp=1'b0: Initial condition for offset calibration logic.<br>offsetcal_byp=1'b1: Override value for offset calibration. It is a signed integer with positive values delaying the reset of the faster path, and negative values delaying the reset of the slower path. 5'b0 is the minimum value, with each count increasing the reset time by one buffer delay.<br>If offsetcal_en=1, this can be used to force a offset correction value based on a previous readout of offsetcal_out[11:0]. If offsetcal_byp=1 this value is forced directly into the calibration logic. If offsetcal_byp=0 this is the initial condition for the calibration sequence. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | offsetcal_fast<br>Offset fast calibration enable.<br>Set this to 1 for initial calibration if an initial value is not already known.<br>Should be set to 0 for normal operation.                                                                                                          |
| 2          | RW          | 0x0                | offsetcal_en<br>Offset calibration enable to actively adjust for input offset.<br>1'b0: Offset calibration is disabled. Static phase offset is determined by analog matching only.<br>1'b1: Offset calibration is enabled. Static phase offset is adjusted by sensing phase at the input. |
| 1          | RW          | 0x0                | offsetcal_byp<br>Offset calibration bypass.<br>1'b0: Use the offset calibration output(when offsetcal_en=1) to set the phase correction<br>1'b1: Use the offsetcal_in[11:0] value (when offsetcal_en=1) to set the phase correction                                                       |
| 0          | RW          | 0x0                | fout2xpd<br>Power down 2X clocks.<br>1'b0: No power down<br>1'b1: Power down                                                                                                                                                                                                              |

**CRU PMU GPLL CON6**

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 16 bits, 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                | offsetcal_cnt<br>Programmable counter for offset calibration loop.<br>Selects the number of PFD edges to wait after each offset calibration step. Count is defined as $2^{(\text{offsetcal\_cnt}+4)}$ . |

**CRU PMU GPLL OFFSETCAL STATUS**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 16         | RW          | 0x0                | offsetcal_lock<br>Asserted when phase lock is achieved when offsetcal_en is set to 1'b1                                                                                                                                                                                                                                                                                                                                    |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 11:0       | RW          | 0x000              | offsetcal_out<br>This is the output of either the offset calibration block (if offsetcal_byp=0) or a buffered version of offsetcal_in[11:0] (if offsetcal_byp=1).<br>It can be used to read out the phase calibration state to use as an override value so that offset calibration can be bypassed for faster locking. The value changes on the rising edge of FREF, so it can be clocked out on the falling edge of FREF. |

**CRU PMU CLKSEL CON00**

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:9       | RO          | 0x00               | reserved                                                                                                                                      |
| 8:7        | RW          | 0x0                | clk_deepslow_sel<br>clk_deepslow clock mux.<br>2'b00: clk_pmupvtm_divout<br>2'b01: xin_osc1_32k<br>2'b10: clk_osc0_div32k<br>Others: Reserved |
| 6:5        | RO          | 0x0                | reserved                                                                                                                                      |
| 4:0        | RW          | 0x00               | xin_osc0_div_div<br>Divide xin_osc0_div by (div_con + 1)                                                                                      |

**CRU PMU CLKSEL CON01**

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 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          | 0x0b               | pclk_pdpmu_pre_div<br>Divide pclk_pdpmu_pre by (div_con + 1)                                                                       |

**CRU PMU CLKSEL CON02**

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:7       | RO          | 0x000              | reserved                                                                                                                           |
| 6:0        | RW          | 0x0b               | clk_i2c0_div<br>Divide clk_i2c0 by (div_con + 1)                                                                                   |

**CRU PMU CLKSEL CON03**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:7       | RO          | 0x000              | reserved                                                                                                                           |
| 6:0        | RW          | 0x0b               | clk_i2c2_div<br>Divide clk_i2c2 by (div_con + 1)                                                                                   |

**CRU PMU CLKSEL CON04**

Address: Operational Base + offset (0x0110)

| <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:12      | RO          | 0x0                | reserved                                                                                                                                           |
| 11:10      | RW          | 0x2                | sclk_uart1_sel<br>sclk_uart1 clock mux.<br>2'b00: sclk_uart1_div<br>2'b01: sclk_uart1_fracdiv<br>2'b10: xin_osc0_func<br>Others: Reserved          |
| 9:8        | RW          | 0x0                | sclk_uart1_div_sel<br>sclk_uart1_div clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: usbphy_clk480m_mux<br>2'b10: clk_cpll_mux<br>2'b11: xin_osc0_func |
| 7          | RO          | 0x0                | reserved                                                                                                                                           |
| 6:0        | RW          | 0x00               | sclk_uart1_div_div<br>Divide sclk_uart1_div by (div_con + 1)                                                                                       |

**CRU PMU CLKSEL CON05**

Address: Operational Base + offset (0x0114)

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

**CRU PMU CLKSEL CON06**

Address: Operational Base + offset (0x0118)

| <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_pwm1_sel<br>clk_pwm1 clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_gpll_mux                                                   |
| 14:8       | RW          | 0x00               | clk_pwm1_div<br>Divide clk_pwm1 by (div_con + 1)                                                                                   |
| 7          | RW          | 0x0                | clk_pwm0_sel<br>clk_pwm0 clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_gpll_mux                                                   |
| 6:0        | RW          | 0x00               | clk_pwm0_div<br>Divide clk_pwm0 by (div_con + 1)                                                                                   |

**CRU PMU CLKSEL CON07**

Address: Operational Base + offset (0x011C)

| <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                | clk_mipidsiphy_ref_sel<br>clk_mipidsiphy_ref clock mux.<br>1'b0: clk_ref24m<br>1'b1: xin_osc0_mipidsiphyref_g       |
| 14:8       | RW          | 0x63               | clk_ref12m_div<br>Divide clk_ref12m by (div_con + 1)                                                                |
| 7          | RW          | 0x1                | clk_usbphy_host_ref_sel<br>clk_usbphy_host_ref clock mux.<br>1'b0: clk_ref12m<br>1'b1: xin_osc0_div2_usbphyref_host |
| 6          | RW          | 0x1                | clk_usbphy_otg_ref_sel<br>clk_usbphy_otg_ref clock mux.<br>1'b0: clk_ref12m<br>1'b1: xin_osc0_div2_usbphyref_otg    |
| 5:0        | RW          | 0x31               | clk_ref24m_div<br>Divide clk_ref24m by (div_con + 1)                                                                |

**CRU PMU CLKSEL CON08**

Address: Operational Base + offset (0x0120)

| <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                | dbclk_gpio0_sel<br>dbclk_gpio0 clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_deepslow                                             |
| 14:0       | RO          | 0x0000             | reserved                                                                                                                           |

**CRU PMU CLKSEL CON09**

Address: Operational Base + offset (0x0124)

| <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_spi0_sel<br>clk_spi0 clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: xin_osc0_func                                                   |
| 6:0        | RW          | 0x0b               | clk_spi0_div<br>Divide clk_spi0 by (div_con + 1)                                                                                   |

**CRU PMU CLKSEL CON12**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:9       | RO          | 0x00               | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | clk_wifi_sel<br>clk_wifi clock mux.<br>1'b0: clk_wifi_osc0<br>1'b1: clk_wifi_div |
| 7:6        | RO          | 0x0                | reserved                                                                         |
| 5:0        | RW          | 0x05               | clk_wifi_div_div<br>Divide clk_wifi_div by (div_con + 1)                         |

**CRU PMU CLKSEL CON13**

Address: Operational Base + offset (0x0134)

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

**CRU PMU GATE CON00**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_pmu_en<br>clk_pmu clock gating control.<br>When high, disable clock.                                                           |
| 14         | RW          | 0x0                | sclk_uart1_en<br>sclk_uart1 clock gating control.<br>When high, disable clock.                                                     |
| 13         | RW          | 0x0                | sclk_uart1_fracdiv_en<br>sclk_uart1_fracdiv clock gating control.<br>When high, disable clock.                                     |
| 12         | RW          | 0x0                | sclk_uart1_div_en<br>sclk_uart1_div clock gating control.<br>When high, disable clock.                                             |
| 11         | RW          | 0x0                | pclk_uart1_en<br>pclk_uart1 clock gating control.<br>When high, disable clock.                                                     |
| 10         | RW          | 0x0                | clk_i2c2_en<br>clk_i2c2 clock gating control.<br>When high, disable clock.                                                         |
| 9          | RW          | 0x0                | pclk_i2c2_en<br>pclk_i2c2 clock gating control.<br>When high, disable clock.                                                       |
| 8          | RO          | 0x0                | reserved                                                                                                                           |
| 7          | RW          | 0x0                | pclk_scrkeygen_en<br>pclk_scrkeygen clock gating control.<br>When high, disable clock.                                             |
| 6          | RW          | 0x0                | clk_i2c0_en<br>clk_i2c0 clock gating control.<br>When high, disable clock.                                                         |
| 5          | RW          | 0x0                | pclk_i2c0_en<br>pclk_i2c0 clock gating control.<br>When high, disable clock.                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | pclk_pmusgrf_en<br>pclk_pmusgrf clock gating control.<br>When high, disable clock.     |
| 3          | RO          | 0x0                | reserved                                                                               |
| 2          | RW          | 0x0                | pclk_pdpmu_biu_en<br>pclk_pdpmu_biu 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                | pclk_pdpmu_en<br>pclk_pdpmu_pre clock gating control.<br>When high, disable clock.     |

**CRU PMU GATE CON01**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_ref12m_en<br>clk_ref12m clock gating control.<br>When high, disable clock.                                                     |
| 14         | RW          | 0x0                | clk_ref24m_en<br>clk_ref24m clock gating control.<br>When high, disable clock.                                                     |
| 13         | RW          | 0x0                | pclk_pmugrf_en<br>pclk_pmugrf clock gating control.<br>When high, disable clock.                                                   |
| 12         | RW          | 0x0                | clk_spi0_en<br>clk_spi0 clock gating control.<br>When high, disable clock.                                                         |
| 11         | RW          | 0x0                | pclk_spi0_en<br>pclk_spi0 clock gating control.<br>When high, disable clock.                                                       |
| 10         | RW          | 0x0                | dbclk_gpio0_en<br>dbclk_gpio0 clock gating control.<br>When high, disable clock.                                                   |
| 9          | RW          | 0x0                | pclk_gpio0_en<br>pclk_gpio0 clock gating control.<br>When high, disable clock.                                                     |
| 8          | RW          | 0x0                | xin_osc0_dsiphy_ref_en<br>xin_osc0_mipidsiphy_ref clock gating control.<br>When high, disable clock.                               |
| 7          | RW          | 0x0                | xin_osc0_hostphy_ref_en<br>xin_osc0_div2_hostphy_ref clock gating control.<br>When high, disable clock.                            |
| 6          | RW          | 0x0                | xin_osc0_otgphy_ref_en<br>xin_osc0_div2_otgphy_ref clock gating control.<br>When high, disable clock.                              |
| 5          | RW          | 0x0                | clk_capture_pwm1_en<br>clk_capture_pwm1_ndft clock gating control.<br>When high, disable clock.                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | clk_pwm1_en<br>clk_pwm1 clock gating control.<br>When high, disable clock.                      |
| 3          | RW          | 0x0                | pclk_pwm1_en<br>pclk_pwm1 clock gating control.<br>When high, disable clock.                    |
| 2          | RW          | 0x0                | clk_capture_pwm0_en<br>clk_capture_pwm0_ndft clock gating control.<br>When high, disable clock. |
| 1          | RW          | 0x0                | clk_pwm0_en<br>clk_pwm0 clock gating control.<br>When high, disable clock.                      |
| 0          | RW          | 0x0                | pclk_pwm0_en<br>pclk_pwm0 clock gating control.<br>When high, disable clock.                    |

**CRU PMU GATE CON02**

Address: Operational Base + offset (0x0188)

| <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_wifi_osc0_en<br>clk_wifi_osc0 clock gating control.<br>When high, disable clock.                                               |
| 10         | RW          | 0x0                | clk_wifi_div_en<br>clk_wifi_div clock gating control.<br>When high, disable clock.                                                 |
| 9          | RW          | 0x0                | clk_osc0_div32k_en<br>clk_osc0_div32k clock gating control.<br>When high, disable clock.                                           |
| 8          | RW          | 0x0                | xin_osc0_div_en<br>xin_osc0_div clock gating control.<br>When high, disable clock.                                                 |
| 7          | RW          | 0x0                | clk_core_pmupvtm_en<br>clk_core_pmupvtm clock gating control.<br>When high, disable clock.                                         |
| 6          | RW          | 0x0                | pclk_pmupvtm_en<br>pclk_pmupvtm clock gating control.<br>When high, disable clock.                                                 |
| 5          | RW          | 0x0                | clk_pmupvtm_en<br>clk_pmupvtm clock gating control.<br>When high, disable clock.                                                   |
| 4          | RW          | 0x0                | pclk_pmucru_en<br>pclk_pmucru clock gating control.<br>When high, disable clock.                                                   |
| 3:1        | RO          | 0x0                | reserved                                                                                                                           |
| 0          | RW          | 0x0                | pclk_chipverotp_en<br>pclk_chipverotp clock gating control.<br>When high, disable clock.                                           |

**CRU PMU SOFTRST CON00**

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 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         | RW          | 0x0                | resetn_pwm1<br>When high, reset relative logic.                                                                                    |
| 13         | RW          | 0x0                | presetn_pwm1<br>When high, reset relative logic.                                                                                   |
| 12         | RW          | 0x0                | resetn_pwm0<br>When high, reset relative logic.                                                                                    |
| 11         | RW          | 0x0                | presetn_pwm0<br>When high, reset relative logic.                                                                                   |
| 10         | RW          | 0x0                | sresetn_uart1<br>When high, reset relative logic.                                                                                  |
| 9          | RW          | 0x0                | presetn_uart1<br>When high, reset relative logic.                                                                                  |
| 8          | RW          | 0x0                | resetn_i2c2<br>When high, reset relative logic.                                                                                    |
| 7          | RW          | 0x0                | presetn_i2c2<br>When high, reset relative logic.                                                                                   |
| 6:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4          | RW          | 0x0                | resetn_i2c0<br>When high, reset relative logic.                                                                                    |
| 3          | RW          | 0x0                | presetn_i2c0<br>When high, reset relative logic.                                                                                   |
| 2          | RW          | 0x0                | presetn_pmusgrf_remap<br>When high, reset relative logic.                                                                          |
| 1          | RW          | 0x0                | presetn_pmusgrf<br>When high, reset relative logic.                                                                                |
| 0          | RW          | 0x0                | presetn_pdpmu_biu<br>When high, reset relative logic.                                                                              |

**CRU PMU SOFTRST CON01**

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 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                | presetn_pmucru<br>When high, reset relative logic.                                                                                 |
| 13:10      | RO          | 0x0                | reserved                                                                                                                           |
| 9          | RW          | 0x0                | presetn_pmupvtm<br>When high, reset relative logic.                                                                                |
| 8          | RW          | 0x0                | resetn_pmupvtm<br>When high, reset relative logic.                                                                                 |
| 7          | RO          | 0x0                | reserved                                                                                                                           |
| 6          | RW          | 0x0                | presetn_chipverotp<br>When high, reset relative logic.                                                                             |
| 5          | RW          | 0x0                | presetn_pmugrf<br>When high, reset relative logic.                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 4          | RW          | 0x0                | resetn_spi0<br>When high, reset relative logic.    |
| 3          | RW          | 0x0                | presetn_spi0<br>When high, reset relative logic.   |
| 2          | RW          | 0x0                | dbresetn_gpio0<br>When high, reset relative logic. |
| 1          | RW          | 0x0                | presetn_gpio0<br>When high, reset relative logic.  |
| 0          | RO          | 0x0                | reserved                                           |

## 5.5 CRU Register Description

### 5.5.1 Registers Summary

| <b>Name</b>               | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                      |
|---------------------------|---------------|-------------|--------------------|-----------------------------------------|
| CRU APLL CON0             | 0x0000        | W           | 0x000020FA         | APLL control register 0                 |
| CRU APLL CON1             | 0x0004        | W           | 0x00001083         | APLL control register 1                 |
| CRU APLL CON2             | 0x0008        | W           | 0x00000000         | APLL control register 2                 |
| CRU APLL CON3             | 0x000C        | W           | 0x00000007         | APLL control register 3                 |
| CRU APLL CON4             | 0x0010        | W           | 0x00007F00         | APLL control register 4                 |
| CRU APLL CON5             | 0x0014        | W           | 0x00000000         | APLL control register 5                 |
| CRU APLL CON6             | 0x0018        | W           | 0x00000000         | APLL control register 6                 |
| CRU DPLL CON0             | 0x0020        | W           | 0x00003215         | DPLL control register 0                 |
| CRU DPLL CON1             | 0x0024        | W           | 0x00001084         | DPLL control register 1                 |
| CRU DPLL CON2             | 0x0028        | W           | 0x00000000         | DPLL control register 2                 |
| CRU DPLL CON3             | 0x002C        | W           | 0x00000007         | DPLL control register 3                 |
| CRU DPLL CON4             | 0x0030        | W           | 0x00007F00         | DPLL control register 4                 |
| CRU DPLL CON5             | 0x0034        | W           | 0x00000000         | DPLL control register 5                 |
| CRU DPLL CON6             | 0x0038        | W           | 0x00000000         | DPLL control register 6                 |
| CRU CPLL CON0             | 0x0040        | W           | 0x000020FA         | CPLL control register 0                 |
| CRU CPLL CON1             | 0x0044        | W           | 0x00001083         | CPLL control register 1                 |
| CRU CPLL CON2             | 0x0048        | W           | 0x00000000         | CPLL control register 2                 |
| CRU CPLL CON3             | 0x004C        | W           | 0x00000007         | CPLL control register 3                 |
| CRU CPLL CON4             | 0x0050        | W           | 0x00007F00         | CPLL control register 4                 |
| CRU CPLL CON5             | 0x0054        | W           | 0x00000000         | CPLL control register 5                 |
| CRU CPLL CON6             | 0x0058        | W           | 0x00000000         | CPLL control register 6                 |
| CRU HPLL CON0             | 0x0060        | W           | 0x00002145         | HPLL control register 0                 |
| CRU HPLL CON1             | 0x0064        | W           | 0x00001083         | HPLL control register 1                 |
| CRU HPLL CON2             | 0x0068        | W           | 0x00000000         | HPLL control register 2                 |
| CRU HPLL CON3             | 0x006C        | W           | 0x00000007         | HPLL control register 3                 |
| CRU HPLL CON4             | 0x0070        | W           | 0x00007F00         | HPLL control register 4                 |
| CRU HPLL CON5             | 0x0074        | W           | 0x00000000         | HPLL control register 5                 |
| CRU HPLL CON6             | 0x0078        | W           | 0x00000000         | HPLL control register 6                 |
| CRU APLL OFFSETCAL STATUS | 0x0080        | W           | 0x00000000         | APLL offset calibration status register |
| CRU DPLL OFFSETCAL STATUS | 0x0084        | W           | 0x00000000         | DPLL offset calibration status register |
| CRU CPLL OFFSETCAL STATUS | 0x0088        | W           | 0x00000000         | CPLL offset calibration status register |
| CRU HPLL OFFSETCAL STATUS | 0x008C        | W           | 0x00000000         | HPLL offset calibration status register |
| CRU MODE CON01            | 0x0090        | W           | 0x00000000         | Mode control register 1                 |

| Name             | Offset | Size | Reset Value | Description                                    |
|------------------|--------|------|-------------|------------------------------------------------|
| CRU CLKSEL CON00 | 0x0100 | W    | 0x000000580 | Internal clock select and division register 0  |
| CRU CLKSEL CON01 | 0x0104 | W    | 0x000000013 | Internal clock select and division register 1  |
| CRU CLKSEL CON02 | 0x0108 | W    | 0x000000583 | Internal clock select and division register 2  |
| CRU CLKSEL CON03 | 0x010C | W    | 0x00000050B | Internal clock select and division register 3  |
| CRU CLKSEL CON04 | 0x0110 | W    | 0x000000103 | Internal clock select and division register 4  |
| CRU CLKSEL CON05 | 0x0114 | W    | 0x000000B0B | Internal clock select and division register 5  |
| CRU CLKSEL CON06 | 0x0118 | W    | 0x000000B0B | Internal clock select and division register 6  |
| CRU CLKSEL CON07 | 0x011C | W    | 0x000000305 | Internal clock select and division register 7  |
| CRU CLKSEL CON08 | 0x0120 | W    | 0x00000000B | Internal clock select and division register 8  |
| CRU CLKSEL CON09 | 0x0124 | W    | 0x000000000 | Internal clock select and division register 9  |
| CRU CLKSEL CON10 | 0x0128 | W    | 0x000000800 | Internal clock select and division register 10 |
| CRU CLKSEL CON11 | 0x012C | W    | 0x000000000 | Internal clock select and division register 11 |
| CRU CLKSEL CON12 | 0x0130 | W    | 0x000000800 | Internal clock select and division register 12 |
| CRU CLKSEL CON13 | 0x0134 | W    | 0x000000000 | Internal clock select and division register 13 |
| CRU CLKSEL CON14 | 0x0138 | W    | 0x000000800 | Internal clock select and division register 14 |
| CRU CLKSEL CON15 | 0x013C | W    | 0x000000000 | Internal clock select and division register 15 |
| CRU CLKSEL CON16 | 0x0140 | W    | 0x000000800 | Internal clock select and division register 16 |
| CRU CLKSEL CON17 | 0x0144 | W    | 0x000000000 | Internal clock select and division register 17 |
| CRU CLKSEL CON18 | 0x0148 | W    | 0x000000800 | Internal clock select and division register 18 |
| CRU CLKSEL CON19 | 0x014C | W    | 0x000000000 | Internal clock select and division register 19 |
| CRU CLKSEL CON20 | 0x0150 | W    | 0x000000001 | Internal clock select and division register 20 |
| CRU CLKSEL CON21 | 0x0154 | W    | 0x000000000 | Internal clock select and division register 21 |
| CRU CLKSEL CON22 | 0x0158 | W    | 0x000000000 | Internal clock select and division register 22 |
| CRU CLKSEL CON23 | 0x015C | W    | 0x000000000 | Internal clock select and division register 23 |
| CRU CLKSEL CON24 | 0x0160 | W    | 0x000000000 | Internal clock select and division register 24 |
| CRU CLKSEL CON25 | 0x0164 | W    | 0x000000305 | Internal clock select and division register 25 |

| Name             | Offset | Size | Reset Value | Description                                    |
|------------------|--------|------|-------------|------------------------------------------------|
| CRU CLKSEL CON26 | 0x0168 | W    | 0x00000007  | Internal clock select and division register 26 |
| CRU CLKSEL CON27 | 0x016C | W    | 0x00000B0B  | Internal clock select and division register 27 |
| CRU CLKSEL CON28 | 0x0170 | W    | 0x00000000  | Internal clock select and division register 28 |
| CRU CLKSEL CON29 | 0x0174 | W    | 0x00000000  | Internal clock select and division register 29 |
| CRU CLKSEL CON30 | 0x0178 | W    | 0x0000014F  | Internal clock select and division register 30 |
| CRU CLKSEL CON31 | 0x017C | W    | 0x00001305  | Internal clock select and division register 31 |
| CRU CLKSEL CON32 | 0x0180 | W    | 0x00000000  | Internal clock select and division register 32 |
| CRU CLKSEL CON33 | 0x0184 | W    | 0x0000070B  | Internal clock select and division register 33 |
| CRU CLKSEL CON34 | 0x0188 | W    | 0x00000000  | Internal clock select and division register 34 |
| CRU CLKSEL CON35 | 0x018C | W    | 0x00000003  | Internal clock select and division register 35 |
| CRU CLKSEL CON36 | 0x0190 | W    | 0x0000000B  | Internal clock select and division register 36 |
| CRU CLKSEL CON37 | 0x0194 | W    | 0x00000000  | Internal clock select and division register 37 |
| CRU CLKSEL CON38 | 0x0198 | W    | 0x00000000  | Internal clock select and division register 38 |
| CRU CLKSEL CON40 | 0x01A0 | W    | 0x00000182  | Internal clock select and division register 40 |
| CRU CLKSEL CON41 | 0x01A4 | W    | 0x00000101  | Internal clock select and division register 41 |
| CRU CLKSEL CON42 | 0x01A8 | W    | 0x00008382  | Internal clock select and division register 42 |
| CRU CLKSEL CON43 | 0x01AC | W    | 0x00008183  | Internal clock select and division register 43 |
| CRU CLKSEL CON44 | 0x01B0 | W    | 0x00000183  | Internal clock select and division register 44 |
| CRU CLKSEL CON45 | 0x01B4 | W    | 0x00000103  | Internal clock select and division register 45 |
| CRU CLKSEL CON46 | 0x01B8 | W    | 0x00000102  | Internal clock select and division register 46 |
| CRU CLKSEL CON47 | 0x01BC | W    | 0x00000007  | Internal clock select and division register 47 |
| CRU CLKSEL CON48 | 0x01C0 | W    | 0x00000000  | Internal clock select and division register 48 |
| CRU CLKSEL CON49 | 0x01C4 | W    | 0x00000101  | Internal clock select and division register 49 |
| CRU CLKSEL CON50 | 0x01C8 | W    | 0x00000101  | Internal clock select and division register 50 |
| CRU CLKSEL CON51 | 0x01CC | W    | 0x00000742  | Internal clock select and division register 51 |
| CRU CLKSEL CON52 | 0x01D0 | W    | 0x00000000  | Internal clock select and division register 52 |

| Name             | Offset | Size | Reset Value | Description                                    |
|------------------|--------|------|-------------|------------------------------------------------|
| CRU CLKSEL CON53 | 0x01D4 | W    | 0x000000503 | Internal clock select and division register 53 |
| CRU CLKSEL CON54 | 0x01D8 | W    | 0x00004203  | Internal clock select and division register 54 |
| CRU CLKSEL CON55 | 0x01DC | W    | 0x000000002 | Internal clock select and division register 55 |
| CRU CLKSEL CON56 | 0x01E0 | W    | 0x000000002 | Internal clock select and division register 56 |
| CRU CLKSEL CON57 | 0x01E4 | W    | 0x000000002 | Internal clock select and division register 57 |
| CRU CLKSEL CON58 | 0x01E8 | W    | 0x000000005 | Internal clock select and division register 58 |
| CRU CLKSEL CON59 | 0x01EC | W    | 0x000000005 | Internal clock select and division register 59 |
| CRU CLKSEL CON61 | 0x01F4 | W    | 0x000000709 | Internal clock select and division register 61 |
| CRU CLKSEL CON63 | 0x01FC | W    | 0x000000107 | Internal clock select and division register 63 |
| CRU CLKSEL CON64 | 0x0200 | W    | 0x00000010B | Internal clock select and division register 64 |
| CRU CLKSEL CON65 | 0x0204 | W    | 0x000000011 | Internal clock select and division register 65 |
| CRU CLKSEL CON66 | 0x0208 | W    | 0x000000701 | Internal clock select and division register 66 |
| CRU CLKSEL CON67 | 0x020C | W    | 0x000000011 | Internal clock select and division register 67 |
| CRU CLKSEL CON68 | 0x0210 | W    | 0x000000501 | Internal clock select and division register 68 |
| CRU CLKSEL CON69 | 0x0214 | W    | 0x000000101 | Internal clock select and division register 69 |
| CRU CLKSEL CON70 | 0x0218 | W    | 0x000000000 | Internal clock select and division register 70 |
| CRU CLKSEL CON71 | 0x021C | W    | 0x000000000 | Internal clock select and division register 71 |
| CRU CLKSEL CON72 | 0x0220 | W    | 0x00000000B | Internal clock select and division register 72 |
| CRU CLKSEL CON73 | 0x0224 | W    | 0x000000007 | Internal clock select and division register 73 |
| CRU CLKSEL CON74 | 0x0228 | W    | 0x000000000 | Internal clock select and division register 74 |
| CRU CLKSEL CON75 | 0x022C | W    | 0x000000000 | Internal clock select and division register 75 |
| CRU CLKSEL CON76 | 0x0230 | W    | 0x000000101 | Internal clock select and division register 76 |
| CRU CLKSEL CON77 | 0x0234 | W    | 0x000000101 | Internal clock select and division register 77 |
| CRU GATE CON00   | 0x0280 | W    | 0x000000000 | Internal clock gate and division register 0    |
| CRU GATE CON02   | 0x0288 | W    | 0x000000000 | Internal clock gate and division register 2    |
| CRU GATE CON03   | 0x028C | W    | 0x000000000 | Internal clock gate and division register 3    |

| Name              | Offset | Size | Reset Value  | Description                                  |
|-------------------|--------|------|--------------|----------------------------------------------|
| CRU GATE CON04    | 0x0290 | W    | 0x0000000000 | Internal clock gate and division register 4  |
| CRU GATE CON05    | 0x0294 | W    | 0x0000000000 | Internal clock gate and division register 5  |
| CRU GATE CON06    | 0x0298 | W    | 0x0000000000 | Internal clock gate and division register 6  |
| CRU GATE CON07    | 0x029C | W    | 0x0000000000 | Internal clock gate and division register 7  |
| CRU GATE CON08    | 0x02A0 | W    | 0x0000000000 | Internal clock gate and division register 8  |
| CRU GATE CON09    | 0x02A4 | W    | 0x0000000000 | Internal clock gate and division register 9  |
| CRU GATE CON10    | 0x02A8 | W    | 0x0000000000 | Internal clock gate and division register 10 |
| CRU GATE CON11    | 0x02AC | W    | 0x0000000000 | Internal clock gate and division register 11 |
| CRU GATE CON12    | 0x02B0 | W    | 0x0000000000 | Internal clock gate and division register 12 |
| CRU GATE CON13    | 0x02B4 | W    | 0x0000000000 | Internal clock gate and division register 13 |
| CRU GATE CON14    | 0x02B8 | W    | 0x0000000000 | Internal clock gate and division register 14 |
| CRU GATE CON15    | 0x02BC | W    | 0x0000000000 | Internal clock gate and division register 15 |
| CRU GATE CON16    | 0x02C0 | W    | 0x0000000000 | Internal clock gate and division register 16 |
| CRU GATE CON17    | 0x02C4 | W    | 0x0000000000 | Internal clock gate and division register 17 |
| CRU GATE CON18    | 0x02C8 | W    | 0x0000000000 | Internal clock gate and division register 18 |
| CRU GATE CON19    | 0x02CC | W    | 0x0000000000 | Internal clock gate and division register 19 |
| CRU GATE CON20    | 0x02D0 | W    | 0x0000000000 | Internal clock gate and division register 20 |
| CRU GATE CON21    | 0x02D4 | W    | 0x0000000000 | Internal clock gate and division register 21 |
| CRU GATE CON22    | 0x02D8 | W    | 0x0000000000 | Internal clock gate and division register 22 |
| CRU GATE CON23    | 0x02DC | W    | 0x0000000000 | Internal clock gate and division register 23 |
| CRU GATE CON24    | 0x02E0 | W    | 0x0000000000 | Internal clock gate and division register 24 |
| CRU SOFTRST CON00 | 0x0300 | W    | 0x0000000000 | Internal clock reset register 0              |
| CRU SOFTRST CON01 | 0x0304 | W    | 0x0000000000 | Internal clock reset register 1              |
| CRU SOFTRST CON02 | 0x0308 | W    | 0x00000400   | Internal clock reset register 2              |
| CRU SOFTRST CON03 | 0x030C | W    | 0x0000000000 | Internal clock reset register 3              |
| CRU SOFTRST CON04 | 0x0310 | W    | 0x0000000000 | Internal clock reset register 4              |
| CRU SOFTRST CON05 | 0x0314 | W    | 0x0000000000 | Internal clock reset register 5              |
| CRU SOFTRST CON06 | 0x0318 | W    | 0x0000000000 | Internal clock reset register 6              |
| CRU SOFTRST CON07 | 0x031C | W    | 0x0000000000 | Internal clock reset register 7              |
| CRU SOFTRST CON08 | 0x0320 | W    | 0x0000000000 | Internal clock reset register 8              |
| CRU SOFTRST CON09 | 0x0324 | W    | 0x0000000000 | Internal clock reset register 9              |
| CRU SOFTRST CON10 | 0x0328 | W    | 0x0000000000 | Internal clock reset register 10             |

| Name              | Offset | Size | Reset Value | Description                                   |
|-------------------|--------|------|-------------|-----------------------------------------------|
| CRU_SOFTRST_CON11 | 0x032C | W    | 0x00000000  | Internal clock reset register 11              |
| CRU_SOFTRST_CON12 | 0x0330 | W    | 0x00001000  | Internal clock reset register 12              |
| CRU_SOFTRST_CON13 | 0x0334 | W    | 0x00000000  | Internal clock reset register 13              |
| CRU_SOFTRST_CON14 | 0x0338 | W    | 0x00000000  | Internal clock reset register 14              |
| CRU_SSCGTBL_CON0  | 0x0380 | W    | 0x00000000  | External wave table configuration register 0  |
| CRU_SSCGTBL_CON1  | 0x0384 | W    | 0x00000000  | External wave table configuration register 1  |
| CRU_SSCGTBL_CON2  | 0x0388 | W    | 0x00000000  | External wave table configuration register 2  |
| CRU_SSCGTBL_CON3  | 0x038C | W    | 0x00000000  | External wave table configuration register 3  |
| CRU_SSCGTBL_CON4  | 0x0390 | W    | 0x00000000  | External wave table configuration register 4  |
| CRU_SSCGTBL_CON5  | 0x0394 | W    | 0x00000000  | External wave table configuration register 5  |
| CRU_SSCGTBL_CON6  | 0x0398 | W    | 0x00000000  | External wave table configuration register 6  |
| CRU_SSCGTBL_CON7  | 0x039C | W    | 0x00000000  | External wave table configuration register 7  |
| CRU_SSCGTBL_CON8  | 0x03A0 | W    | 0x00000000  | External wave table configuration register 8  |
| CRU_SSCGTBL_CON9  | 0x03A4 | W    | 0x00000000  | External wave table configuration register 9  |
| CRU_SSCGTBL_CON10 | 0x03A8 | W    | 0x00000000  | External wave table configuration register 10 |
| CRU_SSCGTBL_CON11 | 0x03AC | W    | 0x00000000  | External wave table configuration register 11 |
| CRU_SSCGTBL_CON12 | 0x03B0 | W    | 0x00000000  | External wave table configuration register 12 |
| CRU_SSCGTBL_CON13 | 0x03B4 | W    | 0x00000000  | External wave table configuration register 13 |
| CRU_SSCGTBL_CON14 | 0x03B8 | W    | 0x00000000  | External wave table configuration register 14 |
| CRU_SSCGTBL_CON15 | 0x03BC | W    | 0x00000000  | External wave table configuration register 15 |
| CRU_SSCGTBL_CON16 | 0x03C0 | W    | 0x00000000  | External wave table configuration register 16 |
| CRU_SSCGTBL_CON17 | 0x03C4 | W    | 0x00000000  | External wave table configuration register 17 |
| CRU_SSCGTBL_CON18 | 0x03C8 | W    | 0x00000000  | External wave table configuration register 18 |
| CRU_SSCGTBL_CON19 | 0x03CC | W    | 0x00000000  | External wave table configuration register 19 |
| CRU_SSCGTBL_CON20 | 0x03D0 | W    | 0x00000000  | External wave table configuration register 20 |
| CRU_SSCGTBL_CON21 | 0x03D4 | W    | 0x00000000  | External wave table configuration register 21 |
| CRU_SSCGTBL_CON22 | 0x03D8 | W    | 0x00000000  | External wave table configuration register 22 |
| CRU_SSCGTBL_CON23 | 0x03DC | W    | 0x00000000  | External wave table configuration register 23 |

| Name                       | Offset | Size | Reset Value | Description                                   |
|----------------------------|--------|------|-------------|-----------------------------------------------|
| CRU SSCGTBL CON24          | 0x03E0 | W    | 0x00000000  | External wave table configuration register 24 |
| CRU SSCGTBL CON25          | 0x03E4 | W    | 0x00000000  | External wave table configuration register 25 |
| CRU SSCGTBL CON26          | 0x03E8 | W    | 0x00000000  | External wave table configuration register 26 |
| CRU SSCGTBL CON27          | 0x03EC | W    | 0x00000000  | External wave table configuration register 27 |
| CRU SSCGTBL CON28          | 0x03F0 | W    | 0x00000000  | External wave table configuration register 28 |
| CRU SSCGTBL CON29          | 0x03F4 | W    | 0x00000000  | External wave table configuration register 29 |
| CRU SSCGTBL CON30          | 0x03F8 | W    | 0x00000000  | External wave table configuration register 30 |
| CRU SSCGTBL CON31          | 0x03FC | W    | 0x00000000  | External wave table configuration register 31 |
| CRU GLB CNT TH             | 0x0400 | W    | 0x00640064  | Global counter threshold register             |
| CRU GLB RST ST             | 0x0404 | W    | 0x00000000  | Global reset status register                  |
| CRU GLB SRST FST VAL<br>UE | 0x0408 | W    | 0x00000000  | Global software reset first value register    |
| CRU GLB SRST SND VA<br>LUE | 0x040C | W    | 0x00000000  | Global software reset second value register   |
| CRU GLB RST CON            | 0x0410 | W    | 0x00000000  | Global reset control register                 |
| CRU SDMMC CON0             | 0x0440 | W    | 0x00000004  | SDMMC clock control register 0                |
| CRU SDMMC CON1             | 0x0444 | W    | 0x00000004  | SDMMC clock control register 1                |
| CRU SDIO CON0              | 0x0448 | W    | 0x00000004  | SDIO clock control register 0                 |
| CRU SDIO CON1              | 0x044C | W    | 0x00000004  | SDIO clock control register 1                 |
| CRU EMMC CON0              | 0x0450 | W    | 0x00000004  | EMMC clock control register 0                 |
| CRU EMMC CON1              | 0x0454 | W    | 0x00000004  | EMMC clock control register 1                 |
| CRU GMAC CON               | 0x0460 | W    | 0x00000000  | GMAC clock control register                   |
| CRU MISC CON0              | 0x0464 | W    | 0x00000000  | Miscellaneous control register 0              |
| CRU MISC CON1              | 0x0468 | W    | 0x00000000  | Miscellaneous control register 1              |

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

## 5.5.2 Detail Register 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   | 0x2         | postdiv1<br>First post divide value. Valid settings are [1-7].                                                                                          |
| 11:0  | RW   | 0x0fa       | 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 APLL CON1**

Address: Operational Base + offset (0x0004)

| 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         | 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/fbdv/fracdiv is changed or pllpd0 is asserted. |
| 14    | RW   | 0x0         | pllpd1<br>PLL global power down request 1.<br>1'b0: No power down<br>1'b1: Power down                                                                                                                         |
| 13    | RW   | 0x0         | pllpd0<br>PLL global power down request 0.<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. Valid settings are [1-7].                                                                                                                                               |
| 5:0   | RW   | 0x03        | refdiv<br>Reference clock divide value, Valid settings are [1-63].                                                                                                                                            |

**CRU APLL CON2**

Address: Operational Base + offset (0x0008)

| Bit   | Attr | Reset Value | Description                                                                                                       |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------|
| 31:28 | RO   | 0x0         | reserved                                                                                                          |
| 27    | RW   | 0x0         | fout4phasepd<br>Power down 4-phase 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, fraction = fracdiv/2^24. |

**CRU APLL 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>Select 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 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. Valid settings are [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 APLL 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 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:4       | RW          | 0x000              | offsetcal_in<br>offsetcal_byp=1'b0: Initial condition for offset calibration logic.<br>offsetcal_byp=1'b1: Override value for offset calibration. It is a signed integer with positive values delaying the reset of the faster path, and negative values delaying the reset of the slower path. 5'b0 is the minimum value, with each count increasing the reset time by one buffer delay.<br>If offsetcal_en=1, this can be used to force a offset correction value based on a previous readout of offsetcal_out[11:0]. If offsetcal_byp=1 this value is forced directly into the calibration logic. If offsetcal_byp=0 this is the initial condition for the calibration sequence. |
| 3          | RW          | 0x0                | offsetcal_fast<br>Offset fast calibration enable.<br>Set this to 1 for initial calibration if an initial value is not already known.<br>Should be set to 0 for normal operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2          | RW          | 0x0                | offsetcal_en<br>Offset calibration enable to actively adjust for input offset.<br>1'b0: Offset calibration is disabled. Static phase offset is determined by analog matching only.<br>1'b1: Offset calibration is enabled. Static phase offset is adjusted by sensing phase at the input.                                                                                                                                                                                                                                                                                                                                                                                           |
| 1          | RW          | 0x0                | offsetcal_byp<br>Offset calibration bypass.<br>1'b0: Use the offset calibration output(when offsetcal_en=1) to set the phase correction<br>1'b1: Use the offsetcal_in[11:0] value (when offsetcal_en=1) to set the phase correction                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RW          | 0x0                | fout2xdp<br>Power down 2X clocks.<br>1'b0: No power down<br>1'b1: Power down                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**CRU APPL CON6**

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 16 bits, 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                | offsetcal_cnt<br>Programmable counter for offset calibration loop.<br>Selects the number of PFD edges to wait after each offset calibration step. Count is defined as $2^{(\text{offsetcal\_cnt}+4)}$ . |

**CRU DPLL 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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. Valid settings are [1-7].                                                                                          |
| 11:0       | RW          | 0x215              | 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 (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                | 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/fbdv/fracdiv is changed or pllpd0 is asserted. |
| 14         | RW          | 0x0                | pllpd1<br>PLL global power down request 1.<br>1'b0: No power down<br>1'b1: Power down                                                                                                                         |
| 13         | RW          | 0x0                | pllpd0<br>PLL global power down request 0.<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. Valid settings are [1-7].                                                                                                                                               |
| 5:0        | RW          | 0x04               | refdiv<br>Reference clock divide value, Valid settings are [1-63].                                                                                                                                            |

**CRU\_DPLL\_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.<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, fraction = fracdiv/2^24.                                           |

**CRU DPLL 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>Select 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 DPLL 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. Valid settings are [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\_DPLL\_CON5**

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:4       | RW          | 0x000              | offsetcal_in<br>offsetcal_byp=1'b0: Initial condition for offset calibration logic.<br>offsetcal_byp=1'b1: Override value for offset calibration. It is a signed integer with positive values delaying the reset of the faster path, and negative values delaying the reset of the slower path.<br>5'b0 is the minimum value, with each count increasing the reset time by one buffer delay.<br>If offsetcal_en=1, this can be used to force a offset correction value based on a previous readout of offsetcal_out[11:0]. If offsetcal_byp=1 this value is forced directly into the calibration logic. If offsetcal_byp=0 this is the initial condition for the calibration sequence. |
| 3          | RW          | 0x0                | offsetcal_fast<br>Offset fast calibration enable.<br>Set this to 1 for initial calibration if an initial value is not already known.<br>Should be set to 0 for normal operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2          | RW          | 0x0                | offsetcal_en<br>Offset calibration enable to actively adjust for input offset.<br>1'b0: Offset calibration is disabled. Static phase offset is determined by analog matching only.<br>1'b1: Offset calibration is enabled. Static phase offset is adjusted by sensing phase at the input.                                                                                                                                                                                                                                                                                                                                                                                              |
| 1          | RW          | 0x0                | offsetcal_byp<br>Offset calibration bypass.<br>1'b0: Use the offset calibration output(when offsetcal_en=1) to set the phase correction<br>1'b1: Use the offsetcal_in[11:0] value (when offsetcal_en=1) to set the phase correction                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0          | RW          | 0x0                | fout2xpd<br>Power down 2X clocks.<br>1'b0: No power down<br>1'b1: Power down                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**CRU\_DPLL\_CON6**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:3       | RO          | 0x0000             | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0        | RW          | 0x0                | offsetcal_cnt<br>Programmable counter for offset calibration loop.<br>Selects the number of PFD edges to wait after each offset calibration step. Count is defined as $2^{(\text{offsetcal\_cnt}+4)}$ . |

**CRU CPLL 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          | 0x2                | postdiv1<br>First post divide value. Valid settings are [1-7].                                                                                          |
| 11:0       | RW          | 0x0fa              | 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 (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                                                                            |
| 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/fbdv/fracdiv is changed or pllpd0 is asserted. |
| 14         | RW          | 0x0                | pllpd1<br>PLL global power down request 1.<br>1'b0: No power down<br>1'b1: Power down                                                                                                                         |
| 13         | RW          | 0x0                | pllpd0<br>PLL global power down request 0.<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                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 8:6        | RW          | 0x2                | postdiv2<br>Second post divide value. Valid settings are [1-7].    |
| 5:0        | RW          | 0x03               | refdiv<br>Reference clock divide value, Valid settings are [1-63]. |

**CRU CPLL 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.<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, fraction = fracdiv/2^24.                                           |

**CRU CPLL 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>Select 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                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 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 (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. Valid settings are [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 CON5**

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:4       | RW          | 0x000              | offsetcal_in<br>offsetcal_byp=1'b0: Initial condition for offset calibration logic.<br>offsetcal_byp=1'b1: Override value for offset calibration. It is a signed integer with positive values delaying the reset of the faster path, and negative values delaying the reset of the slower path. 5'b0 is the minimum value, with each count increasing the reset time by one buffer delay.<br>If offsetcal_en=1, this can be used to force a offset correction value based on a previous readout of offsetcal_out[11:0]. If offsetcal_byp=1 this value is forced directly into the calibration logic. If offsetcal_byp=0 this is the initial condition for the calibration sequence. |
| 3          | RW          | 0x0                | offsetcal_fast<br>Offset fast calibration enable.<br>Set this to 1 for initial calibration if an initial value is not already known.<br>Should be set to 0 for normal operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2          | RW          | 0x0                | offsetcal_en<br>Offset calibration enable to actively adjust for input offset.<br>1'b0: Offset calibration is disabled. Static phase offset is determined by analog matching only.<br>1'b1: Offset calibration is enabled. Static phase offset is adjusted by sensing phase at the input.                                                                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | offsetcal_byp<br>Offset calibration bypass.<br>1'b0: Use the offset calibration output(when offsetcal_en=1) to set the phase correction<br>1'b1: Use the offsetcal_in[11:0] value (when offsetcal_en=1) to set the phase correction |
| 0          | RW          | 0x0                | fout2xdp<br>Power down 2X clocks.<br>1'b0: No power down<br>1'b1: Power down                                                                                                                                                        |

**CRU CPLL CON6**

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:3       | RO          | 0x0000             | reserved                                                                                                                                                                                                |
| 2:0        | RW          | 0x0                | offsetcal_cnt<br>Programmable counter for offset calibration loop.<br>Selects the number of PFD edges to wait after each offset calibration step. Count is defined as $2^{(\text{offsetcal\_cnt}+4)}$ . |

**CRU HPLL 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          | 0x2                | postdiv1<br>First post divide value. Valid settings are [1-7].                                                                                          |
| 11:0       | RW          | 0x145              | 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 HPLL 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                | 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. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | pllpd1<br>PLL global power down request 1.<br>1'b0: No power down<br>1'b1: Power down                  |
| 13         | RW          | 0x0                | pllpd0<br>PLL global power down request 0.<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. Valid settings are [1-7].                                        |
| 5:0        | RW          | 0x03               | refdiv<br>Reference clock divide value, Valid settings are [1-63].                                     |

**CRU HPLL 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.<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, fraction = fracdiv/2^24.                                           |

**CRU HPLL 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                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 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>Select 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 HPLL 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. Valid settings are [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 HPLL CON5**

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 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:4       | RW          | 0x000              | offsetcal_in<br>offsetcal_byp=1'b0: Initial condition for offset calibration logic.<br>offsetcal_byp=1'b1: Override value for offset calibration. It is a signed integer with positive values delaying the reset of the faster path, and negative values delaying the reset of the slower path. 5'b0 is the minimum value, with each count increasing the reset time by one buffer delay.<br>If offsetcal_en=1, this can be used to force a offset correction value based on a previous readout of offsetcal_out[11:0]. If offsetcal_byp=1 this value is forced directly into the calibration logic. If offsetcal_byp=0 this is the initial condition for the calibration sequence. |
| 3          | RW          | 0x0                | offsetcal_fast<br>Offset fast calibration enable.<br>Set this to 1 for initial calibration if an initial value is not already known.<br>Should be set to 0 for normal operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2          | RW          | 0x0                | offsetcal_en<br>Offset calibration enable to actively adjust for input offset.<br>1'b0: Offset calibration is disabled. Static phase offset is determined by analog matching only.<br>1'b1: Offset calibration is enabled. Static phase offset is adjusted by sensing phase at the input.                                                                                                                                                                                                                                                                                                                                                                                           |
| 1          | RW          | 0x0                | offsetcal_byp<br>Offset calibration bypass.<br>1'b0: Use the offset calibration output(when offsetcal_en=1) to set the phase correction<br>1'b1: Use the offsetcal_in[11:0] value (when offsetcal_en=1) to set the phase correction                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RW          | 0x0                | fout2xdp<br>Power down 2X clocks.<br>1'b0: No power down<br>1'b1: Power down                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**CRU HPLL CON6**

Address: Operational Base + offset (0x0078)

| <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:0        | RW          | 0x0                | offsetcal_cnt<br>Programmable counter for offset calibration loop.<br>Selects the number of PFD edges to wait after each offset calibration step. Count is defined as $2^{(\text{offsetcal\_cnt}+4)}$ . |

**CRU APPL OFFSETCAL STATUS**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                |
| 16         | RW          | 0x0                | offsetcal_lock<br>Asserted when phase lock is achieved when offsetcal_en is set to 1'b1 |
| 15:12      | RO          | 0x0                | reserved                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0       | RW          | 0x000              | <p>offsetcal_out</p> <p>This is the output of either the offset calibration block (if offsetcal_byp=0) or a buffered version of offsetcal_in[11:0] (if offsetcal_byp=1).</p> <p>It can be used to read out the phase calibration state to use as an override value so that offset calibration can be bypassed for faster locking. The value changes on the rising edge of FREF, so it can be clocked out on the falling edge of FREF</p> |

**CRU DPLL OFFSETCAL STATUS**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 16         | RW          | 0x0                | <p>offsetcal_lock</p> <p>Asserted when phase lock is achieved when offsetcal_en is set to 1'b1</p>                                                                                                                                                                                                                                                                                                                                       |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11:0       | RW          | 0x000              | <p>offsetcal_out</p> <p>This is the output of either the offset calibration block (if offsetcal_byp=0) or a buffered version of offsetcal_in[11:0] (if offsetcal_byp=1).</p> <p>It can be used to read out the phase calibration state to use as an override value so that offset calibration can be bypassed for faster locking. The value changes on the rising edge of FREF, so it can be clocked out on the falling edge of FREF</p> |

**CRU CPLL OFFSETCAL STATUS**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 16         | RW          | 0x0                | <p>offsetcal_lock</p> <p>Asserted when phase lock is achieved when offsetcal_en is set to 1'b1</p>                                                                                                                                                                                                                                                                                                                                       |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11:0       | RW          | 0x000              | <p>offsetcal_out</p> <p>This is the output of either the offset calibration block (if offsetcal_byp=0) or a buffered version of offsetcal_in[11:0] (if offsetcal_byp=1).</p> <p>It can be used to read out the phase calibration state to use as an override value so that offset calibration can be bypassed for faster locking. The value changes on the rising edge of FREF, so it can be clocked out on the falling edge of FREF</p> |

**CRU HPLL OFFSETCAL STATUS**

Address: Operational Base + offset (0x008C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                           |
| 16         | RW          | 0x0                | <p>offsetcal_lock</p> <p>Asserted when phase lock is achieved when offsetcal_en is set to 1'b1</p> |
| 15:12      | RO          | 0x0                | reserved                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0       | RW          | 0x000              | offsetcal_out<br>This is the output of either the offset calibration block (if offsetcal_byp=0) or a buffered version of offsetcal_in[11:0] (if offsetcal_byp=1).<br>It can be used to read out the phase calibration state to use as an override value so that offset calibration can be bypassed for faster locking. The value changes on the rising edge of FREF, so it can be clocked out on the falling edge of FREF |

**CRU MODE CON01**

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:12      | RO          | 0x0                | reserved                                                                                                                                               |
| 11:10      | RW          | 0x0                | usbphy_clk480m_muxpll_mode<br>usbphy_clk480m_mux clock mux.<br>2'b00: xin_osc0_div<br>2'b01: usbphy_clk480m<br>2'b10: clk_deepslow<br>Others: Reserved |
| 9:8        | RO          | 0x0                | reserved                                                                                                                                               |
| 7:6        | RW          | 0x0                | clk_hpll_mode<br>clk_hpll_mux clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_hpll<br>2'b10: clk_deepslow<br>Others: Reserved                         |
| 5:4        | 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<br>Others: Reserved                         |
| 3:2        | 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<br>Others: Reserved                         |
| 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<br>Others: Reserved                         |

**CRU CLKSEL CON00**

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:13      | RO          | 0x0                | reserved                                                                                                                             |
| 12:8       | RW          | 0x05               | hclk_pdcore_biu_div<br>Divide hclk_pdcore_biu by (div_con + 1)                                                                       |
| 7:6        | RW          | 0x2                | clk_core_pre_sel<br>clk_core_pre clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: clk_apll_mux<br>Others: Reserved |
| 5          | RO          | 0x0                | reserved                                                                                                                             |
| 4:0        | RW          | 0x00               | clk_core_pre_div<br>Divide clk_core_pre by (div_con + 1)                                                                             |

**CRU CLKSEL CON01**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7:4        | RW          | 0x1                | ackl_core_pre_div<br>Divide ackl_core_pre by (div_con + 1)                                                                         |
| 3          | RO          | 0x0                | reserved                                                                                                                           |
| 2:0        | RW          | 0x3                | pclk_dbg_pre_div<br>Divide pclk_dbg_pre by (div_con + 1)                                                                           |

**CRU CLKSEL CON02**

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         | RW          | 0x0                | hclk_pdbus_pre_sel<br>hclk_pdbus_pre clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                              |
| 14:13      | RO          | 0x0                | reserved                                                                                                                                 |
| 12:8       | RW          | 0x05               | hclk_pdbus_pre_div<br>Divide hclk_pdbus_pre by (div_con + 1)                                                                             |
| 7:6        | RW          | 0x2                | ackl_pdbus_pre_sel<br>ackl_pdbus_pre clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: clk_dpll_mux<br>Others: Reserved |
| 5          | RO          | 0x0                | reserved                                                                                                                                 |
| 4:0        | RW          | 0x03               | ackl_pdbus_pre_div<br>Divide ackl_pdbus_pre by (div_con + 1)                                                                             |

**CRU CLKSEL CON03**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_mcu_sel<br>clk_mcu clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                                      |
| 14:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12:8       | RW          | 0x05               | clk_mcu_div<br>Divide clk_mcu by (div_con + 1)                                                                                     |
| 7          | RW          | 0x0                | pclk_pdbus_pre_sel<br>pclk_pdbus_pre clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                        |
| 6:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x0b               | pclk_pdbus_pre_div<br>Divide pclk_pdbus_pre by (div_con + 1)                                                                       |

**CRU CLKSEL CON04**

Address: Operational Base + offset (0x0110)

| <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          | 0x01               | hclk_pdcrypt_div<br>Divide hclk_pdcrypt by (div_con + 1)                                                                           |
| 7          | RW          | 0x0                | ackl_pdcrypt_sel<br>ackl_pdcrypt clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                            |
| 6:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x03               | ackl_pdcrypt_div<br>Divide ackl_pdcrypt by (div_con + 1)                                                                           |

**CRU CLKSEL CON05**

Address: Operational Base + offset (0x0114)

| <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:8       | RW          | 0x0b               | clk_i2c3_div<br>Divide clk_i2c3 by (div_con + 1)                                                                                   |
| 7          | RO          | 0x0                | reserved                                                                                                                           |
| 6:0        | RW          | 0x0b               | clk_i2c1_div<br>Divide clk_i2c1 by (div_con + 1)                                                                                   |

**CRU CLKSEL CON06**

Address: Operational Base + offset (0x0118)

| <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:8       | RW          | 0x0b               | clk_i2c5_div<br>Divide clk_i2c5 by (div_con + 1)                                                                                   |
| 7          | RO          | 0x0                | reserved                                                                                                                           |
| 6:0        | RW          | 0x0b               | clk_i2c4_div<br>Divide clk_i2c4 by (div_con + 1)                                                                                   |

**CRU CLKSEL CON07**

Address: Operational Base + offset (0x011C)

| <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_crypto_pka_sel<br>clk_crypto_pka clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                        |
| 14:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12:8       | RW          | 0x03               | clk_crypto_pka_div<br>Divide clk_crypto_pka by (div_con + 1)                                                                       |
| 7          | RW          | 0x0                | clk_crypto_core_sel<br>clk_crypto_core clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                      |
| 6:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x05               | clk_crypto_core_div<br>Divide clk_crypto_core by (div_con + 1)                                                                     |

**CRU CLKSEL CON08**

Address: Operational Base + offset (0x0120)

| <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_spi1_sel<br>clk_spi1 clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: xin_osc0_func                                                   |
| 6:0        | RW          | 0x0b               | clk_spi1_div<br>Divide clk_spi1 by (div_con + 1)                                                                                   |

**CRU CLKSEL CON09**

Address: Operational Base + offset (0x0124)

| <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                | clk_pwm2_sel<br>clk_pwm2 clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_gpll_mux |
| 14:8       | RW          | 0x00               | clk_pwm2_div<br>Divide clk_pwm2 by (div_con + 1)                                 |
| 7:0        | RO          | 0x00               | reserved                                                                         |

**CRU CLKSEL CON10**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable                 |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                           |
| 11:10      | RW          | 0x2                | sclk_uart0_sel<br>sclk_uart0 clock mux.<br>2'b00: sclk_uart0_div<br>2'b01: sclk_uart0_frac<br>2'b10: xin_osc0_func<br>Others: Reserved             |
| 9:8        | RW          | 0x0                | sclk_uart0_div_sel<br>sclk_uart0_div clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: usbphy_clk480m_mux<br>2'b11: xin_osc0_func |
| 7          | RO          | 0x0                | reserved                                                                                                                                           |
| 6:0        | RW          | 0x00               | sclk_uart0_div_div<br>Divide sclk_uart0_div by (div_con + 1)                                                                                       |

**CRU CLKSEL CON11**

Address: Operational Base + offset (0x012C)

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

**CRU CLKSEL CON12**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable     |
| 15:12      | RO          | 0x0                | reserved                                                                                                                               |
| 11:10      | RW          | 0x2                | sclk_uart2_sel<br>sclk_uart2 clock mux.<br>2'b00: sclk_uart2_div<br>2'b01: sclk_uart2_frac<br>2'b10: xin_osc0_func<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x0                | sclk_uart2_div_sel<br>sclk_uart2_div clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: usbphy_clk480m_mux<br>2'b11: xin_osc0_func |
| 7          | RO          | 0x0                | reserved                                                                                                                                           |
| 6:0        | RW          | 0x00               | sclk_uart2_div_div<br>Divide sclk_uart2_div by (div_con + 1)                                                                                       |

**CRU CLKSEL CON13**

Address: Operational Base + offset (0x0134)

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

**CRU CLKSEL CON14**

Address: Operational Base + offset (0x0138)

| <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:10      | RW          | 0x2                | sclk_uart3_sel<br>sclk_uart3 clock mux.<br>2'b00: sclk_uart3_div<br>2'b01: sclk_uart3_frac<br>2'b10: xin_osc0_func<br>Others: Reserved             |
| 9:8        | RW          | 0x0                | sclk_uart3_div_sel<br>sclk_uart3_div clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: usbphy_clk480m_mux<br>2'b11: xin_osc0_func |
| 7          | RO          | 0x0                | reserved                                                                                                                                           |
| 6:0        | RW          | 0x00               | sclk_uart3_div_div<br>Divide sclk_uart3_div by (div_con + 1)                                                                                       |

**CRU CLKSEL CON15**

Address: Operational Base + offset (0x013C)

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

**CRU CLKSEL CON16**

Address: Operational Base + offset (0x0140)

| <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:10      | RW          | 0x2                | sclk_uart4_sel<br>sclk_uart4 clock mux.<br>2'b00: sclk_uart4_div<br>2'b01: sclk_uart4_frac<br>2'b10: xin_osc0_func<br>Others: Reserved             |
| 9:8        | RW          | 0x0                | sclk_uart4_div_sel<br>sclk_uart4_div clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: usbphy_clk480m_mux<br>2'b11: xin_osc0_func |
| 7          | RO          | 0x0                | reserved                                                                                                                                           |
| 6:0        | RW          | 0x00               | sclk_uart4_div_div<br>Divide sclk_uart4_div by (div_con + 1)                                                                                       |

**CRU CLKSEL CON17**

Address: Operational Base + offset (0x0144)

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

**CRU CLKSEL CON18**

Address: Operational Base + offset (0x0148)

| <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:10      | RW          | 0x2                | sclk_uart5_sel<br>sclk_uart5 clock mux.<br>2'b00: sclk_uart5_div<br>2'b01: sclk_uart5_frac<br>2'b10: xin_osc0_func<br>Others: Reserved             |
| 9:8        | RW          | 0x0                | sclk_uart5_div_sel<br>sclk_uart5_div clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: usbphy_clk480m_mux<br>2'b11: xin_osc0_func |
| 7          | RO          | 0x0                | reserved                                                                                                                                           |
| 6:0        | RW          | 0x00               | sclk_uart5_div_div<br>Divide sclk_uart5_div by (div_con + 1)                                                                                       |

**CRU CLKSEL CON19**

Address: Operational Base + offset (0x014C)

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

**CRU CLKSEL CON20**

Address: Operational Base + offset (0x0150)

| <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      | RO          | 0x00               | reserved                                                                                                                           |
| 10:0       | RW          | 0x001              | clk_saradc_ndft_div<br>Divide clk_saradc_ndft by (div_con + 1)                                                                     |

**CRU CLKSEL CON21**

Address: Operational Base + offset (0x0154)

| <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                | dbclk_gpio1_sel<br>dbclk_gpio1 clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_deepslow                                             |
| 14:0       | RO          | 0x0000             | reserved                                                                                                                           |

**CRU CLKSEL CON22**

Address: Operational Base + offset (0x0158)

| <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                | dbclk_gpio2_sel<br>dbclk_gpio2 clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_deepslow                                             |
| 14:0       | RO          | 0x0000             | reserved                                                                                                                           |

**CRU CLKSEL CON23**

Address: Operational Base + offset (0x015C)

| <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                | dbclk_gpio3_sel<br>dbclk_gpio3 clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_deepslow                                             |
| 14:0       | RO          | 0x0000             | reserved                                                                                                                           |

**CRU CLKSEL CON24**

Address: Operational Base + offset (0x0160)

| 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_gpio4_sel<br>dbclk_gpio4 clock mux.<br>1'b0: xin_osc0_func<br>1'b1: clk_deepslow                                             |
| 14:0  | RO   | 0x0000      | reserved                                                                                                                           |

**CRU CLKSEL CON25**

Address: Operational Base + offset (0x0164)

| 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         | dclk_decom_sel<br>dclk_decom clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                                |
| 14:8  | RW   | 0x03        | dclk_decom_div<br>Divide dclk_decom by (div_con + 1)                                                                               |
| 7     | RW   | 0x0         | clk_can_sel<br>clk_can clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: xin_osc0_func                                                     |
| 6:0   | RW   | 0x05        | clk_can_div<br>Divide clk_can by (div_con + 1)                                                                                     |

**CRU CLKSEL CON26**

Address: Operational Base + offset (0x0168)

| 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:0   | RW   | 0x07        | hclk_pdaudio_div<br>Divide hclk_pdaudio by (div_con + 1)                                                                           |

**CRU CLKSEL CON27**

Address: Operational Base + offset (0x016C)

| 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         | mclk_i2s0_rx_div_sel<br>mclk_i2s0_rx_div clock mux.<br>1'b0: clk_cpll_mux<br>1'b1: clk_gpll_mux                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 14:8       | RW          | 0x0b               | mclk_i2s0_rx_div_div<br>Divide mclk_i2s0_rx_div by (div_con + 1)                                |
| 7          | RW          | 0x0                | mclk_i2s0_tx_div_sel<br>mclk_i2s0_tx_div clock mux.<br>1'b0: clk_cpll_mux<br>1'b1: clk_gpll_mux |
| 6:0        | RW          | 0x0b               | mclk_i2s0_tx_div_div<br>Divide mclk_i2s0_tx_div by (div_con + 1)                                |

**CRU CLKSEL CON28**

Address: Operational Base + offset (0x0170)

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

**CRU CLKSEL CON29**

Address: Operational Base + offset (0x0174)

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

**CRU CLKSEL CON30**

Address: Operational Base + offset (0x0178)

| <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          | RW          | 0x1                | mclk_i2s0_rx_out2io_sel<br>mclk_i2s0_rx_out2io clock mux.<br>1'b0: mclk_i2s0_rx<br>1'b1: xin_osc0_half                                              |
| 7          | RO          | 0x0                | reserved                                                                                                                                            |
| 6          | RW          | 0x1                | mclk_i2s0_tx_out2io_sel<br>mclk_i2s0_tx_out2io clock mux.<br>1'b0: mclk_i2s0_tx<br>1'b1: xin_osc0_half                                              |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                            |
| 3:2        | RW          | 0x3                | mclk_i2s0_rx_sel<br>mclk_i2s0_rx clock mux.<br>2'b00: mclk_i2s0_rx_div<br>2'b01: mclk_i2s0_rx_fracdiv<br>2'b10: i2s0_mclkin<br>2'b11: xin_osc0_half |
| 1:0        | RW          | 0x3                | mclk_i2s0_tx_sel<br>mclk_i2s0_tx clock mux.<br>2'b00: mclk_i2s0_tx_div<br>2'b01: mclk_i2s0_tx_fracdiv<br>2'b10: i2s0_mclkin<br>2'b11: xin_osc0_half |

**CRU CLKSEL CON31**

Address: Operational Base + offset (0x017C)

| 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   | 0x1         | mclk_i2s1_out2io_sel<br>mclk_i2s1_out2io clock mux.<br>1'b0: mclk_i2s1<br>1'b1: xin_osc0_half                                                                                                   |
| 11    | RO   | 0x0         | reserved                                                                                                                                                                                        |
| 10:8  | RW   | 0x3         | mclk_i2s1_sel<br>mclk_i2s1 clock mux.<br>3'b000: mclk_i2s1_div<br>3'b001: mclk_i2s1_fracdiv<br>3'b010: i2s1_mclkin<br>3'b011: xin_osc0_half<br>3'b100: mclk_i2s1_fracdiv_v2<br>Others: Reserved |
| 7     | RW   | 0x0         | mclk_i2s1_div_sel<br>mclk_i2s1_div clock mux.<br>1'b0: clk_cpll_mux<br>1'b1: clk_gpll_mux                                                                                                       |
| 6:0   | RW   | 0x05        | mclk_i2s1_div_div<br>Divide mclk_i2s1_div by (div_con + 1)                                                                                                                                      |

**CRU CLKSEL CON32**

Address: Operational Base + offset (0x0180)

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

**CRU CLKSEL CON33**

Address: Operational Base + offset (0x0184)

| 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   | 0x1         | mclk_i2s2_out2io_sel<br>mclk_i2s2_out2io clock mux.<br>1'b0: mclk_i2s2<br>1'b1: xin_osc0_half                                           |
| 9:8   | RW   | 0x3         | mclk_i2s2_sel<br>mclk_i2s2_clock mux.<br>2'b00: mclk_i2s2_div<br>2'b01: mclk_i2s2_fracdiv<br>2'b10: i2s2_mclkin<br>2'b11: xin_osc0_half |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | mclk_i2s2_div_sel<br>mclk_i2s2_div clock mux.<br>1'b0: clk_cpll_mux<br>1'b1: clk_gpll_mux |
| 6:0        | RW          | 0x0b               | mclk_i2s2_div_div<br>Divide mclk_i2s2_div by (div_con + 1)                                |

**CRU CLKSEL CON34**

Address: Operational Base + offset (0x0188)

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

**CRU CLKSEL CON35**

Address: Operational Base + offset (0x018C)

| <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                | mclk_pdm_sel<br>mclk_pdm clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: xin_osc0_func<br>Others: Reserved      |
| 7          | RO          | 0x0                | reserved                                                                                                                           |
| 6:0        | RW          | 0x03               | mclk_pdm_div<br>Divide mclk_pdm by (div_con + 1)                                                                                   |

**CRU CLKSEL CON36**

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 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                | sclk_aud pwm_sel<br>sclk_aud pwm clock mux.<br>2'b00: sclk_aud pwm_div<br>2'b01: sclk_aud pwm_fracdiv<br>2'b10: xin_osc0_func<br>Others: Reserved |
| 7          | RW          | 0x0                | sclk_aud pwm_div_sel<br>sclk_aud pwm_div clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                                   |
| 6:0        | RW          | 0x0b               | sclk_aud pwm_div_div<br>Divide sclk_aud pwm_div by (div_con + 1)                                                                                  |

**CRU CLKSEL CON37**

Address: Operational Base + offset (0x0194)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sclk_aud pwm fracdiv div<br>sclk_aud pwm fracdiv fraction division register.<br>High 16-bit for numerator<br>Low 16-bit for denominator |

**CRU CLKSEL CON38**

Address: Operational Base + offset (0x0198)

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

**CRU CLKSEL CON40**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable     |
| 15:14      | RW          | 0x0                | clk_venc_core_sel<br>clk_venc_core clock mux.<br>2'b00: clk_cpll_mux<br>2'b01: clk_gpll_mux<br>2'b10: clk_hpll_mux<br>Others: Reserved |
| 13         | RO          | 0x0                | reserved                                                                                                                               |
| 12:8       | RW          | 0x01               | clk_venc_core_div<br>Divide clk_venc_core by (div_con + 1)                                                                             |
| 7:6        | RW          | 0x2                | ackl_pdvepu_sel<br>ackl_pdvepu clock mux.<br>2'b00: clk_cpll_mux<br>2'b01: clk_hpll_mux<br>2'b10: clk_gpll_mux<br>Others: Reserved     |
| 5          | RO          | 0x0                | reserved                                                                                                                               |
| 4:0        | RW          | 0x02               | ackl_pdvepu_div<br>Divide ackl_pdvepu by (div_con + 1)                                                                                 |

**CRU CLKSEL CON41**

Address: Operational Base + offset (0x01A4)

| <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          | 0x01               | hclk_pdvdec_div<br>Divide hclk_pdvdec by (div_con + 1)                                                                             |
| 7:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x01               | hclk_pdvepu_div<br>Divide hclk_pdvepu by (div_con + 1)                                                                             |

**CRU CLKSEL CON42**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable     |
| 15:14      | RW          | 0x2                | clk_vdec_core_sel<br>clk_vdec_core clock mux.<br>2'b00: clk_cpll_mux<br>2'b01: clk_hpll_mux<br>2'b10: clk_gpll_mux<br>Others: Reserved |
| 13         | RO          | 0x0                | reserved                                                                                                                               |
| 12:8       | RW          | 0x03               | clk_vdec_core_div<br>Divide clk_vdec_core by (div_con + 1)                                                                             |
| 7:6        | RW          | 0x2                | ackl_pdvdec_sel<br>ackl_pdvdec clock mux.<br>2'b00: clk_cpll_mux<br>2'b01: clk_hpll_mux<br>2'b10: clk_gpll_mux<br>Others: Reserved     |
| 5          | RO          | 0x0                | reserved                                                                                                                               |
| 4:0        | RW          | 0x02               | ackl_pdvdec_div<br>Divide ackl_pdvdec by (div_con + 1)                                                                                 |

**CRU CLKSEL CON43**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable           |
| 15:14      | RW          | 0x2                | clk_vdec_hevc_ca_sel<br>clk_vdec_hevc_ca clock mux.<br>2'b00: clk_cpll_mux<br>2'b01: clk_hpll_mux<br>2'b10: clk_gpll_mux<br>Others: Reserved |
| 13         | RO          | 0x0                | reserved                                                                                                                                     |
| 12:8       | RW          | 0x01               | clk_vdec_hevc_ca_div<br>Divide clk_vdec_hevc_ca by (div_con + 1)                                                                             |
| 7:6        | RW          | 0x2                | clk_vdec_ca_sel<br>clk_vdec_ca clock mux.<br>2'b00: clk_cpll_mux<br>2'b01: clk_hpll_mux<br>2'b10: clk_gpll_mux<br>Others: Reserved           |
| 5          | RO          | 0x0                | reserved                                                                                                                                     |
| 4:0        | RW          | 0x03               | clk_vdec_ca_div<br>Divide clk_vdec_ca by (div_con + 1)                                                                                       |

**CRU CLKSEL CON44**

Address: Operational Base + offset (0x01B0)

| <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          | 0x01               | hclk_pdjpeg_div<br>Divide hclk_pdjpeg by (div_con + 1)                                                                             |
| 7:6        | RW          | 0x2                | ackl_pdjpeg_sel<br>ackl_pdjpeg clock mux.<br>2'b00: clk_cpll_mux<br>2'b01: clk_hpll_mux<br>2'b10: clk_gpll_mux<br>Others: Reserved |
| 5          | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x03               | ackl_pdjpeg_div<br>Divide ackl_pdjpeg by (div_con + 1)                                                                             |

**CRU CLKSEL CON45**

Address: Operational Base + offset (0x01B4)

| <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          | 0x01               | hclk_pdvo_div<br>Divide hclk_pdvo by (div_con + 1)                                                                                 |
| 7          | RW          | 0x0                | ackl_pdvo_sel<br>ackl_pdvo clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                                  |
| 6:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x03               | ackl_pdvo_div<br>Divide ackl_pdvo by (div_con + 1)                                                                                 |

**CRU CLKSEL CON46**

Address: Operational Base + offset (0x01B8)

| <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          | 0x01               | pclk_pdvo_div<br>Divide pclk_pdvo by (div_con + 1)                                                                                 |
| 7          | RW          | 0x0                | clk_rga_core_sel<br>clk_rga_core clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                            |
| 6:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x02               | clk_rga_core_div<br>Divide clk_rga_core by (div_con + 1)                                                                           |

**CRU CLKSEL CON47**

Address: Operational Base + offset (0x01BC)

| <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:10      | RW          | 0x0                | dclk_vop_sel<br>dclk_vop clock mux.<br>2'b00: dclk_vop_div<br>2'b01: dclk_vop_fracdiv<br>2'b10: xin_osc0_func<br>Others: Reserved  |
| 9          | RO          | 0x0                | reserved                                                                                                                           |
| 8          | RW          | 0x0                | dclk_vop_div_sel<br>dclk_vop_div clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                            |
| 7:0        | RW          | 0x07               | dclk_vop_div_div<br>Divide dclk_vop_div by (div_con + 1)                                                                           |

**CRU CLKSEL CON48**

Address: Operational Base + offset (0x01C0)

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

**CRU CLKSEL CON49**

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 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          | 0x01               | hclk_pdvi_div<br>Divide hclk_pdvi by (div_con + 1)                                                                                     |
| 7:6        | RW          | 0x0                | ackl_pdvi_div_sel<br>ackl_pdvi_div clock mux.<br>2'b00: clk_cpll_mux<br>2'b01: clk_gpll_mux<br>2'b10: clk_hpll_mux<br>Others: Reserved |
| 5          | RO          | 0x0                | reserved                                                                                                                               |
| 4:0        | RW          | 0x01               | ackl_pdvi_div_div<br>Divide ackl_pdvi_div by (div_con + 1)                                                                             |

**CRU CLKSEL CON50**

Address: Operational Base + offset (0x01C8)

| <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:14      | RW          | 0x0                | clk_cif_out2io_sel<br>clk_cif_out2io clock mux.<br>2'b00: xin_osc0_func<br>2'b01: clk_cif_out2io_div<br>2'b10: clk_cif_out2io_fracdiv<br>Others: Reserved |
| 13         | RO          | 0x0                | reserved                                                                                                                                                  |
| 12:8       | RW          | 0x01               | pclk_pdvi_div<br>Divide pclk_pdvi by (div_con + 1)                                                                                                        |
| 7:6        | RW          | 0x0                | clk_isp_div_sel<br>clk_isp_div clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: clk_hpll_mux<br>Others: Reserved                        |
| 5          | RO          | 0x0                | reserved                                                                                                                                                  |
| 4:0        | RW          | 0x01               | clk_isp_div_div<br>Divide clk_isp_div by (div_con + 1)                                                                                                    |

**CRU CLKSEL CON51**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_cif_out2io_div_sel<br>clk_cif_out2io_div clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: usbphy_clk480m_mux                          |
| 14         | RO          | 0x0                | reserved                                                                                                                           |
| 13:8       | RW          | 0x07               | clk_cif_out2io_div_div<br>Divide clk_cif_out2io_div by (div_con + 1)                                                               |
| 7:6        | RW          | 0x1                | dclk_cif_sel<br>dclk_cif clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: clk_hpll_mux<br>Others: Reserved       |
| 5          | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x02               | dclk_cif_div<br>Divide dclk_cif by (div_con + 1)                                                                                   |

**CRU CLKSEL CON52**

Address: Operational Base + offset (0x01D0)

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

**CRU CLKSEL CON53**

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 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          | 0x05               | hclk_pdphp_div<br>Divide hclk_pdphp by (div_con + 1)                                                                               |
| 7          | RW          | 0x0                | ackl_pdphp_sel<br>ackl_pdphp clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                                |
| 6:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x03               | ackl_pdphp_div<br>Divide ackl_pdphp by (div_con + 1)                                                                               |

**CRU CLKSEL CON54**

Address: Operational Base + offset (0x01D8)

| <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          | 0x1                | dclk_ciflite_sel<br>dclk_ciflite clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: clk_hpll_mux<br>Others: Reserved |
| 13         | RO          | 0x0                | reserved                                                                                                                             |
| 12:8       | RW          | 0x02               | dclk_ciflite_div<br>Divide dclk_ciflite by (div_con + 1)                                                                             |
| 7          | RW          | 0x0                | clk_iep_core_sel<br>clk_iep_core clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                              |
| 6:5        | RO          | 0x0                | reserved                                                                                                                             |
| 4:0        | RW          | 0x03               | clk_iep_core_div<br>Divide clk_iep_core by (div_con + 1)                                                                             |

**CRU CLKSEL CON55**

Address: Operational Base + offset (0x01DC)

| <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                | cclkin_sdmmc_sel<br>cclkin_sdmmc clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: xin_osc0_func<br>Others: Reserved |
| 13:8       | RO          | 0x00               | reserved                                                                                                                              |
| 7:0        | RW          | 0x02               | cclkin_sdmmc_div<br>Divide cclkin_sdmmc by (div_con + 1)                                                                              |

**CRU CLKSEL CON56**

Address: Operational Base + offset (0x01E0)

| 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 | RW   | 0x0         | cclk_in_sdio_sel<br>cclk_in_sdio clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: xin_osc0_func<br>Others: Reserved |
| 13:8  | RO   | 0x00        | reserved                                                                                                                              |
| 7:0   | RW   | 0x02        | cclk_in_sdio_div<br>Divide cclk_in_sdio by (div_con + 1)                                                                              |

**CRU CLKSEL CON57**

Address: Operational Base + offset (0x01E4)

| 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 | RW   | 0x0         | cclk_in_emmc_sel<br>cclk_in_emmc clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: xin_osc0_func<br>Others: Reserved |
| 13:8  | RO   | 0x00        | reserved                                                                                                                              |
| 7:0   | RW   | 0x02        | cclk_in_emmc_div<br>Divide cclk_in_emmc by (div_con + 1)                                                                              |

**CRU CLKSEL CON58**

Address: Operational Base + offset (0x01E8)

| 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         | sclk_fspi_sel<br>sclk_fspi clock mux.<br>1'b0: clk_cpll_mux<br>1'b1: clk_gpll_mux                                                  |
| 14:8  | RO   | 0x00        | reserved                                                                                                                           |
| 7:0   | RW   | 0x05        | sclk_fspi_div<br>Divide sclk_fspi by (div_con + 1)                                                                                 |

**CRU CLKSEL CON59**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | nclk_nandc_sel<br>nclk_nandc clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: clk_cpll_mux                                                |
| 14:8       | RO          | 0x00               | reserved                                                                                                                           |
| 7:0        | RW          | 0x05               | nclk_nandc_div<br>Divide nclk_nandc by (div_con + 1)                                                                               |

**CRU CLKSEL CON61**

Address: Operational Base + offset (0x01F4)

| <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_gmac_ethernet_out2io_sel<br>clk_gmac_ethernet_out2io clock mux.<br>1'b0: clk_cpll_mux<br>1'b1: clk_gpll_mux                    |
| 14:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12:8       | RW          | 0x07               | clk_gmac_ethernet_out2io_div<br>Divide clk_gmac_ethernet_out2io by (div_con + 1)                                                   |
| 7          | RW          | 0x0                | clk_usbhost_utmi_ohci_sel<br>clk_usbhost_utmi_ohci clock mux.<br>1'b0: usbphy_clk480m_mux<br>1'b1: clk_gpll_mux                    |
| 6:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x09               | clk_usbhost_utmi_ohci_div<br>Divide clk_usbhost_utmi_ohci by (div_con + 1)                                                         |

**CRU CLKSEL CON63**

Address: Operational Base + offset (0x01FC)

| <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          | 0x01               | pclk_pdgmac_div<br>Divide pclk_pdgmac by (div_con + 1)                                                                             |
| 7          | RW          | 0x0                | clk_gmac_divout_sel<br>clk_gmac_divout clock mux.<br>1'b0: clk_cpll_mux<br>1'b1: clk_gpll_mux                                      |
| 6:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x07               | clk_gmac_divout_div<br>Divide clk_gmac_divout by (div_con + 1)                                                                     |

**CRU CLKSEL CON64**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_ddrphy_com_sel<br>clk_ddrphy_com clock mux.<br>1'b0: clk_dpll_mux<br>1'b1: clk_gpll_mux                                        |
| 14:13      | RO          | 0x0                | reserved                                                                                                                           |
| 12:8       | RW          | 0x01               | clk_ddrphy_com_div<br>Divide clk_ddrphy_com by (div_con + 1)                                                                       |
| 7:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x0b               | pclk_pdddr_pre_div<br>Divide pclk_pdddr_pre by (div_con + 1)                                                                       |

**CRU CLKSEL CON65**

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 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                | aclk_pdnpd_sel<br>aclk_pdnpd clock mux.<br>1'b0: aclk_pdnpd_div<br>1'b1: aclk_pdnpd_np5                                                      |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                     |
| 9:8        | RW          | 0x0                | aclk_pdnpd_div_sel<br>aclk_pdnpd_div clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: clk_apll_mux<br>2'b11: clk_hppll_mux |
| 7:4        | RW          | 0x1                | aclk_pdnpd_np5_div<br>Divide aclk_pdnpd_np5 by (div_con + 1)                                                                                 |
| 3:0        | RW          | 0x1                | aclk_pdnpd_div_div<br>Divide aclk_pdnpd_div by (div_con + 1)                                                                                 |

**CRU CLKSEL CON66**

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 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          | 0x7                | hclk_pdnpd_div<br>Divide hclk_pdnpd by (div_con + 1)                                                                               |
| 7:5        | RO          | 0x0                | reserved                                                                                                                           |
| 4:0        | RW          | 0x01               | pclk_pdnpd_div<br>Divide pclk_pdnpd by (div_con + 1)                                                                               |

**CRU CLKSEL CON67**

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 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_npu_sel<br>clk_npu clock mux.<br>1'b0: clk_npu_div<br>1'b1: clk_npu_np5                                                            |
| 11:10      | RO          | 0x0                | reserved                                                                                                                               |
| 9:8        | RW          | 0x0                | clk_npu_div_sel<br>clk_npu_div clock mux.<br>2'b00: clk_gpll_mux<br>2'b01: clk_cpll_mux<br>2'b10: clk_apll_mux<br>2'b11: clk_hppll_mux |
| 7:4        | RW          | 0x1                | clk_npu_np5_div<br>Divide clk_npu_np5 by (div_con + 1)                                                                                 |
| 3:0        | RW          | 0x1                | clk_npu_div_div<br>Divide clk_npu_div by (div_con + 1)                                                                                 |

**CRU CLKSEL CON68**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable          |
| 15:8       | RO          | 0x05               | reserved                                                                                                                                    |
| 7:6        | RW          | 0x0                | ackl_pdispp_div_sel<br>ackl_pdispp_div clock mux.<br>2'b00: clk_cpll_mux<br>2'b01: clk_gpll_mux<br>2'b10: clk_hppll_mux<br>Others: Reserved |
| 5          | RO          | 0x0                | reserved                                                                                                                                    |
| 4:0        | RW          | 0x01               | ackl_pdispp_div_div<br>Divide ackl_pdispp_div by (div_con + 1)                                                                              |

**CRU CLKSEL CON69**

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 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          | 0x01               | hclk_pdispp_div<br>Divide hclk_pdispp by (div_con + 1)                                                                                |
| 7:6        | RW          | 0x0                | clk_ispp_div_sel<br>clk_ispp_div clock mux.<br>2'b00: clk_cpll_mux<br>2'b01: clk_gpll_mux<br>2'b10: clk_hppll_mux<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 5          | RO          | 0x0                | reserved                                                 |
| 4:0        | RW          | 0x01               | clk_ispp_div_div<br>Divide clk_ispp_div by (div_con + 1) |

**CRU CLKSEL CON70**

Address: Operational Base + offset (0x0218)

| <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      | RO          | 0x00               | reserved                                                                                                                           |
| 10:0       | RW          | 0x000              | clk_cpu_tsadc_div<br>Divide clk_cpu_tsadc by (div_con + 1)                                                                         |

**CRU CLKSEL CON71**

Address: Operational Base + offset (0x021C)

| <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      | RO          | 0x00               | reserved                                                                                                                           |
| 10:0       | RW          | 0x000              | clk_npu_tsadc_div<br>Divide clk_npu_tsadc by (div_con + 1)                                                                         |

**CRU CLKSEL CON72**

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 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                | clk_acdcdig_i2c_sel<br>clk_acdcdig_i2c clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: xin_osc0_func                                     |
| 7          | RO          | 0x0                | reserved                                                                                                                           |
| 6:0        | RW          | 0x0b               | clk_acdcdig_i2c_div<br>Divide clk_acdcdig_i2c by (div_con + 1)                                                                     |

**CRU CLKSEL CON73**

Address: Operational Base + offset (0x0224)

| <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:10      | RW          | 0x0                | mipicsi_clk_out2io_sel<br>mipicsi_clk_out2io clock mux.<br>2'b00: xin_osc0_func<br>2'b01: mipicsi_clk_out2io_div<br>2'b10: mipicsi_clk_out2io_fracdiv<br>Others: Reserved |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                  |
| 8          | RW          | 0x0                | mipicsi_clk_out2io_div_sel<br>mipicsi_clk_out2io_div clock mux.<br>1'b0: clk_gpll_mux<br>1'b1: usbphy_clk480m_mux                                                         |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                  |
| 4:0        | RW          | 0x07               | mipicsi_clk_out2io_div_div<br>Divide mipicsi_clk_out2io_div by (div_con + 1)                                                                                              |

**CRU CLKSEL CON74**

Address: Operational Base + offset (0x0228)

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

**CRU CLKSEL CON75**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:13      | RO          | 0x0                | reserved                                                                                                                           |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:8 | RW   | 0x00        | clk_testout_sel<br>clk_testout clock mux.<br>5'd00: xin_osc0_func<br>5'd01: clk_32k<br>5'd02: clk_core_pre<br>5'd03: clk_ddrphy<br>5'd04: aclk_pdbus<br>5'd05: hclk_pdbus<br>5'd06: clk_npu<br>5'd07: aclk_pdnpn<br>5'd08: aclk_pdvdec<br>5'd09: clk_vdec_hevc_ca<br>5'd10: aclk_pdvepu<br>5'd11: clk_venc_core<br>5'd12: aclk_pdispp<br>5'd13: aclk_pdjpeg<br>5'd14: aclk_pdvi<br>5'd15: aclk_pdvo<br>5'd16: dclk_vop<br>5'd17: clk_spi1<br>5'd18: clk_mcu<br>5'd19: sclk_uart3<br>5'd20: aclk_pdphp<br>5'd21: sclk_fspi<br>5'd22: mclk_i2s1<br>5'd23: mclk_i2s2<br>5'd24: mclk_i2s0_rx<br>5'd25: mclk_i2s0_tx<br>5'd26: clk_gmac_src<br>5'd27: sclk_audpwm<br>5'd28: nclk_nandc<br>5'd29: cclk_in_sdmmc<br>5'd30: cclk_in_sdio<br>5'd31: cclk_in_emmc |
| 7:5  | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4:0  | RW   | 0x00        | clk_testout_div<br>Divide clk_testout by (div_con + 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

**CRU CLKSEL CON76**

Address: Operational Base + offset (0x0230)

| 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         | clk_isp_sel<br>clk_isp clock mux.<br>1'b0: clk_isp_div<br>1'b1: clk_isp_np5                                                        |
| 12:8  | RW   | 0x01        | clk_isp_np5_div<br>Divide clk_isp_np5 by (div_con + 1)                                                                             |
| 7:6   | RO   | 0x0         | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | aclk_pdvi_sel<br>aclk_pdvi clock mux.<br>1'b0: aclk_pdvi_div<br>1'b1: aclk_pdvi_np5 |
| 4:0        | RW          | 0x01               | aclk_pdvi_np5_div<br>Divide aclk_pdvi_np5 by (div_con + 1)                          |

**CRU CLKSEL CON77**

Address: Operational Base + offset (0x0234)

| <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_ispp_sel<br>clk_ispp clock mux.<br>1'b0: clk_ispp_div<br>1'b1: clk_ispp_np5                                                    |
| 12:8       | RW          | 0x01               | clk_ispp_np5_div<br>Divide clk_ispp_np5 by (div_con + 1)                                                                           |
| 7:6        | RO          | 0x0                | reserved                                                                                                                           |
| 5          | RW          | 0x0                | aclk_pdispp_sel<br>aclk_pdispp clock mux.<br>1'b0: aclk_pdispp_div<br>1'b1: aclk_pdispp_np5                                        |
| 4:0        | RW          | 0x01               | aclk_pdispp_np5_div<br>Divide aclk_pdispp_np5 by (div_con + 1)                                                                     |

**CRU GATE 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         | RW          | 0x0                | pclk_dbg_pre_scan_en<br>pclk_dbg_pre_scan clock gating control.<br>When high, disable clock.                                       |
| 14         | RW          | 0x0                | aclk_core_pre_scan_en<br>aclk_core_pre_scan clock gating control.<br>When high, disable clock.                                     |
| 13         | RW          | 0x0                | clk_core_pre_div2_en<br>clk_core_pre_div2 clock gating control.<br>When high, disable clock.                                       |
| 12         | RW          | 0x0                | clk_core_cpupvtm_en<br>clk_core_cpupvtm clock gating control.<br>When high, disable clock.                                         |
| 11         | RW          | 0x0                | clk_cpupvtm_en<br>clk_cpupvtm clock gating control.<br>When high, disable clock.                                                   |
| 10         | RW          | 0x0                | pclk_cpupvtm_en<br>pclk_cpupvtm clock gating control.<br>When high, disable clock.                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | clk_cpu_jtag_en<br>clk_cpu_jtag clock gating control.<br>When high, disable clock.         |
| 8          | RW          | 0x0                | hclk_pdcore_en<br>hclk_pdcore_biu clock gating control.<br>When high, disable clock.       |
| 7          | RW          | 0x0                | clk_core_pre_g_en<br>clk_core_pre_g clock gating control.<br>When high, disable clock.     |
| 6          | RW          | 0x0                | pclk_core_pre_en<br>pclk_core_pre clock gating control.<br>When high, disable clock.       |
| 5          | RW          | 0x0                | pclk_dbg_daplite_en<br>pclk_dbg_datlite clock gating control.<br>When high, disable clock. |
| 4          | RW          | 0x0                | pclk_dbg_biu_en<br>pclk_dbg_biu clock gating control.<br>When high, disable clock.         |
| 3          | RW          | 0x0                | ackl_core_biu_en<br>ackl_core_biu clock gating control.<br>When high, disable clock.       |
| 2          | RW          | 0x0                | clk_core_pre_en<br>clk_core_pre clock gating control.<br>When high, disable clock.         |
| 1          | RO          | 0x0                | reserved                                                                                   |
| 0          | RW          | 0x0                | ackl_dbg_pre_en<br>ackl_dbg_pre clock gating control.<br>When high, disable clock.         |

**CRU GATE CON02**

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 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_mcu_biu_en<br>clk_mcu_biu clock gating control.<br>When high, disable clock.                                                   |
| 13         | RW          | 0x0                | pclk_pdbus_en<br>pclk_pdbus clock gating control.<br>When high, disable clock.                                                     |
| 12         | RW          | 0x0                | hclk_pdbus_en<br>hclk_pdbus clock gating control.<br>When high, disable clock.                                                     |
| 11         | RW          | 0x0                | ackl_pdbus_en<br>ackl_pdbus clock gating control.<br>When high, disable clock.                                                     |
| 10         | RW          | 0x0                | ackl_pdbus_hold_biu1_en<br>ackl_pdbus_hold_biu1 clock gating control.<br>When high, disable clock.                                 |
| 9          | RW          | 0x0                | hclk_pdbus_biu3_en<br>hclk_pdbus_biu3 clock gating control.<br>When high, disable clock.                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | ackl_pdbus_biu3_en<br>ackl_pdbus_biu3 clock gating control.<br>When high, disable clock. |
| 7          | RW          | 0x0                | hclk_pdbus_biu2_en<br>hclk_pdbus_biu2 clock gating control.<br>When high, disable clock. |
| 6          | RW          | 0x0                | ackl_pdbus_biu2_en<br>ackl_pdbus_biu2 clock gating control.<br>When high, disable clock. |
| 5          | RW          | 0x0                | pclk_pdbus_biu1_en<br>pclk_pdbus_biu1 clock gating control.<br>When high, disable clock. |
| 4          | RW          | 0x0                | hclk_pdbus_biu1_en<br>hclk_pdbus_biu1 clock gating control.<br>When high, disable clock. |
| 3          | RW          | 0x0                | ackl_pdbus_biu1_en<br>ackl_pdbus_biu1 clock gating control.<br>When high, disable clock. |
| 2          | RW          | 0x0                | pclk_pdbus_pre_en<br>pclk_pdbus_pre clock gating control.<br>When high, disable clock.   |
| 1          | RW          | 0x0                | hclk_pdbus_pre_en<br>hclk_pdbus_pre clock gating control.<br>When high, disable clock.   |
| 0          | RW          | 0x0                | ackl_pdbus_pre_en<br>ackl_pdbus_pre clock gating control.<br>When high, disable clock.   |

**CRU GATE CON03**

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 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_i2c1_en<br>clk_i2c1 clock gating control.<br>When high, disable clock.                                                         |
| 10         | RW          | 0x0                | pclk_i2c1_en<br>pclk_i2c1 clock gating control.<br>When high, disable clock.                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | aclk_system_sram_en<br>aclk_system_sram clock gating control.<br>When high, disable clock. |
| 8          | RO          | 0x0                | reserved                                                                                   |
| 7          | RW          | 0x0                | pclk_dcf_en<br>pclk_dcf clock gating control.<br>When high, disable clock.                 |
| 6          | RW          | 0x0                | ack_dcf_en<br>ack_dcf clock gating control.<br>When high, disable clock.                   |
| 5          | RW          | 0x0                | clk_crypto_pka_en<br>clk_crypto_pka clock gating control.<br>When high, disable clock.     |
| 4          | RW          | 0x0                | clk_crypto_core_en<br>clk_crypto_core clock gating control.<br>When high, disable clock.   |
| 3          | RW          | 0x0                | hclk_crypto_en<br>hclk_crypto clock gating control.<br>When high, disable clock.           |
| 2          | RW          | 0x0                | ackl_crypto_en<br>ackl_crypto clock gating control.<br>When high, disable clock.           |
| 1:0        | RO          | 0x0                | reserved                                                                                   |

**CRU GATE CON04**

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 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                | hclk_pdcrypt_biu_en<br>hclk_pdcrypt_biu clock gating control.<br>When high, disable clock.                                         |
| 13         | RW          | 0x0                | ackl_pdcrypt_biu_en<br>ackl_pdcrypt_biu clock gating control.<br>When high, disable clock.                                         |
| 12         | RW          | 0x0                | hclk_pdcrypt_en<br>hclk_pdcrypt clock gating control.<br>When high, disable clock.                                                 |
| 11         | RW          | 0x0                | ackl_pdcrypt_en<br>ackl_pdcrypt clock gating control.<br>When high, disable clock.                                                 |
| 10         | RW          | 0x0                | clk_mcu_jtag_en<br>clk_mcu_jtag clock gating control.<br>When high, disable clock.                                                 |
| 9          | RW          | 0x0                | clk_mcu_rtc_en<br>clk_mcu_rtc_ndft clock gating control.<br>When high, disable clock.                                              |
| 8          | RW          | 0x0                | clk_mcu_core_en<br>clk_mcu_core clock gating control.<br>When high, disable clock.                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | clk_mcu_en<br>clk_mcu clock gating control.<br>When high, disable clock.                        |
| 6          | RW          | 0x0                | clk_capture_pwm2_en<br>clk_capture_pwm2_ndft clock gating control.<br>When high, disable clock. |
| 5          | RW          | 0x0                | clk_pwm2_en<br>clk_pwm2 clock gating control.<br>When high, disable clock.                      |
| 4          | RW          | 0x0                | pclk_pwm2_en<br>pclk_pwm2 clock gating control.<br>When high, disable clock.                    |
| 3          | RW          | 0x0                | clk_spi1_en<br>clk_spi1 clock gating control.<br>When high, disable clock.                      |
| 2          | RW          | 0x0                | pclk_spi1_en<br>pclk_spi1 clock gating control.<br>When high, disable clock.                    |
| 1          | RW          | 0x0                | clk_i2c5_en<br>clk_i2c5 clock gating control.<br>When high, disable clock.                      |
| 0          | RW          | 0x0                | pclk_i2c5_en<br>pclk_i2c5 clock gating control.<br>When high, disable clock.                    |

**CRU GATE CON05**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | sclk_uart4_en<br>sclk_uart4 clock gating control.<br>When high, disable clock.                                                     |
| 14         | RW          | 0x0                | sclk_uart4_frac_en<br>sclk_uart4_frac clock gating control.<br>When high, disable clock.                                           |
| 13         | RW          | 0x0                | sclk_uart4_div_en<br>sclk_uart4_div clock gating control.<br>When high, disable clock.                                             |
| 12         | RW          | 0x0                | pclk_uart4_en<br>pclk_uart4 clock gating control.<br>When high, disable clock.                                                     |
| 11         | RW          | 0x0                | sclk_uart3_en<br>sclk_uart3 clock gating control.<br>When high, disable clock.                                                     |
| 10         | RW          | 0x0                | sclk_uart3_frac_en<br>sclk_uart3_frac clock gating control.<br>When high, disable clock.                                           |
| 9          | RW          | 0x0                | sclk_uart3_div_en<br>sclk_uart3_div clock gating control.<br>When high, disable clock.                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | pclk_uart3_en<br>pclk_uart3 clock gating control.<br>When high, disable clock.           |
| 7          | RW          | 0x0                | sclk_uart2_en<br>sclk_uart2 clock gating control.<br>When high, disable clock.           |
| 6          | RW          | 0x0                | sclk_uart2_frac_en<br>sclk_uart2_frac clock gating control.<br>When high, disable clock. |
| 5          | RW          | 0x0                | sclk_uart2_div_en<br>sclk_uart2_div clock gating control.<br>When high, disable clock.   |
| 4          | RW          | 0x0                | pclk_uart2_en<br>pclk_uart2 clock gating control.<br>When high, disable clock.           |
| 3          | RW          | 0x0                | sclk_uart0_en<br>sclk_uart0 clock gating control.<br>When high, disable clock.           |
| 2          | RW          | 0x0                | sclk_uart0_frac_en<br>sclk_uart0_frac clock gating control.<br>When high, disable clock. |
| 1          | RW          | 0x0                | sclk_uart0_div_en<br>sclk_uart0_div clock gating control.<br>When high, disable clock.   |
| 0          | RW          | 0x0                | pclk_uart0_en<br>pclk_uart0 clock gating control.<br>When high, disable clock.           |

**CRU GATE CON06**

Address: Operational Base + offset (0x0298)

| <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_grf_en<br>pclk_grf clock gating control.<br>When high, disable clock.                                                         |
| 14         | RW          | 0x0                | pclk_wdt_en<br>pclk_wdt clock gating control.<br>When high, disable clock.                                                         |
| 13         | RW          | 0x0                | clk_timer5_en<br>clk_timer5 clock gating control.<br>When high, disable clock.                                                     |
| 12         | RW          | 0x0                | clk_timer4_en<br>clk_timer4 clock gating control.<br>When high, disable clock.                                                     |
| 11         | RW          | 0x0                | clk_timer3_en<br>clk_timer3 clock gating control.<br>When high, disable clock.                                                     |
| 10         | RW          | 0x0                | clk_timer2_en<br>clk_timer2 clock gating control.<br>When high, disable clock.                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | clk_timer1_en<br>clk_timer1 clock gating control.<br>When high, disable clock.           |
| 8          | RW          | 0x0                | clk_timer0_en<br>clk_timer0 clock gating control.<br>When high, disable clock.           |
| 7          | RW          | 0x0                | pclk_timer_en<br>pclk_timer clock gating control.<br>When high, disable clock.           |
| 6          | RW          | 0x0                | ack_spinlock_en<br>ack_spinlock clock gating control.<br>When high, disable clock.       |
| 5          | RW          | 0x0                | clk_saradc_en<br>clk_saradc_ndft clock gating control.<br>When high, disable clock.      |
| 4          | RW          | 0x0                | pclk_saradc_en<br>pclk_saradc clock gating control.<br>When high, disable clock.         |
| 3          | RW          | 0x0                | sclk_uart5_en<br>sclk_uart5 clock gating control.<br>When high, disable clock.           |
| 2          | RW          | 0x0                | sclk_uart5_frac_en<br>sclk_uart5_frac clock gating control.<br>When high, disable clock. |
| 1          | RW          | 0x0                | sclk_uart5_div_en<br>sclk_uart5_div clock gating control.<br>When high, disable clock.   |
| 0          | RW          | 0x0                | pclk_uart5_en<br>pclk_uart5 clock gating control.<br>When high, disable clock.           |

**CRU GATE CON07**

Address: Operational Base + offset (0x029C)

| <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                | pclk_intmux_en<br>pclk_intmux clock gating control.<br>When high, disable clock.                                                   |
| 13         | RW          | 0x0                | dclk_decom_en<br>dclk_decom clock gating control.<br>When high, disable clock.                                                     |
| 12         | RW          | 0x0                | pclk_decom_en<br>pclk_decom clock gating control.<br>When high, disable clock.                                                     |
| 11         | RW          | 0x0                | ack_decom_en<br>ack_decom clock gating control.<br>When high, disable clock.                                                       |
| 10         | RW          | 0x0                | pclk_mailbox_en<br>pclk_mailbox clock gating control.<br>When high, disable clock.                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | clk_can_en<br>clk_can clock gating control.<br>When high, disable clock.         |
| 8          | RW          | 0x0                | pclk_can_en<br>pclk_can clock gating control.<br>When high, disable clock.       |
| 7          | RW          | 0x0                | dbclk_gpio4_en<br>dbclk_gpio4 clock gating control.<br>When high, disable clock. |
| 6          | RW          | 0x0                | pclk_gpio4_en<br>pclk_gpio4 clock gating control.<br>When high, disable clock.   |
| 5          | RW          | 0x0                | dbclk_gpio3_en<br>dbclk_gpio3 clock gating control.<br>When high, disable clock. |
| 4          | RW          | 0x0                | pclk_gpio3_en<br>pclk_gpio3 clock gating control.<br>When high, disable clock.   |
| 3          | RW          | 0x0                | dbclk_gpio2_en<br>dbclk_gpio2 clock gating control.<br>When high, disable clock. |
| 2          | RW          | 0x0                | pclk_gpio2_en<br>pclk_gpio2 clock gating control.<br>When high, disable clock.   |
| 1          | RW          | 0x0                | dbclk_gpio1_en<br>dbclk_gpio1 clock gating control.<br>When high, disable clock. |
| 0          | RW          | 0x0                | pclk_gpio1_en<br>pclk_gpio1 clock gating control.<br>When high, disable clock.   |

**CRU GATE CON08**

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 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                | pclk_sgrf_en<br>pclk_sgrf clock gating control.<br>When high, disable clock.                                                       |
| 3:0        | RO          | 0x0                | reserved                                                                                                                           |

**CRU GATE CON09**

Address: Operational Base + offset (0x02A4)

| <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_i2s2_fracdiv_v2_en<br>mclk_i2s2_fracdiv_v2 clock gating control.<br>When high, disable clock.                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | mclk_i2s0_rx_out2io_en<br>mclk_i2s0_rx_out2io clock gating control.<br>When high, disable clock.   |
| 13         | RW          | 0x0                | mclk_i2s0_tx_out2io_en<br>mclk_i2s0_tx_out2io clock gating control.<br>When high, disable clock.   |
| 12:11      | RO          | 0x0                | reserved                                                                                           |
| 10         | RW          | 0x0                | mclk_i2s0_rx_src_en<br>mclk_i2s0_rx clock gating control.<br>When high, disable clock.             |
| 9          | RW          | 0x0                | mclk_i2s0_tx_src_en<br>mclk_i2s0_tx clock gating control.<br>When high, disable clock.             |
| 8          | RW          | 0x0                | mclk_i2s0_rx_fracdiv_en<br>mclk_i2s0_rx_fracdiv clock gating control.<br>When high, disable clock. |
| 7          | RW          | 0x0                | mclk_i2s0_rx_div_en<br>mclk_i2s0_rx_div clock gating control.<br>When high, disable clock.         |
| 6          | RW          | 0x0                | mclk_i2s0_tx_fracdiv_en<br>mclk_i2s0_tx_fracdiv clock gating control.<br>When high, disable clock. |
| 5          | RW          | 0x0                | mclk_i2s0_tx_div_en<br>mclk_i2s0_tx_div clock gating control.<br>When high, disable clock.         |
| 4          | RW          | 0x0                | hclk_i2s0_en<br>hclk_i2s0 clock gating control.<br>When high, disable clock.                       |
| 3          | RW          | 0x0                | pclk_pdaudio_biu_en<br>pclk_pdaudio_biu clock gating control.<br>When high, disable clock.         |
| 2          | RW          | 0x0                | hclk_pdaudio_biu_en<br>hclk_pdaudio_biu clock gating control.<br>When high, disable clock.         |
| 1          | RO          | 0x0                | reserved                                                                                           |
| 0          | RW          | 0x0                | hclk_pdaudio_en<br>hclk_pdaudio clock gating control.<br>When high, disable clock.                 |

**CRU GATE CON10**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | sclk_aud pwm_en<br>sclk_aud pwm clock gating control.<br>When high, disable clock.                                                 |
| 14         | RW          | 0x0                | sclk_aud pwm_fracdiv_en<br>sclk_aud pwm_fracdiv clock gating control.<br>When high, disable clock.                                 |
| 13         | RW          | 0x0                | sclk_aud pwm_div_en<br>sclk_aud pwm_div clock gating control.<br>When high, disable clock.                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | hclk_audpwm_en<br>hclk_audpwm clock gating control.<br>When high, disable clock.             |
| 11         | RW          | 0x0                | mclk_pdm_en<br>mclk_pdm clock gating control.<br>When high, disable clock.                   |
| 10         | RW          | 0x0                | hclk_pdm_en<br>hclk_pdm clock gating control.<br>When high, disable clock.                   |
| 9          | RW          | 0x0                | mclk_i2s2_out2io_en<br>mclk_i2s2_out2io clock gating control.<br>When high, disable clock.   |
| 8          | RW          | 0x0                | mclk_i2s2_en<br>mclk_i2s2 clock gating control.<br>When high, disable clock.                 |
| 7          | RW          | 0x0                | mclk_i2s2_fracdiv_en<br>mclk_i2s2_fracdiv clock gating control.<br>When high, disable clock. |
| 6          | RW          | 0x0                | mclk_i2s2_div_en<br>mclk_i2s2_div clock gating control.<br>When high, disable clock.         |
| 5          | RW          | 0x0                | hclk_i2s2_en<br>hclk_i2s2 clock gating control.<br>When high, disable clock.                 |
| 4          | RW          | 0x0                | mclk_i2s1_out2io_en<br>mclk_i2s1_out2io clock gating control.<br>When high, disable clock.   |
| 3          | RW          | 0x0                | mclk_i2s1_en<br>mclk_i2s1 clock gating control.<br>When high, disable clock.                 |
| 2          | RW          | 0x0                | mclk_i2s1_fracdiv_en<br>mclk_i2s1_fracdiv clock gating control.<br>When high, disable clock. |
| 1          | RW          | 0x0                | mclk_i2s1_div_en<br>mclk_i2s1_div clock gating control.<br>When high, disable clock.         |
| 0          | RW          | 0x0                | hclk_i2s1_en<br>hclk_i2s1 clock gating control.<br>When high, disable clock.                 |

**CRU GATE CON11**

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 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                | clk_acdcdig_dac_en<br>clk_acdcdig_dac clock gating control.<br>When high, disable clock.                                           |
| 2          | RW          | 0x0                | clk_acdcdig_adc_en<br>clk_acdcdig_adc clock gating control.<br>When high, disable clock.                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | clk_acdcdig_i2c_en<br>clk_acdcdig_i2c clock gating control.<br>When high, disable clock. |
| 0          | RW          | 0x0                | pclk_acdcdig_en<br>pclk_acdcdig clock gating control.<br>When high, disable clock.       |

**CRU GATE CON12**

Address: Operational Base + offset (0x02B0)

| <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          | RW          | 0x0                | clk_iep_core_en<br>clk_iep_core clock gating control.<br>When high, disable clock.                                                 |
| 8          | RW          | 0x0                | hclk_iep_en<br>hclk_iep clock gating control.<br>When high, disable clock.                                                         |
| 7          | RW          | 0x0                | ackl_iep_en<br>ackl_iep clock gating control.<br>When high, disable clock.                                                         |
| 6          | RW          | 0x0                | hclk_venc_en<br>hclk_venc clock gating control.<br>When high, disable clock.                                                       |
| 5          | RW          | 0x0                | ackl_venc_en<br>ackl_venc clock gating control.<br>When high, disable clock.                                                       |
| 4          | RW          | 0x0                | hclk_pdvepu_biu_en<br>hclk_pdvepu_biu clock gating control.<br>When high, disable clock.                                           |
| 3          | RW          | 0x0                | ackl_pdvepu_biu_en<br>ackl_pdvepu_biu clock gating control.<br>When high, disable clock.                                           |
| 2          | RW          | 0x0                | hclk_pdvepu_en<br>hclk_pdvepu clock gating control.<br>When high, disable clock.                                                   |
| 1          | RW          | 0x0                | clk_venc_core_en<br>clk_venc_core clock gating control.<br>When high, disable clock.                                               |
| 0          | RW          | 0x0                | ackl_pdvepu_en<br>ackl_pdvepu clock gating control.<br>When high, disable clock.                                                   |

**CRU GATE CON13**

Address: Operational Base + offset (0x02B4)

| <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                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | hclk_jpeg_en<br>hclk_jpeg clock gating control.<br>When high, disable clock.               |
| 13         | RW          | 0x0                | ackl_jpeg_en<br>ackl_jpeg clock gating control.<br>When high, disable clock.               |
| 12         | RW          | 0x0                | hclk_pdjpeg_biu_en<br>hclk_pdjpeg_biu clock gating control.<br>When high, disable clock.   |
| 11         | RW          | 0x0                | ackl_pdjpeg_biu_en<br>ackl_pdjpeg_biu clock gating control.<br>When high, disable clock.   |
| 10         | RW          | 0x0                | hclk_pdjpeg_en<br>hclk_pdjpeg clock gating control.<br>When high, disable clock.           |
| 9          | RW          | 0x0                | ackl_pdjpeg_en<br>ackl_pdjpeg clock gating control.<br>When high, disable clock.           |
| 8          | RW          | 0x0                | hclk_vdec_en<br>hclk_vdec clock gating control.<br>When high, disable clock.               |
| 7          | RW          | 0x0                | ackl_vdec_en<br>ackl_vdec clock gating control.<br>When high, disable clock.               |
| 6          | RW          | 0x0                | hclk_pdvdec_biu_en<br>hclk_pdvdec_biu clock gating control.<br>When high, disable clock.   |
| 5          | RW          | 0x0                | ackl_pdvdec_biu_en<br>ackl_pdvdec_biu clock gating control.<br>When high, disable clock.   |
| 4          | RW          | 0x0                | hclk_pdvdec_en<br>hclk_pdvdec clock gating control.<br>When high, disable clock.           |
| 3          | RW          | 0x0                | clk_vdec_hevc_ca_en<br>clk_vdec_hevc_ca clock gating control.<br>When high, disable clock. |
| 2          | RW          | 0x0                | clk_vdec_ca_en<br>clk_vdec_ca clock gating control.<br>When high, disable clock.           |
| 1          | RW          | 0x0                | clk_vdec_core_en<br>clk_vdec_core clock gating control.<br>When high, disable clock.       |
| 0          | RW          | 0x0                | ackl_pdvdec_en<br>ackl_pdvdec clock gating control.<br>When high, disable clock.           |

**CRU GATE CON14**

Address: Operational Base + offset (0x02B8)

| <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                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | pclk_dsihost_en<br>pclk_dsihost clock gating control.<br>When high, disable clock.         |
| 13         | RW          | 0x0                | dclk_vop_en<br>dclk_vop clock gating control.<br>When high, disable clock.                 |
| 12         | RW          | 0x0                | dclk_vop_fracdiv_en<br>dclk_vop_fracdiv clock gating control.<br>When high, disable clock. |
| 11         | RW          | 0x0                | dclk_vop_div_en<br>dclk_vop_div clock gating control.<br>When high, disable clock.         |
| 10         | RW          | 0x0                | hclk_vop_en<br>hclk_vop clock gating control.<br>When high, disable clock.                 |
| 9          | RW          | 0x0                | ackl_vop_en<br>ackl_vop clock gating control.<br>When high, disable clock.                 |
| 8          | RW          | 0x0                | clk_rga_core_en<br>clk_rga_core clock gating control.<br>When high, disable clock.         |
| 7          | RW          | 0x0                | hclk_rga_en<br>hclk_rga clock gating control.<br>When high, disable clock.                 |
| 6          | RW          | 0x0                | ackl_rga_en<br>ackl_rga clock gating control.<br>When high, disable clock.                 |
| 5          | RW          | 0x0                | pclk_pdvo_biu_en<br>pclk_pdvo_biu clock gating control.<br>When high, disable clock.       |
| 4          | RW          | 0x0                | hclk_pdvo_biu_en<br>hclk_pdvo_biu clock gating control.<br>When high, disable clock.       |
| 3          | RW          | 0x0                | ackl_pdvo_biu_en<br>ackl_pdvo_biu clock gating control.<br>When high, disable clock.       |
| 2          | RW          | 0x0                | pclk_pdvo_en<br>pclk_pdvo clock gating control.<br>When high, disable clock.               |
| 1          | RW          | 0x0                | hclk_pdvo_en<br>hclk_pdvo clock gating control.<br>When high, disable clock.               |
| 0          | RW          | 0x0                | ackl_pdvo_en<br>ackl_pdvo clock gating control.<br>When high, disable clock.               |

**CRU GATE CON15**

Address: Operational Base + offset (0x02BC)

| <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_csihost_en<br>pclk_csihost clock gating control.<br>When high, disable clock.                     |
| 14         | RW          | 0x0                | clk_cif_out2io_en<br>clk_cif_out2io clock gating control.<br>When high, disable clock.                 |
| 13         | RW          | 0x0                | clk_cif_out2io_fracdiv_en<br>clk_cif_out2io_fracdiv clock gating control.<br>When high, disable clock. |
| 12         | RW          | 0x0                | clk_cif_out2io_div_en<br>clk_cif_out2io_div clock gating control.<br>When high, disable clock.         |
| 11         | RW          | 0x0                | dclk_cif_en<br>dclk_cif clock gating control.<br>When high, disable clock.                             |
| 10         | RW          | 0x0                | hclk_cif_en<br>hclk_cif clock gating control.<br>When high, disable clock.                             |
| 9          | RW          | 0x0                | ackl_cif_en<br>ackl_cif clock gating control.<br>When high, disable clock.                             |
| 8          | RW          | 0x0                | clk_isp_div_en<br>clk_isp_div clock gating control.<br>When high, disable clock.                       |
| 7          | RW          | 0x0                | hclk_isp_en<br>hclk_isp clock gating control.<br>When high, disable clock.                             |
| 6          | RW          | 0x0                | ackl_isp_en<br>ackl_isp clock gating control.<br>When high, disable clock.                             |
| 5          | RW          | 0x0                | pclk_pdvi_biu_en<br>pclk_pdvi_biu clock gating control.<br>When high, disable clock.                   |
| 4          | RW          | 0x0                | hclk_pdvi_biu_en<br>hclk_pdvi_biu clock gating control.<br>When high, disable clock.                   |
| 3          | RW          | 0x0                | ackl_pdvi_biu_en<br>ackl_pdvi_biu clock gating control.<br>When high, disable clock.                   |
| 2          | RW          | 0x0                | pclk_pdvi_en<br>pclk_pdvi clock gating control.<br>When high, disable clock.                           |
| 1          | RW          | 0x0                | hclk_pdvi_en<br>hclk_pdvi clock gating control.<br>When high, disable clock.                           |
| 0          | RW          | 0x0                | ackl_pdvi_div_en<br>ackl_pdvi_div clock gating control.<br>When high, disable clock.                   |

**CRU GATE CON16**

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 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_isp_np5_en<br>clk_isp_np5 clock gating control.<br>When high, disable clock.                                                   |
| 13         | RW          | 0x0                | ackl_pdvi_np5_en<br>ackl_pdvi_np5 clock gating control.<br>When high, disable clock.                                               |
| 12         | RW          | 0x0                | dclk_ciflite_en<br>dclk_ciflite clock gating control.<br>When high, disable clock.                                                 |
| 11         | RW          | 0x0                | hclk_ciflite_en<br>hclk_ciflite clock gating control.<br>When high, disable clock.                                                 |
| 10         | RW          | 0x0                | ackl_ciflite_en<br>ackl_ciflite clock gating control.<br>When high, disable clock.                                                 |
| 9          | RO          | 0x0                | reserved                                                                                                                           |
| 8          | RW          | 0x0                | ackl_pdispp_np5_en<br>ackl_pdispp_np5 clock gating control.<br>When high, disable clock.                                           |
| 7          | RW          | 0x0                | clk_ispp_np5_en<br>clk_ispp_np5 clock gating control.<br>When high, disable clock.                                                 |
| 6          | RW          | 0x0                | clk_ispp_div_en<br>clk_ispp_div clock gating control.<br>When high, disable clock.                                                 |
| 5          | RW          | 0x0                | hclk_ispp_en<br>hclk_ispp clock gating control.<br>When high, disable clock.                                                       |
| 4          | RW          | 0x0                | ackl_ispp_en<br>ackl_ispp clock gating control.<br>When high, disable clock.                                                       |
| 3          | RW          | 0x0                | hclk_pdispp_biu_en<br>hclk_pdispp_biu clock gating control.<br>When high, disable clock.                                           |
| 2          | RW          | 0x0                | ackl_pdispp_biu_en<br>ackl_pdispp_biu clock gating control.<br>When high, disable clock.                                           |
| 1          | RW          | 0x0                | hclk_pdispp_en<br>hclk_pdispp clock gating control.<br>When high, disable clock.                                                   |
| 0          | RW          | 0x0                | ackl_pdispp_div_en<br>ackl_pdispp_div clock gating control.<br>When high, disable clock.                                           |

**CRU GATE CON17**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:10      | RO          | 0x00               | reserved                                                                                                                           |
| 9          | RW          | 0x0                | hclk_pdssdio_biu_en<br>hclk_pdssdio_biu clock gating control.<br>When high, disable clock.                                         |
| 8          | RW          | 0x0                | hclk_pdssdio_en<br>hclk_pdssdio clock gating control.<br>When high, disable clock.                                                 |
| 7          | RW          | 0x0                | hclk_pdsdcard_biu_en<br>hclk_pdsdcard_biu clock gating control.<br>When high, disable clock.                                       |
| 6          | RW          | 0x0                | hclk_pdsdcard_en<br>hclk_pdsdcard clock gating control.<br>When high, disable clock.                                               |
| 5          | RW          | 0x0                | hclk_pdphpmid_biu_en<br>hclk_pdphpmid_biu clock gating control.<br>When high, disable clock.                                       |
| 4          | RW          | 0x0                | ackl_pdphpmid_biu_en<br>ackl_pdphpmid_biu clock gating control.<br>When high, disable clock.                                       |
| 3          | RW          | 0x0                | hclk_pdphpmid_en<br>hclk_pdphpmid clock gating control.<br>When high, disable clock.                                               |
| 2          | RW          | 0x0                | ackl_pdphpmid_en<br>ackl_pdphpmid clock gating control.<br>When high, disable clock.                                               |
| 1          | RW          | 0x0                | hclk_pdphp_en<br>hclk_pdphp clock gating control.<br>When high, disable clock.                                                     |
| 0          | RW          | 0x0                | ackl_pdphp_en<br>ackl_pdphp clock gating control.<br>When high, disable clock.                                                     |

**CRU\_GATE\_CON18**

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 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                | nclk_nandc_en<br>nclk_nandc clock gating control.<br>When high, disable clock.                                                     |
| 13         | RW          | 0x0                | hclk_nandc_en<br>hclk_nandc clock gating control.<br>When high, disable clock.                                                     |
| 12         | RW          | 0x0                | sclk_fspi_en<br>sclk_fspi clock gating control.<br>When high, disable clock.                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | hclk_fspixip_en<br>hclk_fspixip clock gating control.<br>When high, disable clock.     |
| 10         | RW          | 0x0                | hclk_fspi_en<br>hclk_fspi clock gating control.<br>When high, disable clock.           |
| 9          | RW          | 0x0                | cclkin_emmc_en<br>cclkin_emmc clock gating control.<br>When high, disable clock.       |
| 8          | RW          | 0x0                | hclk_emmc_en<br>hclk_emmc clock gating control.<br>When high, disable clock.           |
| 7          | RW          | 0x0                | cclkin_sdio_en<br>cclkin_sdio clock gating control.<br>When high, disable clock.       |
| 6          | RW          | 0x0                | hclk_sdio_en<br>hclk_sdio clock gating control.<br>When high, disable clock.           |
| 5          | RW          | 0x0                | cclkin_sdmmc_en<br>cclkin_sdmmc clock gating control.<br>When high, disable clock.     |
| 4          | RW          | 0x0                | hclk_sdmmc_en<br>hclk_sdmmc clock gating control.<br>When high, disable clock.         |
| 3          | RW          | 0x0                | hclk_pdnvm_biu_en<br>hclk_pdnvm_biu clock gating control.<br>When high, disable clock. |
| 2          | RO          | 0x0                | reserved                                                                               |
| 1          | RW          | 0x0                | hclk_pdnvm_en<br>hclk_pdnvm clock gating control.<br>When high, disable clock.         |
| 0          | RO          | 0x0                | reserved                                                                               |

**CRU GATE CON19**

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 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                | pclk_usbphy_host_en<br>pclk_usbphy_host clock gating control.<br>When high, disable clock.                                         |
| 12         | RW          | 0x0                | pclk_usbphy_otg_en<br>pclk_usbphy_otg clock gating control.<br>When high, disable clock.                                           |
| 11:9       | RO          | 0x0                | reserved                                                                                                                           |
| 8          | RW          | 0x0                | clk_usbotg_ref_en<br>clk_usbotg_ref clock gating control.<br>When high, disable clock.                                             |
| 7          | RW          | 0x0                | ack_usbotg_en<br>ack_usbotg clock gating control.<br>When high, disable clock.                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | clk_usbhost_utmi_ohci_en<br>clk_usbhost_utmi_ohci clock gating control.<br>When high, disable clock. |
| 5          | RW          | 0x0                | hclk_usbhost_arb_en<br>hclk_usbhost_arb clock gating control.<br>When high, disable clock.           |
| 4          | RW          | 0x0                | hclk_usbhost_en<br>hclk_usbhost clock gating control.<br>When high, disable clock.                   |
| 3          | RW          | 0x0                | hclk_pdusb_biu_en<br>hclk_pdusb_biu clock gating control.<br>When high, disable clock.               |
| 2          | RW          | 0x0                | ackl_pdusb_biu_en<br>ackl_pdusb_biu clock gating control.<br>When high, disable clock.               |
| 1          | RW          | 0x0                | hclk_pdusb_en<br>hclk_pdusb clock gating control.<br>When high, disable clock.                       |
| 0          | RW          | 0x0                | ackl_pdusb_en<br>ackl_pdusb clock gating control.<br>When high, disable clock.                       |

**CRU GATE CON20**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | clk_ddr_mon_en<br>clk_ddr_mon clock gating control.<br>When high, disable clock.                                                   |
| 14         | RO          | 0x0                | reserved                                                                                                                           |
| 13         | RW          | 0x0                | clk_gmac_rgmii_m1_en<br>clk_gmac_rgmii_m1_g clock gating control.<br>When high, disable clock.                                     |
| 12         | RW          | 0x0                | clk_gmac_rgmii_m0_en<br>clk_gmac_rgmii_m0_g clock gating control.<br>When high, disable clock.                                     |
| 11         | RW          | 0x0                | clk_gmac_ethernet_out2io_en<br>clk_gmac_ethernet_out2io clock gating control.<br>When high, disable clock.                         |
| 10         | RW          | 0x0                | clk_mac_ptpref_en<br>clk_mac_ptpref clock gating control.<br>When high, disable clock.                                             |
| 9          | RW          | 0x0                | clk_mac_tx_en<br>clk_mac_tx_src clock gating control.<br>When high, disable clock.                                                 |
| 8          | RW          | 0x0                | clk_mac_rx_en<br>clk_mac_rx_src clock gating control.<br>When high, disable clock.                                                 |
| 7          | RW          | 0x0                | clk_mac_ref_en<br>clk_mac_ref clock gating control.<br>When high, disable clock.                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | clk_gmac_divout_en<br>clk_gmac_divout clock gating control.<br>When high, disable clock. |
| 5          | RW          | 0x0                | pclk_gmac_en<br>pclk_gmac clock gating control.<br>When high, disable clock.             |
| 4          | RW          | 0x0                | ack_gmac_en<br>ack_gmac clock gating control.<br>When high, disable clock.               |
| 3          | RW          | 0x0                | pclk_pdgmac_biu_en<br>pclk_pdgmac_biu clock gating control.<br>When high, disable clock. |
| 2          | RW          | 0x0                | ack_pdgmac_biu_en<br>ack_pdgmac_biu clock gating control.<br>When high, disable clock.   |
| 1          | RW          | 0x0                | pclk_pdgmac_en<br>pclk_pdgmac clock gating control.<br>When high, disable clock.         |
| 0          | RW          | 0x0                | ack_pdgmac_en<br>ack_pdgmac clock gating control.<br>When high, disable clock.           |

**CRU GATE CON21**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15         | RW          | 0x0                | pclk_pdddr_en<br>pclk_pdddr clock gating control.<br>When high, disable clock.                                                     |
| 14         | RW          | 0x0                | clk_ddr_standby_en<br>clk_ddr_standby clock gating control.<br>When high, disable clock.                                           |
| 13         | RW          | 0x0                | clk_ddr_dfictl_en<br>clk_ddr_dfictl clock gating control.<br>When high, disable clock.                                             |
| 12:11      | RO          | 0x0                | reserved                                                                                                                           |
| 10         | RW          | 0x0                | clk_ddr_msch_en<br>clk_ddr_msch clock gating control.<br>When high, disable clock.                                                 |
| 9          | RW          | 0x0                | ack_ddr_split_en<br>ack_ddr_split clock gating control.<br>When high, disable clock.                                               |
| 8          | RW          | 0x0                | clk_ddrphy_en<br>clk_ddrphy_com clock gating control.<br>When high, disable clock.                                                 |
| 7          | RW          | 0x0                | tmclk_ddr_mon_en<br>tmclk_ddr_mon_ndft clock gating control.<br>When high, disable clock.                                          |
| 6          | RW          | 0x0                | pclk_ddr_msch_en<br>pclk_ddr_msch clock gating control.<br>When high, disable clock.                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | pclk_ddr_grf_en<br>pclk_ddr_grf clock gating control.<br>When high, disable clock.         |
| 4          | RW          | 0x0                | pclk_ddr_standby_en<br>pclk_ddr_standby clock gating control.<br>When high, disable clock. |
| 3          | RW          | 0x0                | pclk_ddr_mon_en<br>pclk_ddr_mon clock gating control.<br>When high, disable clock.         |
| 2          | RW          | 0x0                | pclk_ddr_dfictl_en<br>pclk_ddr_dfictl clock gating control.<br>When high, disable clock.   |
| 1          | RO          | 0x0                | reserved                                                                                   |
| 0          | RW          | 0x0                | pclk_pdddr_pre_en<br>pclk_pdddr_pre clock gating control.<br>When high, disable clock.     |

**CRU GATE CON22**

Address: Operational Base + offset (0x02D8)

| <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_core_npupvtm_en<br>clk_core_npupvtm clock gating control.<br>When high, disable clock.                                         |
| 13         | RW          | 0x0                | clk_npupvtm_en<br>clk_npupvtm clock gating control.<br>When high, disable clock.                                                   |
| 12         | RW          | 0x0                | pclk_npupvtm_en<br>pclk_npupvtm clock gating control.<br>When high, disable clock.                                                 |
| 11         | RW          | 0x0                | clk_npu_div2_en<br>clk_npu_div2 clock gating control.<br>When high, disable clock.                                                 |
| 10         | RW          | 0x0                | clk_npu_np5_en<br>clk_npu_np5 clock gating control.<br>When high, disable clock.                                                   |
| 9          | RW          | 0x0                | clk_npu_div_en<br>clk_npu_div clock gating control.<br>When high, disable clock.                                                   |
| 8          | RW          | 0x0                | hclk_npu_en<br>hclk_npu clock gating control.<br>When high, disable clock.                                                         |
| 7          | RW          | 0x0                | ack_npu_en<br>ack_npu clock gating control.<br>When high, disable clock.                                                           |
| 6          | RW          | 0x0                | pclk_pdnpnu_biu_en<br>pclk_pdnpnu_biu clock gating control.<br>When high, disable clock.                                           |
| 5          | RW          | 0x0                | hclk_pdnpnu_biu_en<br>hclk_pdnpnu_biu clock gating control.<br>When high, disable clock.                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | aclk_pdnpu_biu_en<br>aclk_pdnpu_biu clock gating control.<br>When high, disable clock. |
| 3          | RW          | 0x0                | pclk_pdnpu_en<br>pclk_pdnpu clock gating control.<br>When high, disable clock.         |
| 2          | RW          | 0x0                | hclk_pdnpu_en<br>hclk_pdnpu clock gating control.<br>When high, disable clock.         |
| 1          | RW          | 0x0                | aclk_pdnpu_np5_en<br>aclk_pdnpu_np5 clock gating control.<br>When high, disable clock. |
| 0          | RW          | 0x0                | aclk_pdnpu_div_en<br>aclk_pdnpu_div clock gating control.<br>When high, disable clock. |

**CRU\_GATE\_CON23**

Address: Operational Base + offset (0x02DC)

| <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_en<br>clk_testout clock gating control.<br>When high, disable clock.                                                   |
| 12         | RW          | 0x0                | pclk_cpuemadet_en<br>pclk_cpuemadet clock gating control.<br>When high, disable clock.                                             |
| 11         | RW          | 0x0                | pclk_topgrf_en<br>pclk_topgrf clock gating control.<br>When high, disable clock.                                                   |
| 10         | RW          | 0x0                | pclk_topcru_en<br>pclk_topcru clock gating control.<br>When high, disable clock.                                                   |
| 9          | RW          | 0x0                | pclk_topbiu_en<br>pclk_topbiu clock gating control.<br>When high, disable clock.                                                   |
| 8          | RW          | 0x0                | pclk_pdttop_en<br>pclk_pdttop clock gating control.<br>When high, disable clock.                                                   |
| 7          | RW          | 0x0                | mipicsi_clk_out2io_en<br>mipicsi_clk_out2io clock gating control.<br>When high, disable clock.                                     |
| 6          | RW          | 0x0                | mipicsi_clk_out2io_fracdiv_en<br>mipicsi_clk_out2io_fracdiv clock gating control.<br>When high, disable clock.                     |
| 5          | RW          | 0x0                | mipicsi_clk_out2io_div_en<br>mipicsi_clk_out2io_div clock gating control.<br>When high, disable clock.                             |
| 4          | RW          | 0x0                | pclk_dsiphy_en<br>pclk_dsiphy 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_csiphy1_en<br>pclk_csiphy1 clock gating control.<br>When high, disable clock. |
| 2          | RW          | 0x0                | pclk_csiphy0_en<br>pclk_csiphy0 clock gating control.<br>When high, disable clock. |
| 1          | RW          | 0x0                | clk1x_ddrphy_en<br>clk1x_ddrphy clock gating control.<br>When high, disable clock. |
| 0          | RW          | 0x0                | pclk_ddrphy_en<br>pclk_ddrphy clock gating control.<br>When high, disable clock.   |

**CRU GATE CON24**

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 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_npu_mcu_biu_en<br>clk_npu_mcu_biu clock gating control.<br>When high, disable clock.                                           |
| 5          | RW          | 0x0                | clk_npu_tsadcphy_en<br>clk_npu_tsadcphy clock gating control.<br>When high, disable clock.                                         |
| 4          | RW          | 0x0                | clk_npu_tsadc_en<br>clk_npu_tsadc clock gating control.<br>When high, disable clock.                                               |
| 3          | RW          | 0x0                | pclk_npu_tsadc_en<br>pclk_npu_tsadc clock gating control.<br>When high, disable clock.                                             |
| 2          | RW          | 0x0                | clk_cpu_tsadcphy_en<br>clk_cpu_tsadcphy clock gating control.<br>When high, disable clock.                                         |
| 1          | RW          | 0x0                | clk_cpu_tsadc_en<br>clk_cpu_tsadc clock gating control.<br>When high, disable clock.                                               |
| 0          | RW          | 0x0                | pclk_cpu_tsadc_en<br>pclk_cpu_tsadc clock gating control.<br>When high, disable clock.                                             |

**CRU SOFTRST 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         | RW          | 0x0                | presetn_daplite<br>When high, reset relative logic.                                                                                |
| 14         | RW          | 0x0                | presetn_dbg_daplite<br>When high, reset relative logic.                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 13         | RW          | 0x0                | aresetn_core_biu<br>When high, reset relative logic. |
| 12         | RW          | 0x0                | nl2reset<br>When high, reset relative logic.         |
| 11         | RW          | 0x0                | ndbgreset3<br>When high, reset relative logic.       |
| 10         | RW          | 0x0                | ndbgreset2<br>When high, reset relative logic.       |
| 9          | RW          | 0x0                | ndbgreset1<br>When high, reset relative logic.       |
| 8          | RW          | 0x0                | ndbgreset0<br>When high, reset relative logic.       |
| 7          | RW          | 0x0                | ncoreset3<br>When high, reset relative logic.        |
| 6          | RW          | 0x0                | ncoreset2<br>When high, reset relative logic.        |
| 5          | RW          | 0x0                | ncoreset1<br>When high, reset relative logic.        |
| 4          | RW          | 0x0                | ncoreset0<br>When high, reset relative logic.        |
| 3          | RW          | 0x0                | ncoreporeset3<br>When high, reset relative logic.    |
| 2          | RW          | 0x0                | ncoreporeset2<br>When high, reset relative logic.    |
| 1          | RW          | 0x0                | ncoreporeset1<br>When high, reset relative logic.    |
| 0          | RW          | 0x0                | ncoreporeset0<br>When high, reset relative logic.    |

**CRU SOFTRST 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         | RW          | 0x0                | aresetn_system_sram<br>When high, reset relative logic.                                                                            |
| 14         | RW          | 0x0                | presetn_dcf<br>When high, reset relative logic.                                                                                    |
| 13         | RW          | 0x0                | aresetn_dcf<br>When high, reset relative logic.                                                                                    |
| 12:11      | RO          | 0x0                | reserved                                                                                                                           |
| 10         | RW          | 0x0                | resetn_mcu_biu<br>When high, reset relative logic.                                                                                 |
| 9          | RW          | 0x0                | hresetn_pdcore_biu<br>When high, reset relative logic.                                                                             |
| 8          | RW          | 0x0                | presetn_dbg_biu<br>When high, reset relative logic.                                                                                |
| 7          | RW          | 0x0                | aresetn_pdbus_hold_biu1<br>When high, reset relative logic.                                                                        |
| 6          | RW          | 0x0                | hresetn_pdbus_biu3<br>When high, reset relative logic.                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 5          | RW          | 0x0                | aresetn_pdbus_biu3<br>When high, reset relative logic. |
| 4          | RW          | 0x0                | hresetn_pdbus_biu2<br>When high, reset relative logic. |
| 3          | RW          | 0x0                | aresetn_pdbus_biu2<br>When high, reset relative logic. |
| 2          | RW          | 0x0                | presetn_pdbus_biu1<br>When high, reset relative logic. |
| 1          | RW          | 0x0                | hresetn_pdbus_biu1<br>When high, reset relative logic. |
| 0          | RW          | 0x0                | aresetn_pdbus_biu1<br>When high, reset relative logic. |

**CRU SOFTRST 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         | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | aresetn_spinlock<br>When high, reset relative logic.                                                                               |
| 13         | RW          | 0x0                | resetn_pwm2<br>When high, reset relative logic.                                                                                    |
| 12         | RW          | 0x0                | presetn_pwm2<br>When high, reset relative logic.                                                                                   |
| 11         | RO          | 0x0                | reserved                                                                                                                           |
| 10         | RW          | 0x1                | resetn_mcu_core<br>When high, reset relative logic.                                                                                |
| 9          | RW          | 0x0                | resetn_spi1<br>When high, reset relative logic.                                                                                    |
| 8          | RW          | 0x0                | presetn_spi1<br>When high, reset relative logic.                                                                                   |
| 7          | RW          | 0x0                | resetn_i2c5<br>When high, reset relative logic.                                                                                    |
| 6          | RW          | 0x0                | presetn_i2c5<br>When high, reset relative logic.                                                                                   |
| 5          | RW          | 0x0                | resetn_i2c4<br>When high, reset relative logic.                                                                                    |
| 4          | RW          | 0x0                | presetn_i2c4<br>When high, reset relative logic.                                                                                   |
| 3          | RW          | 0x0                | resetn_i2c3<br>When high, reset relative logic.                                                                                    |
| 2          | RW          | 0x0                | presetn_i2c3<br>When high, reset relative logic.                                                                                   |
| 1          | RW          | 0x0                | resetn_i2c1<br>When high, reset relative logic.                                                                                    |
| 0          | RW          | 0x0                | presetn_i2c1<br>When high, reset relative logic.                                                                                   |

**CRU SOFTRST 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         | RW          | 0x0                | preseth_mailbox<br>When high, reset relative logic.                                                                                |
| 14         | RW          | 0x0                | preseth_timer<br>When high, reset relative logic.                                                                                  |
| 13         | RW          | 0x0                | preseth_grf<br>When high, reset relative logic.                                                                                    |
| 12         | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | preseth_saradc<br>When high, reset relative logic.                                                                                 |
| 10         | RW          | 0x0                | preseth_wdt<br>When high, reset relative logic.                                                                                    |
| 9          | RW          | 0x0                | sresetn_uart5<br>When high, reset relative logic.                                                                                  |
| 8          | RW          | 0x0                | sresetn_uart5<br>When high, reset relative logic.                                                                                  |
| 7          | RW          | 0x0                | sresetn_uart4<br>When high, reset relative logic.                                                                                  |
| 6          | RW          | 0x0                | sresetn_uart4<br>When high, reset relative logic.                                                                                  |
| 5          | RW          | 0x0                | sresetn_uart3<br>When high, reset relative logic.                                                                                  |
| 4          | RW          | 0x0                | sresetn_uart3<br>When high, reset relative logic.                                                                                  |
| 3          | RW          | 0x0                | sresetn_uart2<br>When high, reset relative logic.                                                                                  |
| 2          | RW          | 0x0                | sresetn_uart2<br>When high, reset relative logic.                                                                                  |
| 1          | RW          | 0x0                | sresetn_uart0<br>When high, reset relative logic.                                                                                  |
| 0          | RW          | 0x0                | sresetn_uart0<br>When high, reset relative logic.                                                                                  |

**CRU SOFTRST 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         | RW          | 0x0                | dbresetn_gpio4<br>When high, reset relative logic.                                                                                 |
| 14         | RW          | 0x0                | preseth_gpio4<br>When high, reset relative logic.                                                                                  |
| 13         | RW          | 0x0                | dbresetn_gpio3<br>When high, reset relative logic.                                                                                 |
| 12         | RW          | 0x0                | preseth_gpio3<br>When high, reset relative logic.                                                                                  |
| 11         | RW          | 0x0                | dbresetn_gpio2<br>When high, reset relative logic.                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 10         | RW          | 0x0                | presetn_gpio2<br>When high, reset relative logic.  |
| 9          | RW          | 0x0                | dbresetn_gpio1<br>When high, reset relative logic. |
| 8          | RW          | 0x0                | presetn_gpio1<br>When high, reset relative logic.  |
| 7          | RO          | 0x0                | reserved                                           |
| 6          | RW          | 0x0                | presetn_intmux<br>When high, reset relative logic. |
| 5          | RW          | 0x0                | resetn_timer5<br>When high, reset relative logic.  |
| 4          | RW          | 0x0                | resetn_timer4<br>When high, reset relative logic.  |
| 3          | RW          | 0x0                | resetn_timer3<br>When high, reset relative logic.  |
| 2          | RW          | 0x0                | resetn_timer2<br>When high, reset relative logic.  |
| 1          | RW          | 0x0                | resetn_timer1<br>When high, reset relative logic.  |
| 0          | RW          | 0x0                | resetn_timer0<br>When high, reset relative logic.  |

**CRU SOFTRST 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         | RW          | 0x0                | presetn_sgrf<br>When high, reset relative logic.                                                                                   |
| 14         | RO          | 0x0                | reserved                                                                                                                           |
| 13         | RW          | 0x0                | resetn_crypto_pka<br>When high, reset relative logic.                                                                              |
| 12         | RW          | 0x0                | resetn_crypto_core<br>When high, reset relative logic.                                                                             |
| 11         | RW          | 0x0                | hresetn_crypto<br>When high, reset relative logic.                                                                                 |
| 10         | RW          | 0x0                | aresetn_crypto<br>When high, reset relative logic.                                                                                 |
| 9          | RW          | 0x0                | hresetn_pdcrypt_biu<br>When high, reset relative logic.                                                                            |
| 8          | RW          | 0x0                | aresetn_pdcrypt_biu<br>When high, reset relative logic.                                                                            |
| 7          | RW          | 0x0                | dresetn_decom<br>When high, reset relative logic.                                                                                  |
| 6          | RW          | 0x0                | presetn_decom<br>When high, reset relative logic.                                                                                  |
| 5          | RW          | 0x0                | aresetn_decom<br>When high, reset relative logic.                                                                                  |
| 4:2        | RO          | 0x0                | reserved                                                                                                                           |
| 1          | RW          | 0x0                | resetn_can<br>When high, reset relative logic.                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                              |
|------------|-------------|--------------------|-------------------------------------------------|
| 0          | RW          | 0x0                | presetn_can<br>When high, reset relative logic. |

**CRU SOFTRST 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 |
| 15         | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | resetn_acdcdig<br>When high, reset relative logic.                                                                                 |
| 13         | RW          | 0x0                | presetn_acdcdig<br>When high, reset relative logic.                                                                                |
| 12         | RW          | 0x0                | sresetn_audpwm<br>When high, reset relative logic.                                                                                 |
| 11         | RW          | 0x0                | hresetn_audpwm<br>When high, reset relative logic.                                                                                 |
| 10         | RW          | 0x0                | mresetn_pdm<br>When high, reset relative logic.                                                                                    |
| 9          | RW          | 0x0                | hresetn_pdm<br>When high, reset relative logic.                                                                                    |
| 8          | RW          | 0x0                | mresetn_i2s2<br>When high, reset relative logic.                                                                                   |
| 7          | RW          | 0x0                | hresetn_i2s2<br>When high, reset relative logic.                                                                                   |
| 6          | RW          | 0x0                | mresetn_i2s1<br>When high, reset relative logic.                                                                                   |
| 5          | RW          | 0x0                | hresetn_i2s1<br>When high, reset relative logic.                                                                                   |
| 4          | RW          | 0x0                | mresetn_i2s0_rx<br>When high, reset relative logic.                                                                                |
| 3          | RW          | 0x0                | mresetn_i2s0_tx<br>When high, reset relative logic.                                                                                |
| 2          | RW          | 0x0                | hresetn_i2s0<br>When high, reset relative logic.                                                                                   |
| 1          | RW          | 0x0                | presetn_pdaudio_biu<br>When high, reset relative logic.                                                                            |
| 0          | RW          | 0x0                | hresetn_pdaudio_biu<br>When high, reset relative logic.                                                                            |

**CRU SOFTRST 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         | RW          | 0x0                | hresetn_jpeg<br>When high, reset relative logic.                                                                                   |
| 14         | RW          | 0x0                | aresetn_jpeg<br>When high, reset relative logic.                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 13         | RW          | 0x0                | hresetn_pdjpeg_biu<br>When high, reset relative logic.  |
| 12         | RW          | 0x0                | aresetn_pdjpeg_biu<br>When high, reset relative logic.  |
| 11         | RW          | 0x0                | resetn_vdec_hevc_ca<br>When high, reset relative logic. |
| 10         | RW          | 0x0                | resetn_vdec_ca<br>When high, reset relative logic.      |
| 9          | RW          | 0x0                | resetn_vdec_core<br>When high, reset relative logic.    |
| 8          | RW          | 0x0                | hresetn_vdec<br>When high, reset relative logic.        |
| 7          | RW          | 0x0                | aresetn_vdec<br>When high, reset relative logic.        |
| 6          | RW          | 0x0                | hresetn_pdvdec_biu<br>When high, reset relative logic.  |
| 5          | RW          | 0x0                | aresetn_pdvdec_biu<br>When high, reset relative logic.  |
| 4          | RW          | 0x0                | resetn_venc_core<br>When high, reset relative logic.    |
| 3          | RW          | 0x0                | hresetn_venc<br>When high, reset relative logic.        |
| 2          | RW          | 0x0                | aresetn_venc<br>When high, reset relative logic.        |
| 1          | RW          | 0x0                | hresetn_pdvepu_biu<br>When high, reset relative logic.  |
| 0          | RW          | 0x0                | aresetn_pdvepu_biu<br>When high, reset relative logic.  |

**CRU SOFTRST 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         | RO          | 0x0                | reserved                                                                                                                           |
| 14         | RW          | 0x0                | rxpresetn_isp<br>When high, reset relative logic.                                                                                  |
| 13         | RW          | 0x0                | resetn_iep_core<br>When high, reset relative logic.                                                                                |
| 12         | RW          | 0x0                | hresetn_iep<br>When high, reset relative logic.                                                                                    |
| 11         | RW          | 0x0                | aresetn_iep<br>When high, reset relative logic.                                                                                    |
| 10         | RW          | 0x0                | presetn_dsihost<br>When high, reset relative logic.                                                                                |
| 9          | RW          | 0x0                | resetn_txbytehs_dsihost<br>When high, reset relative logic.                                                                        |
| 8          | RW          | 0x0                | dresetn_vop<br>When high, reset relative logic.                                                                                    |
| 7          | RW          | 0x0                | hresetn_vop<br>When high, reset relative logic.                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 6          | RW          | 0x0                | aresetn_vop<br>When high, reset relative logic.      |
| 5          | RW          | 0x0                | resetn_rga_core<br>When high, reset relative logic.  |
| 4          | RW          | 0x0                | hresetn_rga<br>When high, reset relative logic.      |
| 3          | RW          | 0x0                | aresetn_rga<br>When high, reset relative logic.      |
| 2          | RW          | 0x0                | presetn_pdvo_biu<br>When high, reset relative logic. |
| 1          | RW          | 0x0                | hresetn_pdvo_biu<br>When high, reset relative logic. |
| 0          | RW          | 0x0                | aresetn_pdvo_biu<br>When high, reset relative logic. |

**CRU SOFTRST 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         | RW          | 0x0                | presetn_csihost<br>When high, reset relative logic.                                                                                |
| 14         | RW          | 0x0                | resetn_ispp<br>When high, reset relative logic.                                                                                    |
| 13         | RW          | 0x0                | hresetn_ispp<br>When high, reset relative logic.                                                                                   |
| 12         | RW          | 0x0                | aresetn_ispp<br>When high, reset relative logic.                                                                                   |
| 11         | RW          | 0x0                | hresetn_pdispp_biu<br>When high, reset relative logic.                                                                             |
| 10         | RW          | 0x0                | aresetn_pdispp_biu<br>When high, reset relative logic.                                                                             |
| 9          | RW          | 0x0                | rxpresetn_cif<br>When high, reset relative logic.                                                                                  |
| 8          | RW          | 0x0                | iresetn_cif<br>When high, reset relative logic.                                                                                    |
| 7          | RW          | 0x0                | presetn_cif<br>When high, reset relative logic.                                                                                    |
| 6          | RW          | 0x0                | dresetn_cif<br>When high, reset relative logic.                                                                                    |
| 5          | RW          | 0x0                | hresetn_cif<br>When high, reset relative logic.                                                                                    |
| 4          | RW          | 0x0                | aresetn_cif<br>When high, reset relative logic.                                                                                    |
| 3          | RW          | 0x0                | resetn_isp<br>When high, reset relative logic.                                                                                     |
| 2          | RW          | 0x0                | presetn_pdvi_biu<br>When high, reset relative logic.                                                                               |
| 1          | RW          | 0x0                | hresetn_pdvi_biu<br>When high, reset relative logic.                                                                               |
| 0          | RW          | 0x0                | aresetn_pdvi_biu<br>When high, reset relative logic.                                                                               |

**CRU SOFTRST CON10**

Address: Operational Base + offset (0x0328)

| 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    | RO   | 0x0         | reserved                                                                                                                           |
| 14    | RW   | 0x0         | hresetn_pdऱdio_biu<br>When high, reset relative logic.                                                                             |
| 13    | RW   | 0x0         | hresetn_pdऱcard_biu<br>When high, reset relative logic.                                                                            |
| 12    | RO   | 0x0         | reserved                                                                                                                           |
| 11    | RW   | 0x0         | nresetn_nandc<br>When high, reset relative logic.                                                                                  |
| 10    | RW   | 0x0         | hresetn_nandc<br>When high, reset relative logic.                                                                                  |
| 9     | RW   | 0x0         | sresetn_fspi<br>When high, reset relative logic.                                                                                   |
| 8     | RW   | 0x0         | hresetn_fspixip<br>When high, reset relative logic.                                                                                |
| 7     | RW   | 0x0         | hresetn_fspi<br>When high, reset relative logic.                                                                                   |
| 6     | RW   | 0x0         | hresetn_emmc<br>When high, reset relative logic.                                                                                   |
| 5     | RW   | 0x0         | hresetn_sdio<br>When high, reset relative logic.                                                                                   |
| 4     | RW   | 0x0         | hresetn_sdmmc<br>When high, reset relative logic.                                                                                  |
| 3     | RW   | 0x0         | hresetn_pdऱvm_biu<br>When high, reset relative logic.                                                                              |
| 2     | RO   | 0x0         | reserved                                                                                                                           |
| 1     | RW   | 0x0         | hresetn_pdऱphpmid_biu<br>When high, reset relative logic.                                                                          |
| 0     | RW   | 0x0         | aresetn_pdऱphpmid_biu<br>When high, reset relative logic.                                                                          |

**CRU SOFTRST 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    | RO   | 0x0         | reserved                                                                                                                           |
| 14    | RW   | 0x0         | aresetn_gmac_req<br>When high, reset relative logic.                                                                               |
| 13    | RW   | 0x0         | presetn_pdऱmac_biu<br>When high, reset relative logic.                                                                             |
| 12    | RW   | 0x0         | aresetn_pdऱmac_biu<br>When high, reset relative logic.                                                                             |
| 11:10 | RO   | 0x0         | reserved                                                                                                                           |
| 9     | RW   | 0x0         | resetn_usbphyor_host<br>When high, reset relative logic.                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 8          | RW          | 0x0                | resetn_usbphyor_otg<br>When high, reset relative logic. |
| 7          | RW          | 0x0                | preseth_usbphy_host<br>When high, reset relative logic. |
| 6          | RW          | 0x0                | preseth_usbphy_otg<br>When high, reset relative logic.  |
| 5          | RW          | 0x0                | aresetn_usbotg<br>When high, reset relative logic.      |
| 4          | RW          | 0x0                | resetn_usbhost_utmi<br>When high, reset relative logic. |
| 3          | RW          | 0x0                | hresetn_usbhost_arb<br>When high, reset relative logic. |
| 2          | RW          | 0x0                | hresetn_usbhost<br>When high, reset relative logic.     |
| 1          | RW          | 0x0                | hresetn_pdusb_biu<br>When high, reset relative logic.   |
| 0          | RW          | 0x0                | aresetn_pdusb_biu<br>When high, reset relative logic.   |

**CRU SOFTRST CON12**

Address: Operational Base + offset (0x0330)

| <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_ddrphy<br>When high, reset relative logic.                                                                                  |
| 14         | RW          | 0x0                | preseth_ddrphy<br>When high, reset relative logic.                                                                                 |
| 13         | RW          | 0x0                | resetn_npumcu_biu<br>When high, reset relative logic.                                                                              |
| 12         | RO          | 0x1                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | resetn_ddr_standby<br>When high, reset relative logic.                                                                             |
| 10         | RW          | 0x0                | resetn_ddr_dfictl<br>When high, reset relative logic.                                                                              |
| 9:8        | RO          | 0x0                | reserved                                                                                                                           |
| 7          | RW          | 0x0                | resetn_ddr_msch<br>When high, reset relative logic.                                                                                |
| 6          | RW          | 0x0                | aresetn_ddr_split<br>When high, reset relative logic.                                                                              |
| 5          | RW          | 0x0                | preseth_ddr_msch<br>When high, reset relative logic.                                                                               |
| 4          | RW          | 0x0                | preseth_ddr_grf<br>When high, reset relative logic.                                                                                |
| 3          | RW          | 0x0                | preseth_ddr_standby<br>When high, reset relative logic.                                                                            |
| 2          | RW          | 0x0                | preseth_ddr_mon<br>When high, reset relative logic.                                                                                |
| 1          | RW          | 0x0                | preseth_ddr_dfictl<br>When high, reset relative logic.                                                                             |
| 0          | RO          | 0x0                | reserved                                                                                                                           |

**CRU SOFTRST 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         | RW          | 0x0                | rxpresetn_ciflite<br>When high, reset relative logic.                                                                              |
| 14         | RW          | 0x0                | dresetn_ciflite<br>When high, reset relative logic.                                                                                |
| 13         | RW          | 0x0                | hresetn_ciflite<br>When high, reset relative logic.                                                                                |
| 12         | RW          | 0x0                | aresetn_ciflite<br>When high, reset relative logic.                                                                                |
| 11         | RO          | 0x0                | reserved                                                                                                                           |
| 10         | RW          | 0x0                | resetn_npu_tsadcphy<br>When high, reset relative logic.                                                                            |
| 9          | RW          | 0x0                | resetn_npu_tsadc<br>When high, reset relative logic.                                                                               |
| 8          | RW          | 0x0                | presetn_npu_tsadc<br>When high, reset relative logic.                                                                              |
| 7          | RW          | 0x0                | resetn_npupvtm<br>When high, reset relative logic.                                                                                 |
| 6          | RW          | 0x0                | presetn_npupvtm<br>When high, reset relative logic.                                                                                |
| 5          | RW          | 0x0                | resetn_npu<br>When high, reset relative logic.                                                                                     |
| 4          | RW          | 0x0                | hresetn_npu<br>When high, reset relative logic.                                                                                    |
| 3          | RW          | 0x0                | aresetn_npu<br>When high, reset relative logic.                                                                                    |
| 2          | RW          | 0x0                | presetn_pdnpnu_biu<br>When high, reset relative logic.                                                                             |
| 1          | RW          | 0x0                | hresetn_pdnpnu_biu<br>When high, reset relative logic.                                                                             |
| 0          | RW          | 0x0                | aresetn_pdnpnu_biu<br>When high, reset relative logic.                                                                             |

**CRU SOFTRST CON14**

Address: Operational Base + offset (0x0338)

| <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                | resetn_cpupvtm<br>When high, reset relative logic.                                                                                 |
| 11         | RW          | 0x0                | presetn_cpupvtm<br>When high, reset relative logic.                                                                                |
| 10         | RW          | 0x0                | resetn_cpu_tsadcphy<br>When high, reset relative logic.                                                                            |
| 9          | RW          | 0x0                | resetn_cpu_tsadc<br>When high, reset relative logic.                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 8          | RW          | 0x0                | presetn_cpu_tsadc<br>When high, reset relative logic. |
| 7          | RO          | 0x0                | reserved                                              |
| 6          | RW          | 0x0                | presetn_dsiphy<br>When high, reset relative logic.    |
| 5          | RW          | 0x0                | presetn_csiphy1<br>When high, reset relative logic.   |
| 4          | RW          | 0x0                | presetn_csiphy0<br>When high, reset relative logic.   |
| 3          | RW          | 0x0                | presetn_cpuemadet<br>When high, reset relative logic. |
| 2          | RW          | 0x0                | presetn_topgrf<br>When high, reset relative logic.    |
| 1          | RW          | 0x0                | presetn_topcru<br>When high, reset relative logic.    |
| 0          | RW          | 0x0                | presetn_topbiu<br>When high, reset relative logic.    |

**CRU SSCGTBL CON0**

Address: Operational Base + offset (0x0380)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl3<br>External wave table 3 |
| 23:16      | RW          | 0x00               | ssgtbl2<br>External wave table 2 |
| 15:8       | RW          | 0x00               | ssgtbl1<br>External wave table 1 |
| 7:0        | RW          | 0x00               | ssgtbl0<br>External wave table 0 |

**CRU SSCGTBL CON1**

Address: Operational Base + offset (0x0384)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------|-------------|--------------------|----------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl7<br>External wave table 7 |
| 23:16      | RW          | 0x00               | ssgtbl6<br>External wave table 6 |
| 15:8       | RW          | 0x00               | ssgtbl5<br>External wave table 5 |
| 7:0        | RW          | 0x00               | ssgtbl4<br>External wave table 4 |

**CRU SSCGTBL CON2**

Address: Operational Base + offset (0x0388)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl11<br>External wave table 11 |
| 23:16      | RW          | 0x00               | ssgtbl10<br>External wave table 10 |
| 15:8       | RW          | 0x00               | ssgtbl9<br>External wave table 9   |
| 7:0        | RW          | 0x00               | ssgtbl8<br>External wave table 8   |

**CRU SSCGTBL CON3**

Address: Operational Base + offset (0x038C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl15<br>External wave table 15 |
| 23:16      | RW          | 0x00               | ssgtbl14<br>External wave table 14 |
| 15:8       | RW          | 0x00               | ssgtbl13<br>External wave table 13 |
| 7:0        | RW          | 0x00               | ssgtbl12<br>External wave table 12 |

**CRU SSCGTBL CON4**

Address: Operational Base + offset (0x0390)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl19<br>External wave table 19 |
| 23:16      | RW          | 0x00               | ssgtbl18<br>External wave table 18 |
| 15:8       | RW          | 0x00               | ssgtbl17<br>External wave table 17 |
| 7:0        | RW          | 0x00               | ssgtbl16<br>External wave table 16 |

**CRU SSCGTBL CON5**

Address: Operational Base + offset (0x0394)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl23<br>External wave table 23 |
| 23:16      | RW          | 0x00               | ssgtbl22<br>External wave table 22 |
| 15:8       | RW          | 0x00               | ssgtbl21<br>External wave table 21 |
| 7:0        | RW          | 0x00               | ssgtbl20<br>External wave table 20 |

**CRU SSCGTBL CON6**

Address: Operational Base + offset (0x0398)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl27<br>External wave table 27 |
| 23:16      | RW          | 0x00               | ssgtbl26<br>External wave table 26 |
| 15:8       | RW          | 0x00               | ssgtbl25<br>External wave table 25 |
| 7:0        | RW          | 0x00               | ssgtbl24<br>External wave table 24 |

**CRU SSCGTBL CON7**

Address: Operational Base + offset (0x039C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl31<br>External wave table 31 |
| 23:16      | RW          | 0x00               | ssgtbl30<br>External wave table 30 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 15:8       | RW          | 0x00               | ssgtbl29<br>External wave table 29 |
| 7:0        | RW          | 0x00               | ssgtbl28<br>External wave table 28 |

**CRU SSCGTBL CON8**

Address: Operational Base + offset (0x03A0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl35<br>External wave table 35 |
| 23:16      | RW          | 0x00               | ssgtbl34<br>External wave table 34 |
| 15:8       | RW          | 0x00               | ssgtbl33<br>External wave table 33 |
| 7:0        | RW          | 0x00               | ssgtbl32<br>External wave table 32 |

**CRU SSCGTBL CON9**

Address: Operational Base + offset (0x03A4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl39<br>External wave table 39 |
| 23:16      | RW          | 0x00               | ssgtbl38<br>External wave table 38 |
| 15:8       | RW          | 0x00               | ssgtbl37<br>External wave table 37 |
| 7:0        | RW          | 0x00               | ssgtbl36<br>External wave table 36 |

**CRU SSCGTBL CON10**

Address: Operational Base + offset (0x03A8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl43<br>External wave table 43 |
| 23:16      | RW          | 0x00               | ssgtbl42<br>External wave table 42 |
| 15:8       | RW          | 0x00               | ssgtbl41<br>External wave table 41 |
| 7:0        | RW          | 0x00               | ssgtbl40<br>External wave table 40 |

**CRU SSCGTBL CON11**

Address: Operational Base + offset (0x03AC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl47<br>External wave table 47 |
| 23:16      | RW          | 0x00               | ssgtbl46<br>External wave table 46 |
| 15:8       | RW          | 0x00               | ssgtbl45<br>External wave table 45 |
| 7:0        | RW          | 0x00               | ssgtbl44<br>External wave table 44 |

**CRU SSCGTBL CON12**

Address: Operational Base + offset (0x03B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl51<br>External wave table 51 |
| 23:16      | RW          | 0x00               | ssgtbl50<br>External wave table 50 |
| 15:8       | RW          | 0x00               | ssgtbl49<br>External wave table 49 |
| 7:0        | RW          | 0x00               | ssgtbl48<br>External wave table 48 |

**CRU SSCGTBL CON13**

Address: Operational Base + offset (0x03B4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl55<br>External wave table 55 |
| 23:16      | RW          | 0x00               | ssgtbl54<br>External wave table 54 |
| 15:8       | RW          | 0x00               | ssgtbl53<br>External wave table 53 |
| 7:0        | RW          | 0x00               | ssgtbl52<br>External wave table 52 |

**CRU SSCGTBL CON14**

Address: Operational Base + offset (0x03B8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl59<br>External wave table 59 |
| 23:16      | RW          | 0x00               | ssgtbl58<br>External wave table 58 |
| 15:8       | RW          | 0x00               | ssgtbl57<br>External wave table 57 |
| 7:0        | RW          | 0x00               | ssgtbl56<br>External wave table 56 |

**CRU SSCGTBL CON15**

Address: Operational Base + offset (0x03BC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl63<br>External wave table 63 |
| 23:16      | RW          | 0x00               | ssgtbl62<br>External wave table 62 |
| 15:8       | RW          | 0x00               | ssgtbl61<br>External wave table 61 |
| 7:0        | RW          | 0x00               | ssgtbl60<br>External wave table 60 |

**CRU SSCGTBL CON16**

Address: Operational Base + offset (0x03C0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl67<br>External wave table 67 |
| 23:16      | RW          | 0x00               | ssgtbl66<br>External wave table 66 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 15:8       | RW          | 0x00               | ssgtbl65<br>External wave table 65 |
| 7:0        | RW          | 0x00               | ssgtbl64<br>External wave table 64 |

**CRU SSCGTBL CON17**

Address: Operational Base + offset (0x03C4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl71<br>External wave table 71 |
| 23:16      | RW          | 0x00               | ssgtbl70<br>External wave table 70 |
| 15:8       | RW          | 0x00               | ssgtbl69<br>External wave table 69 |
| 7:0        | RW          | 0x00               | ssgtbl68<br>External wave table 68 |

**CRU SSCGTBL CON18**

Address: Operational Base + offset (0x03C8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl75<br>External wave table 75 |
| 23:16      | RW          | 0x00               | ssgtbl74<br>External wave table 74 |
| 15:8       | RW          | 0x00               | ssgtbl73<br>External wave table 73 |
| 7:0        | RW          | 0x00               | ssgtbl72<br>External wave table 72 |

**CRU SSCGTBL CON19**

Address: Operational Base + offset (0x03CC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl79<br>External wave table 79 |
| 23:16      | RW          | 0x00               | ssgtbl78<br>External wave table 78 |
| 15:8       | RW          | 0x00               | ssgtbl77<br>External wave table 77 |
| 7:0        | RW          | 0x00               | ssgtbl76<br>External wave table 76 |

**CRU SSCGTBL CON20**

Address: Operational Base + offset (0x03D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl83<br>External wave table 83 |
| 23:16      | RW          | 0x00               | ssgtbl82<br>External wave table 82 |
| 15:8       | RW          | 0x00               | ssgtbl81<br>External wave table 81 |
| 7:0        | RW          | 0x00               | ssgtbl80<br>External wave table 80 |

**CRU SSCGTBL CON21**

Address: Operational Base + offset (0x03D4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl87<br>External wave table 87 |
| 23:16      | RW          | 0x00               | ssgtbl86<br>External wave table 86 |
| 15:8       | RW          | 0x00               | ssgtbl85<br>External wave table 85 |
| 7:0        | RW          | 0x00               | ssgtbl84<br>External wave table 84 |

**CRU SSCGTBL CON22**

Address: Operational Base + offset (0x03D8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl91<br>External wave table 91 |
| 23:16      | RW          | 0x00               | ssgtbl90<br>External wave table 90 |
| 15:8       | RW          | 0x00               | ssgtbl89<br>External wave table 89 |
| 7:0        | RW          | 0x00               | ssgtbl88<br>External wave table 88 |

**CRU SSCGTBL CON23**

Address: Operational Base + offset (0x03DC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl95<br>External wave table 95 |
| 23:16      | RW          | 0x00               | ssgtbl94<br>External wave table 94 |
| 15:8       | RW          | 0x00               | ssgtbl93<br>External wave table 93 |
| 7:0        | RW          | 0x00               | ssgtbl92<br>External wave table 92 |

**CRU SSCGTBL CON24**

Address: Operational Base + offset (0x03E0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl99<br>External wave table 99 |
| 23:16      | RW          | 0x00               | ssgtbl98<br>External wave table 98 |
| 15:8       | RW          | 0x00               | ssgtbl97<br>External wave table 97 |
| 7:0        | RW          | 0x00               | ssgtbl96<br>External wave table 96 |

**CRU SSCGTBL CON25**

Address: Operational Base + offset (0x03E4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl103<br>External wave table 103 |
| 23:16      | RW          | 0x00               | ssgtbl102<br>External wave table 102 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 15:8       | RW          | 0x00               | ssgtbl101<br>External wave table 101 |
| 7:0        | RW          | 0x00               | ssgtbl100<br>External wave table 100 |

**CRU SSCGTBL CON26**

Address: Operational Base + offset (0x03E8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl107<br>External wave table 107 |
| 23:16      | RW          | 0x00               | ssgtbl106<br>External wave table 106 |
| 15:8       | RW          | 0x00               | ssgtbl105<br>External wave table 105 |
| 7:0        | RW          | 0x00               | ssgtbl104<br>External wave table 104 |

**CRU SSCGTBL CON27**

Address: Operational Base + offset (0x03EC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl111<br>External wave table 111 |
| 23:16      | RW          | 0x00               | ssgtbl110<br>External wave table 110 |
| 15:8       | RW          | 0x00               | ssgtbl109<br>External wave table 109 |
| 7:0        | RW          | 0x00               | ssgtbl108<br>External wave table 108 |

**CRU SSCGTBL CON28**

Address: Operational Base + offset (0x03F0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl115<br>External wave table 115 |
| 23:16      | RW          | 0x00               | ssgtbl114<br>External wave table 114 |
| 15:8       | RW          | 0x00               | ssgtbl113<br>External wave table 113 |
| 7:0        | RW          | 0x00               | ssgtbl112<br>External wave table 112 |

**CRU SSCGTBL CON29**

Address: Operational Base + offset (0x03F4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl119<br>External wave table 119 |
| 23:16      | RW          | 0x00               | ssgtbl118<br>External wave table 118 |
| 15:8       | RW          | 0x00               | ssgtbl117<br>External wave table 117 |
| 7:0        | RW          | 0x00               | ssgtbl116<br>External wave table 116 |

**CRU SSCGTBL CON30**

Address: Operational Base + offset (0x03F8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl123<br>External wave table 123 |
| 23:16      | RW          | 0x00               | ssgtbl122<br>External wave table 122 |
| 15:8       | RW          | 0x00               | ssgtbl121<br>External wave table 121 |
| 7:0        | RW          | 0x00               | ssgtbl120<br>External wave table 120 |

**CRU SSCGTBL CON31**

Address: Operational Base + offset (0x03FC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:24      | RW          | 0x00               | ssgtbl127<br>External wave table 127 |
| 23:16      | RW          | 0x00               | ssgtbl126<br>External wave table 126 |
| 15:8       | RW          | 0x00               | ssgtbl125<br>External wave table 125 |
| 7:0        | RW          | 0x00               | ssgtbl124<br>External wave table 124 |

**CRU GLB CNT TH**

Address: Operational Base + offset (0x0400)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00640064         | 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 (0x0404)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                                                                            |
| 6          | RW          | 0x0                | wdt_rst_pos<br>WDT reset flag.<br>1'b0: WDT reset inactive<br>1'b1: WDT reset active                                                                                                                |
| 5          | RW          | 0x0                | snd_glb_wdt_RST_st<br>Second global WDT triggered reset flag.<br>1'b0: Last hot reset is not second global WDT triggered reset<br>1'b1: Last hot reset is second 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>Second global TSADC triggered reset flag.<br>1'b0: Last hot reset is not second global TSADC triggered reset<br>1'b1: Last hot reset is second 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    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | snd_glb_RST_ST<br>Second global rst flag.<br>1'b0: Last hot reset is not second global reset<br>1'b1: Last hot reset is second 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 VALUE**

Address: Operational Base + offset (0x0408)

| <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_value<br>Global software reset first value |

**CRU GLB SRST SND VALUE**

Address: Operational Base + offset (0x040C)

| <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_value<br>Global software reset second value |

**CRU GLB RST CON**

Address: Operational Base + offset (0x0410)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                                                                                                |
| 12         | RW          | 0x0                | cru_wdt_con<br>WDT reset selection.<br>1'b0: Second reset<br>1'b1: First reset                                          |
| 11:9       | RO          | 0x0                | reserved                                                                                                                |
| 8          | RW          | 0x0                | cru_wdt_en<br>1'b0: Disable WDT reset<br>1'b1: Enable WDT reset                                                         |
| 7:5        | RO          | 0x0                | reserved                                                                                                                |
| 4          | RW          | 0x0                | pmu_srst_wdt_rst_en<br>1'b0: Enable WDT reset as PMU reset source<br>1'b1: Disable WDT reset as PMU reset source        |
| 3          | RW          | 0x0                | pmu_srst_glb_srst_en<br>1'b0: Enable global reset as PMU reset source<br>1'b1: Disable global reset as PMU reset source |
| 2          | RW          | 0x0                | pmu_srst_glb_srst_sel<br>1'b0: First global reset as PMU reset source<br>1'b1: Second global reset as PMU reset source  |
| 1          | RO          | 0x0                | reserved                                                                                                                |
| 0          | RW          | 0x0                | tsadc_glb_srst_ctrl<br>1'b0: TSADC trigger second global reset<br>1'b1: TSADC trigger first global reset                |

**CRU SDMMC CON0**

Address: Operational Base + offset (0x0440)

| <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                | drv_sel<br>Driver clock source selection.<br>1'b0: Use clock after phase shift<br>1'b1: Use clock after phase shift and delay line |
| 10:3       | RW          | 0x00               | drv_delaynum<br>Element number in delay line for driver clock                                                                      |
| 2:1        | RW          | 0x2                | drv_degree<br>Phase shift for driver clock.<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, high active                                                                      |

**CRU SDMMC CON1**

Address: Operational Base + offset (0x0444)

| <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                | smp_sel<br>Sample clock source selection.<br>1'b0: Use clock after phase shift<br>1'b1: Use clock after phase shift and delay line |
| 10:3       | RW          | 0x00               | smp_delaynum<br>Element number in delay line for sample clock                                                                      |
| 2:1        | RW          | 0x2                | smp_degree<br>Phase shift for sample clock.<br>2'b00: 0 degree<br>2'b01: 90 degree<br>2'b10: 180 degree<br>2'b11: 270 degree       |
| 0          | RO          | 0x0                | reserved                                                                                                                           |

**CRU SDIO CON0**

Address: Operational Base + offset (0x0448)

| <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                | drv_sel<br>Driver clock source selection.<br>1'b0: Use clock after phase shift<br>1'b1: Use clock after phase shift and delay line |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 10:3       | RW          | 0x00               | drv_delaynum<br>Element number in delay line for driver clock                                                                |
| 2:1        | RW          | 0x2                | drv_degree<br>Phase shift for driver clock.<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, high active                                                                |

**CRU SDIO CON1**

Address: Operational Base + offset (0x044C)

| <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                | smp_sel<br>Sample clock source selection.<br>1'b0: Use clock after phase shift<br>1'b1: Use clock after phase shift and delay line |
| 10:3       | RW          | 0x00               | smp_delaynum<br>Element number in delay line for sample clock                                                                      |
| 2:1        | RW          | 0x2                | smp_degree<br>Phase shift for sample clock.<br>2'b00: 0 degree<br>2'b01: 90 degree<br>2'b10: 180 degree<br>2'b11: 270 degree       |
| 0          | RO          | 0x0                | reserved                                                                                                                           |

**CRU EMMC CON0**

Address: Operational Base + offset (0x0450)

| <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                | drv_sel<br>Driver clock source selection.<br>1'b0: Use clock after phase shift<br>1'b1: Use clock after phase shift and delay line |
| 10:3       | RW          | 0x00               | drv_delaynum<br>Element number in delay line for driver clock                                                                      |
| 2:1        | RW          | 0x2                | drv_degree<br>Phase shift for driver clock.<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, high active                                                                      |

**CRU EMMC CON1**

Address: Operational Base + offset (0x0454)

| 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         | smp_sel<br>Sample clock source selection.<br>1'b0: Use clock after phase shift<br>1'b1: Use clock after phase shift and delay line |
| 10:3  | RW   | 0x00        | smp_delaynum<br>Element number in delay line for sample clock                                                                      |
| 2:1   | RW   | 0x2         | smp_degree<br>Phase shift for sample clock.<br>2'b00: 0 degree<br>2'b01: 90 degree<br>2'b10: 180 degree<br>2'b11: 270 degree       |
| 0     | RO   | 0x0         | reserved                                                                                                                           |

**CRU GMAC CON**

Address: Operational Base + offset (0x0460)

| 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:6  | RO   | 0x000       | reserved                                                                                                                                  |
| 5     | RW   | 0x0         | ext_sel_m1<br>GMAC RMII clock source selection 1.<br>1'b0: From PLL<br>1'b1: From GPIO2B7                                                 |
| 4     | RW   | 0x0         | rmii_mode<br>RMII mode selection.<br>1'b0: RGMII mode<br>1'b1: RMII mode                                                                  |
| 3:2   | RW   | 0x0         | mii_txclk_sel<br>MII TX clock selection.<br>2'b10: clk_gmac_src divided by 50<br>2'b11: clk_gmac_src divided by 5<br>Others: clk_gmac_src |
| 1     | RW   | 0x0         | rmii_clk_sel<br>RMII clock selection.<br>1'b0: clk_gmac_src divided by 20<br>1'b1: clk_gmac_src divided by 2                              |
| 0     | RW   | 0x0         | ext_sel_m0<br>GMAC RMII clock source selection 0.<br>1'b0: From PLL<br>1'b1: From GPIO3C0                                                 |

**CRU MISC CON0**

Address: Operational Base + offset (0x0464)

| <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                | dis_pd_sdio_dwn_clk_en<br>Disable pd_sdio_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable         |
| 13         | RO          | 0x0                | reserved                                                                                                                           |
| 12         | RW          | 0x0                | dis_pd_crypt_dwn_clk_en<br>Disable pd_crypt_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable       |
| 11         | RO          | 0x0                | reserved                                                                                                                           |
| 10         | RW          | 0x0                | dis_pd_usb_dwn_clk_en<br>Disable pd_usb_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable           |
| 9          | RW          | 0x0                | dis_pd_nvm_dwn_clk_en<br>Disable pd_nvm_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable           |
| 8          | RO          | 0x0                | reserved                                                                                                                           |
| 7          | RW          | 0x0                | dis_pd_npu_dwn_clk_en<br>Disable pd_npu_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable           |
| 6          | RW          | 0x0                | dis_pd_vdpu_dwn_clk_en<br>Disable pd_vdpu_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable         |
| 5          | RW          | 0x0                | dis_pd_vepu_dwn_clk_en<br>Disable pd_vepu_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable         |
| 4          | RW          | 0x0                | dis_pd_ispp_dwn_clk_en<br>Disable pd_ispp_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable         |
| 3          | RW          | 0x0                | dis_pd_vo_dwn_clk_en<br>Disable pd_vo_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable             |
| 2          | RW          | 0x0                | dis_pd_vi_dwn_clk_en<br>Disable pd_vi_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable             |
| 1          | RW          | 0x0                | dis_pd_ddr_dwn_clk_en<br>Disable pd_ddr_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | dis_pd_core_dwn_clk_en<br>Disable pd_core_dwn_clk_en, i.e. clocks cannot be gated by PMU.<br>1'b0: Enable<br>1'b1: Disable |

**CRU\_MISC\_CON1**

Address: Operational Base + offset (0x0468)

| <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          | RW          | 0x0                | corepo_srst_wfien<br>CPU power-on reset enable when CPU is in WFI state.<br>1'b0: Disable<br>1'b1: Enable                          |
| 8          | RW          | 0x0                | core_srst_wfien<br>CPU reset enable when CPU is in WFI state.<br>1'b0: Disable<br>1'b1: Enable                                     |
| 7:0        | RO          | 0x00               | reserved                                                                                                                           |

## 5.6 Application Notes

### 5.6.1 PLL Usage

#### 5.6.1.1 PLL Frequency Configuration

FBDIV, POSTDIV1, BYPASS can be configured by programming CRU\_xPLL\_CON0.

DSMPD, REFIDIV, POSTDIV2 can be configured by programming CRU\_xPLL\_CON1.

FRAC can be configured by programming CRU\_xPLL\_CON2.(x=A,D,C,H,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:

$$\text{DSMPD} = 1$$

$$\text{REFDIV} = 6$$

$$\text{FBDIV} = 175$$

$$\text{POSTDIV1}=1$$

$$\text{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}))$$

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

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

$$\text{DSMPD} = 0$$

$$\text{REFDIV} = 1$$

$$\text{FBDIV} = 40$$

$$\text{FRAC} = 24'hf5c28f$$

$$\text{POSTDIV1}=2$$

$$\text{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.

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

### 5.6.1.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=A,D,C,H,G) register. The lock state is high when both original hardware PLL lock and PLL counter lock are high.

The max delay time is 1000\*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 256 FREF / 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 256\*REFDIV/FREF.

### 5.6.2 PLL Offset Calibration Usage Options

Multiple usage options are available for offset calibration. All options result in systematic period jitter contribution below noise floor.

Following parameters can be configured by programming CRU\_xPLL\_CON5 and CRU\_xPLL\_CON6.

CALBYPASS: CRU\_xPLL\_CON5[1]

CALEN : CRU\_xPLL\_CON5[2]  
FASTCAL : CRU\_xPLL\_CON5[3]  
CALIN : CRU\_xPLL\_CON5[15:4]  
CALCNT : CRU\_xPLL\_CON6[2:0]

The status can be monitored in CRU\_xPLL\_OFFSETCAL\_STATUS.

CALOUT : CRU\_xPLL\_OFFSETCAL\_STATUS[11:0]

CALLOCK : CRU\_xPLL\_OFFSETCAL\_STATUS[16]

### **5.6.2.1 Option 1: CALOUT Permanently Stored**

- 1) Set CALCNT with legal value, set CALEN =1, enable PLL, start calibration.
- 2) Store CALOUT after CALLOCK goes high, then disable PLL.
- 3) Preset CALIN to stored value and set CALBYPASS=1 for the remainder of life time. And enable PLL.
- 4) PLL clock is valid when PLLLOCK goes high.

### **5.6.2.2 Option 2: CALOUT Not Stored**

In many cases, it is impossible or impractical to store the CALOUT value. In such a case, the calibration can be initialized from CALIN=0, and run constantly in the background.

- 1) It is recommended to run the offset calibration constantly.
- 2) Set FASTCAL=1. PLL clock is valid after  $32 * 2^{(5+CALCNT)} * PFD$  cycles.

## **5.6.3 Divider Usage**

CRU supports multi-dividers for different clock requirement.

- Divider free divider
- Fractional divider
- Divfree50 divider
- DivfreeNP5 divider

### **5.6.3.1 Fractional Divider Usage**

To get specific frequency, clocks of I2S, audiOPWM, UART, VOP, CIFOUT, MIPICSI can be generated by fractional divider. Generally you should set that denominator 20 times larger than numerator to generate precise clock frequency. So the fractional divider applies only to generate low frequency clock. For implementation issue, the input source clocks of fractional divider should limit to less than 1200MHz, except MIPICSI with the input source clock of fractional divider less than 400MHz.

### **5.6.3.2 Divfree50 Divider Usage**

Some modules like PDM, EMMC, SDIO, SDMMC, FSPI and NANDC need clock of 50% duty cycle, divfree50 can generate clock of 50% duty cycle even in odd value divisor.

### **5.6.3.3 DivFreeNP5 Divider Usage**

Some modules like NPU, ISPP and ISP need some special frequency can use this divider.

Frequency of this divider= $clk\_src / ((2*n+1)/2)$ .

## **5.6.4 Global Software Reset**

Two global software resets are designed in RV1109/RV1126, you can program CRU\_GLB\_SRST\_FST\_VALUE[15:0] as 0xfdb9 to assert the first global software reset glb\_srstn\_1 and program CRU\_GLB\_SRST\_SND\_VALUE[15:0] as 0xecfa8 to assert the second global software reset glb\_srstn\_2. These two software resets are self-de-asserted by hardware. Resetting hold timing of global software reset (glb\_srstn\_1, glb\_srstn\_2, wdt\_rstn, tsadc\_rstn) can be programmed up to 1ms.

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.

## **5.6.5 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 a system requiring a clock with low long-term jitter. When SSCG is used, the PLL should be configured to fractional mode firstly for spread spectrum capability.

### **5.6.5.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 / (Point number\*REFDIV\*ssmod\_divval). The FMOD is typically set above 32KHz and below the maximum frequency for modulation fidelity, which is determined by the PLL bandwidth. The maximum modulation frequency is conservatively set at FREF/(200\*REFDIV).

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

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

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

## Chapter 6 General Register Files (GRF)

### 6.1 Overview

The general register file will be used to do static setting by software, which is composed of many registers for system control. The GRF is located at several addresses.

- GRF, used for general system, with base address 0xFE000000.
- PMUGRF, used for always on system, with base address 0xFE020000.
- DDRGRF, used for DDR system, with base address 0xFE030000.

### 6.2 Function Description

The function of general register file is:

- GPIO IOMUX control
- GPIO PAD pull down and pull up control
- Common system control
- Record the system state

### 6.3 GRF Register Description

#### 6.3.1 Registers Summary

| Name                | Offset | Size | Reset Value | Description                                   |
|---------------------|--------|------|-------------|-----------------------------------------------|
| GRF SOC CON0        | 0x0000 | W    | 0x00000000  | System control register 0                     |
| GRF SOC CON1        | 0x0004 | W    | 0x00000000  | System control register 1                     |
| GRF SOC CON2        | 0x0008 | W    | 0x00000000  | System control register 2                     |
| GRF SOC STATUS0     | 0x0010 | W    | 0x00380400  | System status register 0                      |
| GRF SOC STATUS1     | 0x0014 | W    | 0x00000000  | System status register 1                      |
| GRF CPU CON0        | 0x0020 | W    | 0x00000C0F  | CPU control register 0                        |
| GRF CPU CON1        | 0x0024 | W    | 0x00000000  | CPU control register 1                        |
| GRF CPU STATUS0     | 0x0030 | W    | 0x0000C0F0  | CPU status register 0                         |
| GRF INTCONNEN CON0  | 0x0040 | W    | 0x00000000  | System internal connection control register 0 |
| GRF INTCONNEN CON1  | 0x0044 | W    | 0x00000000  | System internal connection control register 1 |
| GRF INTCONNEN CON2  | 0x0048 | W    | 0x00000000  | System internal connection control register 2 |
| GRF INTCONNEN CON3  | 0x004C | W    | 0x00000000  | System internal connection control register 3 |
| GRF USBHOST CON0    | 0x0050 | W    | 0x00000820  | USBHOST control register 0                    |
| GRF USBHOST CON1    | 0x0054 | W    | 0x000004BC  | USBHOST control register 1                    |
| GRF USBHOST STATUS0 | 0x0058 | W    | 0x00000000  | USBHOST status register 0                     |
| GRF USBOTG CON0     | 0x005C | W    | 0x00002000  | USBOTG control register 0                     |
| GRF USBOTG CON1     | 0x0060 | W    | 0x00000100  | USBOTG control register 1                     |
| GRF USBOTG STATUS0  | 0x0064 | W    | 0x00000000  | USBOTG status register 0                      |
| GRF USBOTG STATUS1  | 0x0068 | W    | 0x00000000  | USBOTG status register 1                      |
| GRF USBOTG STATUS2  | 0x006C | W    | 0x000007E8  | USBOTG status register 2                      |
| GRF MAC CON0        | 0x0070 | W    | 0x00000000  | MAC control register 0                        |
| GRF MAC CON1        | 0x0074 | W    | 0x00000000  | MAC control register 1                        |
| GRF MAC CON2        | 0x0078 | W    | 0x00000000  | MAC control register 2                        |
| GRF MAC STATUS0     | 0x0084 | W    | 0x00000000  | MAC status register 0                         |
| GRF MAC STATUS1     | 0x0088 | W    | 0x00000000  | MAC status register 1                         |
| GRF MAC STATUS2     | 0x008C | W    | 0x00000000  | MAC status register 2                         |
| GRF MEM CON0        | 0x0090 | W    | 0x00000505  | Memory EMA control register 0                 |
| GRF MEM CON1        | 0x0094 | W    | 0x00000505  | Memory EMA control register 1                 |

| Name               | Offset  | Size | Reset Value | Description                             |
|--------------------|---------|------|-------------|-----------------------------------------|
| GRF MEM CON2       | 0x0098  | W    | 0x000000A5  | Memory EMA control register 2           |
| GRF MEM CON3       | 0x009C  | W    | 0x00002805  | Memory EMA control register 3           |
| GRF TSADC CON      | 0x0100  | W    | 0x00000377  | TSADC control register                  |
| GRF CHIP ID        | 0x0110  | W    | 0x00001109  | Chip ID register                        |
| GRF GPIO0C IOMUX_H | 0x10000 | W    | 0x00000000  | GPIO0C high bits IOMUX control register |
| GRF GPIO0D IOMUX_L | 0x10004 | W    | 0x00000000  | GPIO0D low bits IOMUX control register  |
| GRF GPIO0D IOMUX_H | 0x10008 | W    | 0x00000000  | GPIO0D high bits IOMUX control register |
| GRF GPIO1A IOMUX_L | 0x10010 | W    | 0x00000000  | GPIO1A low bits IOMUX control register  |
| GRF GPIO1A IOMUX_H | 0x10014 | W    | 0x00000000  | GPIO1A high bits IOMUX control register |
| GRF GPIO1B IOMUX_L | 0x10018 | W    | 0x00000000  | GPIO1B low bits IOMUX control register  |
| GRF GPIO1B IOMUX_H | 0x1001C | W    | 0x00000000  | GPIO1B high bits IOMUX control register |
| GRF GPIO1C IOMUX_L | 0x10020 | W    | 0x00000000  | GPIO1C low bits IOMUX control register  |
| GRF GPIO1C IOMUX_H | 0x10024 | W    | 0x00000000  | GPIO1C high bits IOMUX control register |
| GRF GPIO1D IOMUX_L | 0x10028 | W    | 0x00000000  | GPIO1D low bits IOMUX control register  |
| GRF GPIO1D IOMUX_H | 0x1002C | W    | 0x00000000  | GPIO1D high bits IOMUX control register |
| GRF GPIO2A IOMUX_L | 0x10030 | W    | 0x00000000  | GPIO2A low bits IOMUX control register  |
| GRF GPIO2A IOMUX_H | 0x10034 | W    | 0x00000000  | GPIO2A high bits IOMUX control register |
| GRF GPIO2B IOMUX_L | 0x10038 | W    | 0x00000000  | GPIO2B low bits IOMUX control register  |
| GRF GPIO2B IOMUX_H | 0x1003C | W    | 0x00000000  | GPIO2B high bits IOMUX control register |
| GRF GPIO2C IOMUX_L | 0x10040 | W    | 0x00000000  | GPIO2C low bits IOMUX control register  |
| GRF GPIO2C IOMUX_H | 0x10044 | W    | 0x00000000  | GPIO2C high bits IOMUX control register |
| GRF GPIO2D IOMUX_L | 0x10048 | W    | 0x00000000  | GPIO2D low bits IOMUX control register  |
| GRF GPIO2D IOMUX_H | 0x1004C | W    | 0x00000000  | GPIO2D high bits IOMUX control register |
| GRF GPIO3A IOMUX_L | 0x10050 | W    | 0x00000000  | GPIO3A low bits IOMUX control register  |
| GRF GPIO3A IOMUX_H | 0x10054 | W    | 0x00000000  | GPIO3A high bits IOMUX control register |
| GRF GPIO3B IOMUX_L | 0x10058 | W    | 0x00000000  | GPIO3B low bits IOMUX control register  |
| GRF GPIO3B IOMUX_H | 0x1005C | W    | 0x00000000  | GPIO3B high bits IOMUX control register |
| GRF GPIO3C IOMUX_L | 0x10060 | W    | 0x00000000  | GPIO3C low bits IOMUX control register  |

| Name               | Offset  | Size | Reset Value | Description                                       |
|--------------------|---------|------|-------------|---------------------------------------------------|
| GRF GPIO3C IOMUX_H | 0x10064 | W    | 0x00000000  | GPIO3C high bits IOMUX control register           |
| GRF GPIO3D IOMUX_L | 0x10068 | W    | 0x00000000  | GPIO3D low bits IOMUX control register            |
| GRF GPIO3D IOMUX_H | 0x1006C | W    | 0x00000000  | GPIO3D high bits IOMUX control register           |
| GRF GPIO4A IOMUX_L | 0x10070 | W    | 0x00000000  | GPIO4A low bits IOMUX control register            |
| GRF GPIO0C DS_H    | 0x10080 | W    | 0x00001111  | GPIO0C high bits driver strength control register |
| GRF GPIO0D DS_L    | 0x10084 | W    | 0x00001111  | GPIO0D low bits driver strength control register  |
| GRF GPIO0D DS_H    | 0x10088 | W    | 0x00002111  | GPIO0D high bits driver strength control register |
| GRF GPIO1A DS_L    | 0x10090 | W    | 0x00002111  | GPIO1A low bits driver strength control register  |
| GRF GPIO1A DS_H    | 0x10094 | W    | 0x00001111  | GPIO1A high bits driver strength control register |
| GRF GPIO1B DS_L    | 0x10098 | W    | 0x00001212  | GPIO1B low bits driver strength control register  |
| GRF GPIO1B DS_H    | 0x1009C | W    | 0x00001111  | GPIO1B high bits driver strength control register |
| GRF GPIO1C DS_L    | 0x100A0 | W    | 0x00001111  | GPIO1C low bits driver strength control register  |
| GRF GPIO1C DS_H    | 0x100A4 | W    | 0x00001111  | GPIO1C high bits driver strength control register |
| GRF GPIO1D DS_L    | 0x100A8 | W    | 0x00001111  | GPIO1D low bits driver strength control register  |
| GRF GPIO1D DS_H    | 0x100AC | W    | 0x00001111  | GPIO1D high bits driver strength control register |
| GRF GPIO2A DS_L    | 0x100B0 | W    | 0x00002211  | GPIO2A low bits driver strength control register  |
| GRF GPIO2A DS_H    | 0x100B4 | W    | 0x00001111  | GPIO2A high bits driver strength control register |
| GRF GPIO2B DS_L    | 0x100B8 | W    | 0x00001111  | GPIO2B low bits driver strength control register  |
| GRF GPIO2B DS_H    | 0x100BC | W    | 0x00001111  | GPIO2B high bits driver strength control register |
| GRF GPIO2C DS_L    | 0x100C0 | W    | 0x00001111  | GPIO2C low bits driver strength control register  |
| GRF GPIO2C DS_H    | 0x100C4 | W    | 0x00001111  | GPIO2C high bits driver strength control register |
| GRF GPIO2D DS_L    | 0x100C8 | W    | 0x00001111  | GPIO2D low bits driver strength control register  |
| GRF GPIO2D DS_H    | 0x100CC | W    | 0x00002111  | GPIO2D high bits driver strength control register |
| GRF GPIO3A DS_L    | 0x100D0 | W    | 0x00001111  | GPIO3A low bits driver strength control register  |
| GRF GPIO3A DS_H    | 0x100D4 | W    | 0x00001111  | GPIO3A high bits driver strength control register |
| GRF GPIO3B DS_L    | 0x100D8 | W    | 0x00001111  | GPIO3B low bits driver strength control register  |

| <b>Name</b>      | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------------|---------------|-------------|--------------------|---------------------------------------------------|
| GRF GPIO3B DS H  | 0x100DC       | W           | 0x00001111         | GPIO3B high bits driver strength control register |
| GRF GPIO3C DS L  | 0x100E0       | W           | 0x00001111         | GPIO3C low bits driver strength control register  |
| GRF GPIO3C DS H  | 0x100E4       | W           | 0x00001111         | GPIO3C high bits driver strength control register |
| GRF GPIO3D DS L  | 0x100E8       | W           | 0x00001111         | GPIO3D low bits driver strength control register  |
| GRF GPIO3D DS H  | 0x100EC       | W           | 0x00001111         | GPIO3D high bits driver strength control register |
| GRF GPIO4A DS L  | 0x100F0       | W           | 0x00000011         | GPIO4A low bits driver strength control register  |
| GRF GPIO0C P H   | 0x10100       | W           | 0x000055AA         | GPIO0C high bits PU/PD control register           |
| GRF GPIO0D P     | 0x10104       | W           | 0x0000A555         | GPIO0D PU/PD control register                     |
| GRF GPIO1A P     | 0x10108       | W           | 0x00005596         | GPIO1A PU/PD control register                     |
| GRF GPIO1B P     | 0x1010C       | W           | 0x00005565         | GPIO1B PU/PD control register                     |
| GRF GPIO1C P     | 0x10110       | W           | 0x0000AA55         | GPIO1C PU/PD control register                     |
| GRF GPIO1D P     | 0x10114       | W           | 0x0000AA5A         | GPIO1D PU/PD control register                     |
| GRF GPIO2A P     | 0x10118       | W           | 0x0000AAAA         | GPIO2A PU/PD control register                     |
| GRF GPIO2B P     | 0x1011C       | W           | 0x0000AAAA         | GPIO2B PU/PD control register                     |
| GRF GPIO2C P     | 0x10120       | W           | 0x0000AAAA         | GPIO2C PU/PD control register                     |
| GRF GPIO2D P     | 0x10124       | W           | 0x0000AAAA         | GPIO2D PU/PD control register                     |
| GRF GPIO3A P     | 0x10128       | W           | 0x0000AA55         | GPIO3A PU/PD control register                     |
| GRF GPIO3B P     | 0x1012C       | W           | 0x0000AAAA         | GPIO3B PU/PD control register                     |
| GRF GPIO3C P     | 0x10130       | W           | 0x0000AAAA         | GPIO3C PU/PD control register                     |
| GRF GPIO3D P     | 0x10134       | W           | 0x0000AAAA         | GPIO3D PU/PD control register                     |
| GRF GPIO4A P     | 0x10138       | W           | 0x0000000A         | GPIO4A PU/PD control register                     |
| GRF GPIO0C IE H  | 0x10140       | W           | 0x000000FF         | GPIO0C high bits IE control register              |
| GRF GPIO0D IE    | 0x10144       | W           | 0x000000FF         | GPIO0D IE control register                        |
| GRF GPIO1A IE    | 0x10148       | W           | 0x000000FF         | GPIO1A IE control register                        |
| GRF GPIO1B IE    | 0x1014C       | W           | 0x000000FF         | GPIO1B IE control register                        |
| GRF GPIO1C IE    | 0x10150       | W           | 0x000000FF         | GPIO1C IE control register                        |
| GRF GPIO1D IE    | 0x10154       | W           | 0x000000FF         | GPIO1D IE control register                        |
| GRF GPIO2A IE    | 0x10158       | W           | 0x000000FF         | GPIO2A IE control register                        |
| GRF GPIO2B IE    | 0x1015C       | W           | 0x000000FF         | GPIO2B IE control register                        |
| GRF GPIO2C IE    | 0x10160       | W           | 0x000000FF         | GPIO2C IE control register                        |
| GRF GPIO2D IE    | 0x10164       | W           | 0x000000FF         | GPIO2D IE control register                        |
| GRF GPIO3A IE    | 0x10168       | W           | 0x000000FF         | GPIO3A IE control register                        |
| GRF GPIO3B IE    | 0x1016C       | W           | 0x000000FF         | GPIO3B IE control register                        |
| GRF GPIO3C IE    | 0x10170       | W           | 0x000000FF         | GPIO3C IE control register                        |
| GRF GPIO3D IE    | 0x10174       | W           | 0x000000FF         | GPIO3D IE control register                        |
| GRF GPIO4A IE    | 0x10178       | W           | 0x000000FF         | GPIO4A IE control register                        |
| GRF GPIO0C SMT H | 0x10180       | W           | 0x00000000         | GPIO0C high bits SMT control register             |
| GRF GPIO0D SMT   | 0x10184       | W           | 0x00000000         | GPIO0D SMT control register                       |
| GRF GPIO1A SMT   | 0x10188       | W           | 0x00000000         | GPIO1A SMT control register                       |
| GRF GPIO1B SMT   | 0x1018C       | W           | 0x00000000         | GPIO1B SMT control register                       |
| GRF GPIO1C SMT   | 0x10190       | W           | 0x00000000         | GPIO1C SMT control register                       |
| GRF GPIO1D SMT   | 0x10194       | W           | 0x00000000         | GPIO1D SMT control register                       |
| GRF GPIO2A SMT   | 0x10198       | W           | 0x00000000         | GPIO2A SMT control register                       |

| Name                       | Offset  | Size | Reset Value | Description                                                |
|----------------------------|---------|------|-------------|------------------------------------------------------------|
| GRF GPIO2B SMT             | 0x1019C | W    | 0x00000000  | GPIO2B SMT control register                                |
| GRF GPIO2C SMT             | 0x101A0 | W    | 0x00000000  | GPIO2C SMT control register                                |
| GRF GPIO2D SMT             | 0x101A4 | W    | 0x00000000  | GPIO2D SMT control register                                |
| GRF GPIO3A SMT             | 0x101A8 | W    | 0x00000000  | GPIO3A SMT control register                                |
| GRF GPIO3B SMT             | 0x101AC | W    | 0x00000000  | GPIO3B SMT control register                                |
| GRF GPIO3C SMT             | 0x101B0 | W    | 0x00000000  | GPIO3C SMT control register                                |
| GRF GPIO3D SMT             | 0x101B4 | W    | 0x00000000  | GPIO3D SMT control register                                |
| GRF GPIO4A SMT             | 0x101B8 | W    | 0x00000000  | GPIO4A SMT control register                                |
| GRF CSIPHY0 CON            | 0x10200 | W    | 0x00000000  | CSIPHY0 control register                                   |
| GRF CSIPHY0 STATUS         | 0x10208 | W    | 0x00000000  | CSIPHY0 status register                                    |
| GRF CSIPHY1 CON            | 0x10210 | W    | 0x00000000  | CSIPHY1 control register                                   |
| GRF CSIPHY1 STATUS         | 0x10218 | W    | 0x00000000  | CSIPHY1 status register                                    |
| GRF DSIPHY CON             | 0x10220 | W    | 0x00000000  | DSIPHY control register                                    |
| GRF USBPHY CON0            | 0x10230 | W    | 0x00008C52  | USBPHY control register 0                                  |
| GRF USBPHY CON1            | 0x10234 | W    | 0x00000080  | USBPHY control register 1                                  |
| GRF USBPHY CON2            | 0x10238 | W    | 0x00000D50  | USBPHY control register 2                                  |
| GRF USBPHY STATUS          | 0x10248 | W    | 0x20082048  | USBPHY status register                                     |
| GRF CIFIO CON              | 0x10250 | W    | 0x00000000  | CIF IO control register                                    |
| GRF SD JTAG SWITCH DLY CNT | 0x10254 | W    | 0x00000000  | JTAG switch delay counter register                         |
| GRF UART2RX LOW CON        | 0x10258 | W    | 0x00000000  | UART2 RX pin filter control register                       |
| GRF IOFUNC CON0            | 0x10260 | W    | 0x00000000  | IO function control register 0                             |
| GRF IOFUNC CON1            | 0x10264 | W    | 0x00000000  | IO function control register 1                             |
| GRF IOFUNC CON2            | 0x10268 | W    | 0x00000000  | IO function control register 2                             |
| GRF IOFUNC CON3            | 0x1026C | W    | 0x00000010  | IO function control register 3                             |
| GRF USBPHY0 CFG CON        | 0x10270 | W    | 0x00000004  | USBPHY0 APB configuration control register                 |
| GRF USBPHY0 CFG ADD RIN    | 0x10274 | W    | 0x00000000  | USBPHY0 APB configuration address register                 |
| GRF USBPHY0 CFG ADD ROUT   | 0x10278 | W    | 0x00000000  | USBPHY0 APB configuration address status register          |
| GRF USBPHY0 CFG DLY CON    | 0x1027C | W    | 0x00000000  | USBPHY0 APB configuration interface delay control register |
| GRF USBPHY1 CFG CON        | 0x10280 | W    | 0x00000004  | USBPHY1 APB configuration control register                 |
| GRF USBPHY1 CFG ADD RIN    | 0x10284 | W    | 0x00000000  | USBPHY1 APB configuration address register                 |
| GRF USBPHY1 CFG ADD ROUT   | 0x10288 | W    | 0x00000000  | USBPHY1 APB configuration address status register          |
| GRF USBPHY1 CFG DLY CON    | 0x1028C | W    | 0x00000000  | USBPHY1 APB configuration interface delay control register |
| GRF USB SIG DETECT C ON    | 0x10300 | W    | 0x00000000  | USB detection control register                             |
| GRF USB SIG DETECT S TATUS | 0x10304 | W    | 0x00000000  | USB detection status register                              |
| GRF USB SIG DETECT C LR    | 0x10308 | W    | 0x00000000  | USB detection clear register                               |
| GRF USB LINESTATE CO N     | 0x10310 | W    | 0x00030100  | USB linestate control register                             |
| GRF USB DISCONNECT CON     | 0x10314 | W    | 0x00030100  | USB disconnect control register                            |
| GRF USB BVALID CON         | 0x10318 | W    | 0x00030100  | USBPHY bvalid control register                             |

| Name           | Offset  | Size | Reset Value | Description                |
|----------------|---------|------|-------------|----------------------------|
| GRF_USB_ID_CON | 0x1031C | W    | 0x00030100  | USBPHY id control register |

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

### 6.3.2 Detail Register Description

#### 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:12 | RO   | 0x0         | reserved                                                                                                                           |
| 11    | RW   | 0x0         | clk_hpll_ls_sel<br>HPLL clock path selection.<br>1'b0: Normal<br>1'b1: Through level-shift cell                                    |
| 10    | RW   | 0x0         | clk_cpll_ls_sel<br>CPLL clock path selection.<br>1'b0: Normal<br>1'b1: Through level-shift cell                                    |
| 9     | RW   | 0x0         | clk_dpll_ls_sel<br>DPLL clock path selection.<br>1'b0: Normal<br>1'b1: Through level-shift cell                                    |
| 8     | RW   | 0x0         | clk_apll_ls_sel<br>APLL clock path selection.<br>1'b0: Normal<br>1'b1: Through level-shift cell                                    |
| 7:6   | RO   | 0x0         | reserved                                                                                                                           |
| 5     | RW   | 0x0         | npu_csysreq_sel<br>NPU csysreq source selection.<br>1'b0: From software (GRF_SOC_CON0[4])<br>1'b1: From hardware (npu_pwr_IdleReq) |
| 4     | RW   | 0x0         | npu_csysreq<br>NPU system low-power request(csysreq).<br>1'b0: Inactive<br>1'b1: Active                                            |
| 3     | RW   | 0x0         | mcu_soft_irq<br>MCU software irq.<br>1'b0: Inactive<br>1'b1: Active                                                                |
| 2     | RW   | 0x0         | usbphy_hostport_wakeup_irq_en<br>USBPHY host port wakeup irq enable.<br>1'b0: Disable<br>1'b1: Enable                              |
| 1     | RW   | 0x0         | npu_disable_ram_clockgating<br>Disable NPU clock gating of the rams during BIST.<br>1'b0: Not disable<br>1'b1: Disable             |
| 0     | RW   | 0x0         | wdt_ns_glb_reset_en<br>Non-secure WDT global reset enable.<br>1'b0: Disable<br>1'b1: Enable                                        |

#### 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 |
| 15:12      | RO          | 0x0                | reserved                                                                                                                          |
| 11         | RW          | 0x0                | uart5_cts_inv<br>uart5_cts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                           |
| 10         | RW          | 0x0                | uart5_rts_inv<br>uart5_rts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                           |
| 9          | RW          | 0x0                | uart4_cts_inv<br>uart4_cts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                           |
| 8          | RW          | 0x0                | uart4_rts_inv<br>uart4_rts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                           |
| 7          | RW          | 0x0                | uart3_cts_inv<br>uart3_cts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                           |
| 6          | RW          | 0x0                | uart3_rts_inv<br>uart3_rts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                           |
| 5          | RW          | 0x0                | uart2_cts_inv<br>uart2_cts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                           |
| 4          | RW          | 0x0                | uart2_rts_inv<br>uart2_rts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                           |
| 3:2        | RO          | 0x0                | reserved                                                                                                                          |
| 1          | RW          | 0x0                | uart0_cts_inv<br>uart0_cts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                           |
| 0          | RW          | 0x0                | uart0_rts_inv<br>uart0_rts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                           |

**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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | mcu_jtag_sel<br>MCU jtag selection.<br>1'b0: MCU jtag<br>1'b1: Reserved<br>This bit should be set to 0 for MCU jtag working.       |
| 14         | RW          | 0x0                | accdig_i2c_trans_req<br>ACODEC I2C transfer request.<br>1'b0: Not request<br>1'b1: Request                                         |
| 13         | RW          | 0x0                | accdig_i2s_active<br>I2S0 input source selection.<br>1'b0: From external ACODEC<br>1'b1: From internal ACODEC                      |
| 12         | RW          | 0x0                | vopm_dma_finish_en<br>vop_dma_finish enable for dma_finish generation.<br>1'b0: Disable<br>1'b1: Enable                            |
| 11:8       | RO          | 0x0                | reserved                                                                                                                           |
| 7          | RW          | 0x0                | vdec_fuse_vp9<br>Need tie to 0 for VDEC normal work                                                                                |
| 6          | RO          | 0x0                | reserved                                                                                                                           |
| 5          | RW          | 0x0                | dsi0_dpiupdatecfg<br>DSIHOST dsi0_dpiupdatecfg configuration                                                                       |
| 4          | RW          | 0x0                | dsi0_dpishutdn<br>DSIHOST dsi0_dpishutdn configuration                                                                             |
| 3          | RW          | 0x0                | dsi0_dpicolorm<br>DSIHOST dsi0_dpicolorm configuration                                                                             |
| 2          | RW          | 0x0                | vop_flow_switch<br>1'b0: VOP access DDR through VPU memory scheduler port<br>1'b1: VOP access DDR through VI memory scheduler port |
| 1:0        | RW          | 0x0                | vop_press<br>QoS control for VOP                                                                                                   |

**GRF SOC STATUS0**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | npu_debug_out<br>NPU debug output                                                                      |
| 23:22      | RO          | 0x0                | reserved                                                                                               |
| 21         | RO          | 0x1                | nandc_master_idle<br>NANDC master idle status.<br>1'b0: Not idle<br>1'b1: Idle                         |
| 20         | RO          | 0x1                | pmu_pwr_IdleAck<br>PMU idle acknowledge status.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge          |
| 19         | RO          | 0x1                | pmu_pwr_Idle<br>PMU idle status.<br>1'b0: Not idle<br>1'b1: Idle                                       |
| 18         | RO          | 0x0                | accdig_i2c_trans_ack<br>ACODEC I2C transfer acknowledge.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------|
| 17         | RO          | 0x0                | vopm_dma_finish<br>VOP dma finish status.<br>1'b0: Not finish<br>1'b1: Finish               |
| 16         | RO          | 0x0                | timer5_en_status<br>Timer5 enable status.<br>1'b0: Disable<br>1'b1: Enable                  |
| 15         | RO          | 0x0                | timer4_en_status<br>Timer4 enable status.<br>1'b0: Disable<br>1'b1: Enable                  |
| 14         | RO          | 0x0                | timer3_en_status<br>Timer3 enable status.<br>1'b0: Disable<br>1'b1: Enable                  |
| 13         | RO          | 0x0                | timer2_en_status<br>Timer2 enable status.<br>1'b0: Disable<br>1'b1: Enable                  |
| 12         | RO          | 0x0                | timer1_en_status<br>Timer1 enable status.<br>1'b0: Disable<br>1'b1: Enable                  |
| 11         | RO          | 0x0                | timer0_en_status<br>Timer0 enable status.<br>1'b0: Disable<br>1'b1: Enable                  |
| 10         | RO          | 0x1                | iep_core_idle<br>IEP core idle status.<br>1'b0: Not idle<br>1'b0: Idle                      |
| 9          | RO          | 0x0                | reserved                                                                                    |
| 8          | RO          | 0x0                | scramble_shift_ready<br>Scramble shift status.<br>1'b0: Not ready<br>1'b1: Ready            |
| 7          | RO          | 0x0                | mcu_RST_N_out<br>MCU reset status.<br>1'b0: MCU in reset state<br>1'b1: MCU in normal state |
| 6          | RO          | 0x0                | ddrphy_plllock<br>DDRPHY PLL lock status.<br>1'b0: Not locked<br>1'b1: Locked               |
| 5          | RO          | 0x0                | reserved                                                                                    |
| 4          | RO          | 0x0                | hpll_lock<br>HPLL lock status.<br>1'b0: Not locked<br>1'b1: Locked                          |
| 3          | RO          | 0x0                | gpll_lock<br>GPLL lock status.<br>1'b0: Not locked<br>1'b1: Locked                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 2          | RO          | 0x0                | cpll_lock<br>CPLL lock status.<br>1'b0: Not locked<br>1'b1: Locked  |
| 1          | RO          | 0x0                | dpll_lock<br>DPPLL lock status.<br>1'b0: Not locked<br>1'b1: Locked |
| 0          | RO          | 0x0                | apll_lock<br>APPLL lock status.<br>1'b0: Not locked<br>1'b1: Locked |

**GRF SOC STATUS1**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                   |
| 4          | RO          | 0x0                | pmu_global_int_disable3<br>CPU3 interrupt disable by PMU.<br>1'b0: Enable<br>1'b1: Disable |
| 3          | RO          | 0x0                | pmu_global_int_disable2<br>CPU2 interrupt disable by PMU.<br>1'b0: Enable<br>1'b1: Disable |
| 2          | RO          | 0x0                | pmu_global_int_disable1<br>CPU1 interrupt disable by PMU.<br>1'b0: Enable<br>1'b1: Disable |
| 1          | RO          | 0x0                | pmu_global_int_disable0<br>CPU0 interrupt disable by PMU.<br>1'b0: Enable<br>1'b1: Disable |
| 0          | RO          | 0x0                | pmu_global_int_disable<br>SCU interrupt disable by PMU.<br>1'b0: Enable<br>1'b1: Disable   |

**GRF CPU CON0**

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'b0: Write access disable<br>1'b1: Write access enable                                            |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                     |
| 13         | RW          | 0x0                | cpu_ema_detect_en<br>CPU EMA detection enable. If enabled, hardware will set CPU bus idle and stop CPU clock until finish EMA modification.<br>1'b0: Disable<br>1'b1: Enable |
| 12         | RW          | 0x0                | evento_clear<br>EVENTO clear.<br>1'b0: Not clear<br>1'b1: Clear                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x1                | dbgselfaddrv<br>Debug self-address offset valid.<br>1'b0: Not valid<br>1'b1: Valid                                                                                                                                                                                                                                                                                                                                                                              |
| 10         | RW          | 0x1                | dbgromaddrv<br>Debug ROM physical address valid.<br>1'b0: Not valid<br>1'b1: Valid                                                                                                                                                                                                                                                                                                                                                                              |
| 9          | RW          | 0x0                | eventi<br>Event input for processor wake-up from WFE state. When this signal is asserted, it acts as a WFE wake-up event to all the processors in the multiprocessor device.                                                                                                                                                                                                                                                                                    |
| 8          | RW          | 0x0                | I2rstdisable<br>Disable automatic L2 cache invalidated at reset.<br>1'b0: Enable L2 cache invalidated at reset<br>1'b1: Disable L2 cache invalidated at reset (soft reset)<br>Only change this signal when the processor is in the reset state.                                                                                                                                                                                                                 |
| 7:4        | RW          | 0x0                | I1rstdisable<br>Disable automatic data cache, instruction cache and TLB invalidated at reset for each processor. Each bit represents each processor respectively.<br>1'b0: Enable data cache invalidated, instruction cache invalidated and TLB invalidated at reset.<br>1'b1: Disable data cache invalidated, instruction cache invalidated, and TLB invalidated at reset (soft reset).<br>Only change these signals when the processor is in the reset state. |
| 3:0        | RW          | 0xf                | viniti<br>Set the base address of the vector table for each processor. Each bit represents each processor respectively.<br>1'b0: Vector table base address of 0x00000000<br>1'b1: Vector table base address of 0xFFFFF0000<br>Only change this signal when the processor is in the reset state.                                                                                                                                                                 |

**GRF CPU CON1**

Address: Operational Base + offset (0x0024)

| <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:8       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                      |
| 7:4        | RW          | 0x0                | cgte<br>Controls processor state for exception handling (TE bit) at reset for each processor. Each bit represents each processor respectively.<br>1'b0: ARM instruction set for exception handling<br>1'b1: Thumb instruction set for exception handling<br>Only change this signal when the processor is in the reset state. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x0                | <p>cfgend<br/>Control endianness during data exception handling (EE-bit) at reset for each processor. Each bit represents each processor respectively.</p> <p>1'b0: Little-endian data during exception handling<br/>1'b1: Big-endian data during exception handling<br/>Only change this signal when the processor is in the reset state.</p> |

**GRF CPU STATUS**

Address: Operational Base + offset (0x0030)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                |
| 15         | RO          | 0x1                | jtagnsw<br>JTAGNSW output                                                                                                                                               |
| 14         | RO          | 0x1                | jtagtop<br>JTAGTOP output                                                                                                                                               |
| 13         | WO          | 0x0                | evento_rising_edge<br>Event output rising edge indication.<br>1'b0: Inactive<br>1'b1: Active                                                                            |
| 12         | RO          | 0x0                | standbywfil2<br>Indicates if the L2 memory system is in WFI standby mode.<br>1'b0: Normal state<br>1'b1: WFI state                                                      |
| 11:8       | RO          | 0x0                | smpnamp<br>Signals Symmetric MultiProcessing (SMP) mode or Asymmetric MultiProcessing (AMP) for each processor. Each bit represents each processor respectively.        |
| 7:4        | RO          | 0xf                | standbywfi<br>Indicates if a processor is in WFI state for each processor.<br>1'b0: Normal state<br>1'b1: WFI state<br>Each bit represents each processor respectively. |
| 3:0        | RO          | 0x0                | standbywfe<br>Indicates if a processor is in WFE state for each processor. Each bit represents each processor respectively.<br>1'b0: Normal state<br>1'b1: WFE state    |

**GRF INTCONNET CON0**

Address: Operational Base + offset (0x0040)

| <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 16bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p> |
| 15:6       | RO          | 0x000              | reserved                                                                                                                                       |
| 5:4        | RW          | 0x0                | press_vdec<br>QoS control for VDEC                                                                                                             |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | <p>split<br/>Decide the splitting size of the interconnection for a transaction from a master.</p> <p>2'b00: Splitting size is 64 bytes<br/>2'b01: Splitting size is 32 bytes<br/>2'b10: Splitting size is 16 bytes<br/>2'b11: Reserved. Do not set to this value; otherwise, the system will crash.</p> |

**GRF INTCONNET CON1**

Address: Operational Base + offset (0x0044)

| <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 16bits, each bit is individual.</p> <p>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                |
| 15         | RW          | 0x0                | <p>vi_bus_to_ddr_stall<br/>Response type when BIU_BUS or BIU_DDR in idle state and ISPP/ISP/CIF/IEP access DDR.</p> <p>1'b0: BIU return ERROR response<br/>1'b1: BIU hold the bus until the BIU idle state is de-asserted</p>                                                 |
| 14         | RW          | 0x0                | <p>bus_to_ddr_stall<br/>Response type when BIU_BUS or BIU_DDR in idle state and masters in BUS or in PHP or NPU access DDR.</p> <p>1'b0: BIU return ERROR response<br/>1'b1: BIU hold the bus until the BIU idle state is de-asserted</p>                                     |
| 13         | RW          | 0x0                | <p>mcu_to_bushold_stall<br/>Response type when BIU_BUS or BIU_BUSHOLD in idle state and MCU access DDR.</p> <p>1'b0: BIU return ERROR response<br/>1'b1: BIU hold the bus until the BIU idle state is de-asserted</p>                                                         |
| 12         | RW          | 0x0                | <p>phpmid_to_bus_stall<br/>Response type when BIU_PHPMID or BIU_BUS in idle state and SDMMC/SDIO/EMMC/FSPI/NANDC/USBHOST/USBOTG/GMAC access DDR or SYSTEM_SRAM.</p> <p>1'b0: BIU return ERROR response<br/>1'b1: BIU hold the bus until the BIU idle state is de-asserted</p> |
| 11         | RW          | 0x0                | <p>phpmid_to_usb_stall<br/>Response type when BIU_PHPMID or BIU_USB in idle state and CPU or MCU access USBOTG/USBHOST register.</p> <p>1'b0: BIU return ERROR response<br/>1'b1: BIU hold the bus until the BIU idle state is de-asserted</p>                                |
| 10         | RW          | 0x0                | <p>phpmid_to_nvm_stall<br/>Response type when BIU_PHPMID or BIU_NVM in idle state and CPU or MCU access FSPI/EMMC/NANDC register.</p> <p>1'b0: BIU return ERROR response<br/>1'b1: BIU hold the bus until the BIU idle state is de-asserted</p>                               |
| 9          | RW          | 0x0                | <p>phpmid_to_gmac_stall<br/>Response type when BIU_PHPMID or BIU_GMAC in idle state and CPU or MCU access GMAC register.</p> <p>1'b0: BIU return ERROR response<br/>1'b1: BIU hold the bus until the BIU idle state is de-asserted</p>                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | usb_to_phpmid_stall<br>Response type when BIU_USB or BIU_PHPMID in idle state and USBHOST access DDR or USBOTG access SYSTEM_SRAM or DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted |
| 7          | RW          | 0x0                | gmac_to_phpmid_stall<br>Response type when BIU_GMAC or BIU_PHPMID in idle state and GMAC access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                      |
| 6          | RW          | 0x0                | nvm_to_phpmid_stall<br>Response type when BIU_NVM or BIU_PHPMID in idle state and FSPI/EMMC/NANDC access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                             |
| 5          | 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 BIU idle state is de-asserted                                            |
| 4          | RW          | 0x0                | vdpu_to_ddr_stall<br>Response type when BIU_VDPU or BIU_DDR in idle state and VDEC/JPEG access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                       |
| 3          | RW          | 0x0                | ispp_to_bus_stall<br>Response type when BIU_ISPP or BIU_BUS in idle state and ISPP access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                            |
| 2          | RW          | 0x0                | vo_to_bus_stall<br>Response type when BIU_VO or BIU_BUS in idle state and RGA/IEP/VOP access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                         |
| 1          | RW          | 0x0                | cpu_to_bus_stall<br>Response type when BIU_CORE or BIU_BUS in idle state and CPU access other slave or SYSTEM_SRAM.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                       |
| 0          | RW          | 0x0                | cpu_to_ddr_stall<br>Response type when BIU_CORE 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 BIU idle state is de-asserted                                              |

**GRF INTCONNNET CON2**

Address: Operational Base + offset (0x0048)

| <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                | bus_to_vi_stall<br>Response type when BIU_BUS or BIU_VI in idle state and CPU/MCU access ISP/CIF.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                              |
| 14         | RW          | 0x0                | bus_to_vepu_stall<br>Response type when BIU_BUS or BIU_VEPU in idle state and CPU/MCU access VENC register.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                    |
| 13         | RW          | 0x0                | bus_to_vdpu_stall<br>Response type when BIU_BUS or BIU_VDPU in idle state and CPU/MCU access VDEC/JPEG register.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                               |
| 12         | RW          | 0x0                | bus_to_ispp_stall<br>Response type when BIU_BUS or BIU_ISPP in idle state and CPU/MCU access ISPP register.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                    |
| 11         | RW          | 0x0                | npu_to_bus_stall<br>Response type when BIU_NPU or BIU_BUS in idle state and NPU access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                                    |
| 10         | RW          | 0x0                | bus_to_top_stall<br>Response type when BIU_BUS or BIU_TOP in idle state and CPU/MCU access all PHYs/CRU register.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                              |
| 9          | RW          | 0x0                | vi_to_bus_stall<br>Response type when BIU_VI or BIU_BUS in idle state and ISPP/ISP/CIF/IEP access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                         |
| 8          | RW          | 0x0                | bus_to_phpid_stall<br>Response type when BIU_BUS or BIU_PHPID in idle state and CPU/MCU access SDMMC/SDIO/EMMC/FSPI/NANDC/USBHOST/USBOTG/GMAC.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted |
| 7          | RW          | 0x0                | bus_to_npu_stall<br>Response type when BIU_BUS or BIU_NPU in idle state and CPU/MCU access NPU register.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                       |
| 6          | RW          | 0x0                | hold_to_bus_stall<br>Response type when BIU_BUSHOLD or BIU_DDR in idle state and MCU/DMAC/CRYPTO access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | busmst_to_hold_stall<br>Response type when BIU_BUS or BIU_BUSHOLD in idle state and DMAC/CRYPTO access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                      |
| 4          | RW          | 0x0                | bus_to_pmu_stall<br>Response type when BIU_BUS or BIU_PMU in idle state and CPU/MCU access IPs in PMU.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                           |
| 3          | RW          | 0x0                | bus_to_ddrc_stall<br>Response type when BIU_BUS or BIU_DDR in idle state and CPU/MCU access DDR controller register.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted             |
| 2          | RW          | 0x0                | bus_to_audio_stall<br>Response type when BIU_BUS or BIU_AUDIO in idle state and CPU/MCU access I2S/PDM/audPWM/ACDC_DIG register.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted |
| 1          | RW          | 0x0                | bus_to_mschreg_stall<br>Response type when BIU_BUS or BIU_DDR in idle state and CPU/MCU access firewall or scheduler register.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted   |
| 0          | RW          | 0x0                | vo_bus_to_ddr_stall<br>Response type when BIU_BUS or BIU_DDR in idle state and RGA/VOP/IEP access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                           |

**GRF INTCONNET CON3**

Address: Operational Base + offset (0x004C)

| <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:8       | RO          | 0x00               | reserved                                                                                                                                                                                                                              |
| 7          | RW          | 0x0                | bus_to_cpu_stall<br>bus_to_cpu_stall<br>Response type when BIU_BUS or BIU_CORE in idle state and MCU access debug/PVTM register.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted |
| 6          | RW          | 0x0                | sdio_to_phpmid_stall<br>Response type when BIU_SDIO or BIU_PHPMID in idle state and SDIO access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                             |
| 5          | RW          | 0x0                | sdcard_to_phpmid_stall<br>Response type when BIU_SDCARD or BIU_PHPMID in idle state and SDMMC access DDR.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | phpmid_to_sdio_stall<br>Response type when BIU_PHPMID or BIU_SDIO in idle state and CPU/MCU access SDIO.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted           |
| 3          | RW          | 0x0                | phpmid_to_sdcard_stall<br>Response type when BIU_PHPMID or BIU_SDCARD in idle state and CPU/MCU access SDMMC.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted      |
| 2          | RW          | 0x0                | bus_to_crypto_stall<br>Response type when BIU_BUS or BIU_CRYPT in idle state and CPU/ MCU access CRYPTO.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted           |
| 1          | RW          | 0x0                | crypto_to_bus_stall<br>Response type when BIU_CRYPT or BIU_BUS in idle state and CRYPTO access DDR or SYSTEM_SRAM.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted |
| 0          | RW          | 0x0                | bus_to_vo_stall<br>Response type when BIU_BUS or BIU_VO in idle state and CPU/MCU access VOP/RGA/IEP register.<br>1'b0: BIU return ERROR response<br>1'b1: BIU hold the bus until the BIU idle state is de-asserted     |

**GRF USBHOST CON0**

Address: Operational Base + offset (0x0050)

| <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:6       | RW          | 0x20               | usbhost_flsj_val_common<br>USBHOST fladj_val_common bit control.<br>1'b0: Disable<br>1'b1: Enable                                 |
| 5:0        | RW          | 0x20               | usbhost_fladj_val<br>USBHOST fladj bit control.<br>1'b0: Disable<br>1'b1: Enable                                                  |

**GRF USBHOST CON1**

Address: Operational Base + offset (0x0054)

| <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:14      | RO          | 0x0                | reserved                                                                                                                          |
| 13         | RW          | 0x0                | usbhost_arb_pause<br>USBHOST ehci/ohci arbiter pause control.<br>1'b0: Disable<br>1'b1: Enable                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | usbhost_ohci_susp_lgcy<br>USBHOST ohci_susp_lgcy bit control.<br>1'b0: Disable<br>1'b1: Enable               |
| 11         | RW          | 0x0                | usbhost_ohci_cntsel<br>USBHOST ohci_cntsel bit control.<br>1'b0: Disable<br>1'b1: Enable                     |
| 10         | RW          | 0x1                | usbhost_ohci_clkctrst<br>USBHOST ohci_clkctrst bit control.<br>1'b0: Disable<br>1'b1: Enable                 |
| 9          | RW          | 0x0                | usbhost_app_prt_ovrcur<br>USBHOST app_prt_ovrcur bit control.<br>1'b0: Disable<br>1'b1: Enable               |
| 8          | RW          | 0x0                | usbhost_autoppd_on_overcur_en<br>USBHOST autoppd_on_overcur_en bit control.<br>1'b0: Disable<br>1'b1: Enable |
| 7          | RW          | 0x1                | usbhost_word_if<br>USBHOST word_if bit control.<br>1'b0: Disable<br>1'b1: Enable                             |
| 6          | RW          | 0x0                | usbhost_sim_mode<br>USBHOST sim_mode bit control.<br>1'b0: Disable<br>1'b1: Enable                           |
| 5          | RW          | 0x1                | usbhost_incrx_en<br>USBHOST incr_x_en bit control.<br>1'b0: Disable<br>1'b1: Enable                          |
| 4          | RW          | 0x1                | usbhost_incr8_en<br>USBHOST incr8_en bit control.<br>1'b0: Disable<br>1'b1: Enable                           |
| 3          | RW          | 0x1                | usbhost_incr4_en<br>USBHOST incr4_en bit control.<br>1'b0: Disable<br>1'b1: Enable                           |
| 2          | RW          | 0x1                | usbhost_incr16_en<br>USBHOST incr16_en bit control.<br>1'b0: Disable<br>1'b1: Enable                         |
| 1          | RW          | 0x0                | usbhost_hubsetup_min<br>USBHOST hubsetup_min bit control.<br>1'b0: Disable<br>1'b1: Enable                   |
| 0          | RW          | 0x0                | usbhost_app_start_clk<br>USBHOST app_start_clk bit control.<br>1'b0: Disable<br>1'b1: Enable                 |

**GRF USBHOST STATUS0**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                            |
| 30         | RW          | 0x0                | usbhost_ehci_power_state_ack<br>USBHOST ehci_power_state_ack status |
| 29         | RW          | 0x0                | usbhost_ehci_pme_status<br>USBHOST ehci_pme_status status           |
| 28         | RW          | 0x0                | usbhost_ehci_bufacc<br>USBHOST ehci_bufacc status                   |
| 27         | RW          | 0x0                | usbhost_ehci_xfer_prdc<br>USBHOST ehci_xfer_prdc status             |
| 26         | RW          | 0x0                | usbhost_ohci_ccs<br>USBHOST ohci_ccs status                         |
| 25         | RW          | 0x0                | usbhost_ohci_rwe<br>USBHOST ohci_rwe status                         |
| 24         | RW          | 0x0                | usbhost_ohci_drwe<br>USBHOST ohci_drwe status                       |
| 23         | RW          | 0x0                | usbhost_ohci_globalsuspend<br>USBHOST ohci_globalsuspend status     |
| 22         | RW          | 0x0                | usbhost_ohci_bufacc<br>USBHOST ohci_bufacc status                   |
| 21         | RW          | 0x0                | usbhost_ohci_rmtwkp<br>USBHOST ohci_rmtwkp status                   |
| 20:17      | RW          | 0x0                | usbhost_ehci_lpsmc_state<br>USBHOST ehci_lpsmc_state status         |
| 16:11      | RW          | 0x00               | usbhost_ehci_usbsts<br>USBHOST ehci_usbsts status                   |
| 10:0       | RW          | 0x000              | usbhost_ehci_xfer_cnt<br>USBHOST ehci_xfer_cnt status               |

**GRF USBOTG CONO**

Address: Operational Base + offset (0x005C)

| <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                | usbotg_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                | usbotg_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               | usbotg_fladj_30mhz_reg<br>USB OTG fladj_30mhz_reg configuration                                                                                                                                                                                              |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                     |
| 6          | RW          | 0x0                | usbotg_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                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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<br>utmisrp_bvalid and utmisrp_sessend<br>usb0tg_bus_filter_bypass[1]: Bypass the filter for<br>pipe3_PowerPresent all U3 ports<br>usb0tg_bus_filter_bypass[0]: Bypass the filter for<br>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<br>and is not changed during the normal operation of the core. |

**GRF USBOTG CON1**

Address: Operational Base + offset (0x0060)

| <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:8       | RW          | 0x1                | usb0tg_host_num_u2_port<br>xHCI host USB2 Port number, default as 1.                                                                                                                                     |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                 |
| 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:2        | RO          | 0x0                | reserved                                                                                                                                                                                                 |
| 1          | RW          | 0x0                | usb0tg_pme_en<br>Enable the core to assert pme_generation.<br>1'b0: Disable<br>1'b1: Enable                                                                                                              |
| 0          | RO          | 0x0                | reserved                                                                                                                                                                                                 |

**GRF USBOTG STATUS0**

Address: Operational Base + offset (0x0064)

| <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 |

**GRF USBOTG STATUS1**

Address: Operational Base + offset (0x0068)

| <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 |

**GRF USBOTG STATUS2**

Address: Operational Base + offset (0x006C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                              |
| 27:0       | RO          | 0x00007e8          | usb0tg_host_current_belt<br>usb0tg_host_current_belt bit[11:0] status |

**GRF MAC CON0**

Address: Operational Base + offset (0x0070)

| <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                | mac_ptp_aux_ts_trig<br>MAC auxiliary timestamp trigger.<br>1'b0: Disable<br>1'b1: Enable                                          |
| 7          | RW          | 0x0                | mac_sbd_flowctrl<br>MAC sideband flow control.<br>1'b0: Disable<br>1'b1: Enable                                                   |
| 6:4        | RW          | 0x0                | mac_phy_intf_sel<br>MAC PHY interface selection.<br>3'b000: GMII or MII<br>3'b001: RGMII<br>3'b100: RMII<br>Others: Reserved      |
| 3          | RW          | 0x0                | mac_m1_rxclk_dly_ena<br>MAC receive clock delay enable for iomux group 1.<br>1'b0: Disable<br>1'b1: Enable                        |
| 2          | RW          | 0x0                | mac_m1_txclk_dly_ena<br>MAC transmit clock delay enable for iomux group 1.<br>1'b0: Disable<br>1'b1: Enable                       |
| 1          | RW          | 0x0                | mac_m0_rxclk_dly_ena<br>MAC receive clock delay enable for iomux group 0.<br>1'b0: Disable<br>1'b1: Enable                        |
| 0          | RW          | 0x0                | mac_m0_txclk_dly_ena<br>MAC transmit clock delay enable for iomux group 0.<br>1'b0: Disable<br>1'b1: Enable                       |

**GRF MAC CON1**

Address: Operational Base + offset (0x0074)

| <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:8       | RW          | 0x00               | mac_m0_clk_rx_dl_cfg<br>MAC recept clock delay length configuration for iomux group 0                                             |
| 7:0        | RW          | 0x00               | mac_m0_clk_tx_dl_cfg<br>GMAC transmit clock delay length configuration for iomux group 0                                          |

**GRF MAC CON2**

Address: Operational Base + offset (0x0078)

| <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:8       | RW          | 0x00               | mac_m1_clk_rx_dl_cfg<br>MAC receive clock delay length configuration for iomux group 1                                            |
| 7:0        | RW          | 0x00               | mac_m1_clk_tx_dl_cfg<br>MAC transmit clock delay length configuration for iomux group 1                                           |

**GRF MAC STATUS0**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                           |
| 3          | RO          | 0x0                | gmac_sbd_tx_clk_gating_ctrl<br>MAC LPI transmit clock gating control status                                                                        |
| 2          | RO          | 0x0                | mac_ptp_pps<br>MAC pulse per second status                                                                                                         |
| 1:0        | RO          | 0x0                | mac_mac_speed<br>MAC sideband speed status.<br>2'b00: 1000 Mbps (GMII)<br>2'b01: 2500 Mbps (GMII)<br>2'b10: 10 Mbps (MII)<br>2'b11: 100 Mbps (MII) |

**GRF MAC STATUS1**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | gmac_ptp_timestamp_31_0<br>MAC reference time output bit[31:0] |

**GRF MAC STATUS2**

Address: Operational Base + offset (0x008C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | gmac_ptp_timestamp_63_32<br>MAC reference time output bit[63:32] |

**GRF MEM CON0**

Address: Operational Base + offset (0x0090)

| <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:14      | RO          | 0x0                | reserved                                                                                                                                     |
| 13:8       | RW          | 0x05               | mem_romcfg<br>ROM EMA configuration.<br>bit[0]: RME<br>bit[3:1]: RM<br>bit[4]: LS<br>bit[5]: TEST1                                           |
| 7:0        | RW          | 0x05               | core_mem_spcfg<br>CORE memory EMA configuration.<br>bit[0]: RME<br>bit[3:1]: RM<br>bit[4]: LS<br>bit[5]: BC1<br>bit[6]: BC2<br>bit[7]: TEST1 |

**GRF MEM CON1**

Address: Operational Base + offset (0x0094)

| <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:8       | RW          | 0x05               | mem_hssprfcfg<br>HSSPRF memory EMA configuration.<br>bit[0]: RME<br>bit[3:1]: RM<br>bit[4]: LS<br>bit[5]: BC1<br>bit[6]: BC2<br>bit[7]: TEST1 |
| 7:0        | RW          | 0x05               | mem_sprfcfg<br>SPRF memory EMA configuration.<br>bit[0]: RME<br>bit[3:1]: RM<br>bit[4]: LS<br>bit[5]: BC1<br>bit[6]: BC2<br>bit[7]: TEST1     |

**GRF MEM CON2**

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:10      | RO          | 0x00               | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:0        | RW          | 0x0a5              | mem_dprfcfg<br>DPRF memory EMA configuration.<br>bit[0]: RMEA<br>bit[3:1]: RMA<br>bit[4]: LS<br>bit[5]: RMEB<br>bit[8:6]: RMB<br>bit[9]: TEST1 |

**GRF MEM CON3**

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:14      | RO          | 0x0                | reserved                                                                                                                                                                         |
| 13:0       | RW          | 0x2805             | mem_spracfg<br>SPRA memory EMA configuration.<br>bit[0]: RME<br>bit[3:1]: RM<br>bit[4]: LS<br>bit[5]: BC1<br>bit[6]: BC2<br>bit[7]: TEST1<br>bit[10:8]: WPULSE<br>bit[13:11]: WA |

**GRF TSADC CON**

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         | RO          | 0x0                | reserved                                                                                                                                                                                                                           |
| 14         | RW          | 0x0                | pvt_shut_2gpio_sel<br>pvt_shut_2gpio selection.<br>1'b0: pvt_shut_2gpio valid if either cpu_pvt_shut_2gpio or<br>npu_pvt_shut_2gpio valid<br>1'b1: pvt_shut_2gpio valid if both cpu_pvt_shut_2gpio and<br>npu_pvt_shut_2gpio valid |
| 13         | RW          | 0x0                | npu_pvt_shut_2gpio_ena<br>Enable NPU pvt_shut_2gpio.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                              |
| 12         | RW          | 0x0                | cpu_pvt_shut_2gpio_ena<br>Enable CPU pvt_shut_2gpio.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                              |
| 11         | RW          | 0x0                | npupvt_shut_2cru_ena<br>Enable NPU pvt_shut to reset CRU.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | cpupvt_shut_2cru_ena<br>Enable CPU pvt_shut to reset CRU.<br>1'b0: Disable<br>1'b1: Enable                           |
| 9          | RW          | 0x1                | npu_pvt_tdc_mode<br>NPU PVT TDC mode enable signal.<br>1'b0: VDC(voltage sensor) mode<br>1'b1: TDC(temp sensor) mode |
| 8          | RW          | 0x1                | cpu_pvt_tdc_mode<br>CPU PVT TDC mode enable signal.<br>1'b0: VDC(voltage sensor) mode<br>1'b1: TDC(temp sensor) mode |
| 7:4        | RW          | 0x7                | npu_pvt_trim<br>NPU PVT bandgap trim signal                                                                          |
| 3:0        | RW          | 0x7                | cpu_pvt_trim<br>CPU PVT bandgap trim signal                                                                          |

**GRF CHIP ID**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b> |
|------------|-------------|--------------------|--------------------|
| 31:0       | RO          | 0x00001109         | chipid<br>Chip ID  |

**GRF GPIOOC\_IOMUX\_H**

Address: Operational Base + offset (0x10000)

| <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                | gpio0c7_sel<br>3'h0: GPIO0_C7_u<br>3'h1: FLASH_D3<br>3'h2: EMMC_D3<br>Others: Reserved                                            |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio0c6_sel<br>3'h0: GPIO0_C6_u<br>3'h1: FLASH_D2<br>3'h2: EMMC_D2<br>Others: Reserved                                            |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio0c5_sel<br>3'h0: GPIO0_C5_u<br>3'h1: FLASH_D1<br>3'h2: EMMC_D1<br>Others: Reserved                                            |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio0c4_sel<br>3'h0: GPIO0_C4_u<br>3'h1: FLASH_D0<br>3'h2: EMMC_D0<br>Others: Reserved                                            |

**GRF GPIOOD\_IOMUX\_L**

Address: Operational Base + offset (0x10004)

| 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         | gpio0d3_sel<br>3'h0: GPIO0_D3_u<br>3'h1: FLASH_D7<br>3'h2: EMMC_D7<br>Others: Reserved                                            |
| 11    | RO   | 0x0         | reserved                                                                                                                          |
| 10:8  | RW   | 0x0         | gpio0d2_sel<br>3'h0: GPIO0_D2_u<br>3'h1: FLASH_D6<br>3'h2: EMMC_D6<br>Others: Reserved                                            |
| 7     | RO   | 0x0         | reserved                                                                                                                          |
| 6:4   | RW   | 0x0         | gpio0d1_sel<br>3'h0: GPIO0_D1_u<br>3'h1: FLASH_D5<br>3'h2: EMMC_D5<br>3'h3: FSPI_CS1N<br>Others: Reserved                         |
| 3     | RO   | 0x0         | reserved                                                                                                                          |
| 2:0   | RW   | 0x0         | gpio0d0_sel<br>3'h0: GPIO0_D0_u<br>3'h1: FLASH_D4<br>3'h2: EMMC_D4<br>Others: Reserved                                            |

**GRF GPIOOD\_IOMUX\_H**

Address: Operational Base + offset (0x10008)

| 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         | gpio0d7_sel<br>3'h0: GPIO0_D7_d<br>3'h1: FLASH_CLE<br>3'h2: EMMC_CLKO<br>Others: Reserved                                         |
| 11    | RO   | 0x0         | reserved                                                                                                                          |
| 10:8  | RW   | 0x0         | gpio0d6_sel<br>3'h0: GPIO0_D6_d<br>3'h3: FSPI_D2<br>3'h4: I2S1_SDO_M0<br>Others: Reserved                                         |
| 7     | RO   | 0x0         | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 6:4        | RW          | 0x0                | gpio0d5_sel<br>3'h0: GPIO0_D5_u<br>3'h1: FLASH_WRN<br>3'h2: EMMC_CMD<br>Others: Reserved                         |
| 3          | RO          | 0x0                | reserved                                                                                                         |
| 2:0        | RW          | 0x0                | gpio0d4_sel<br>3'h0: GPIO0_D4_u<br>3'h1: FLASH_CS0N<br>3'h3: FSPI_CS0N<br>3'h4: I2S1_MCLK_M0<br>Others: Reserved |

**GRF GPIO1A\_IOMUX\_L**

Address: Operational Base + offset (0x10010)

| <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                | gpio1a3_sel<br>3'h0: GPIO1_A3_d<br>3'h1: FLASH_WPN<br>3'h2: EMMC_RSTn<br>3'h3: FSPI_CLK<br>Others: Reserved                       |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio1a2_sel<br>3'h0: GPIO1_A2_u<br>3'h1: FLASH_RDN<br>3'h3: FSPI_D3<br>3'h4: I2S1_SDI_M0<br>Others: Reserved                      |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio1a1_sel<br>3'h0: GPIO1_A1_u<br>3'h1: FLASH_RDYN<br>3'h3: FSPI_D1<br>3'h4: I2S1_SCLK_M0<br>Others: Reserved                    |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio1a0_sel<br>3'h0: GPIO1_A0_d<br>3'h1: FLASH_ALE<br>3'h3: FSPI_D0<br>3'h4: I2S1_LRCK_M0<br>Others: Reserved                     |

**GRF GPIO1A\_IOMUX\_H**

Address: Operational Base + offset (0x10014)

| <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                | gpio1a7_sel<br>3'h0: GPIO1_A7_u<br>3'h1: SDMMC0_D3<br>3'h2: UART3_TX_M1<br>3'h3: A7_JTAG_TMS_M0<br>3'h4: MCU_JTAG_TMS<br>Others: Reserved  |
| 11         | RO          | 0x0                | reserved                                                                                                                                   |
| 10:8       | RW          | 0x0                | gpio1a6_sel<br>3'h0: GPIO1_A6_u<br>3'h1: SDMMC0_D2<br>3'h2: UART3_RX_M1<br>3'h3: A7_JTAG_TCK_M0<br>3'h4: MCU_JTAG_TCK<br>Others: Reserved  |
| 7          | RO          | 0x0                | reserved                                                                                                                                   |
| 6:4        | RW          | 0x0                | gpio1a5_sel<br>3'h0: GPIO1_A5_u<br>3'h1: SDMMC0_D1<br>3'h2: TEST_CLK0_OUT<br>3'h3: UART2_TX_M0<br>3'h4: MCU_JTAG_TRSTN<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                                                   |
| 2:0        | RW          | 0x0                | gpio1a4_sel<br>3'h0: GPIO1_A4_u<br>3'h1: SDMMC0_D0<br>3'h2: TEST_CLK1_OUT<br>3'h3: UART2_RX_M0<br>Others: Reserved                         |

**GRF GPIO1B\_IOMUX\_L**

Address: Operational Base + offset (0x10018)

| <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: GPIO1_B3_u<br>3'h1: SDIO_CMD<br>Others: Reserved                                                             |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio1b2_sel<br>3'h0: GPIO1_B2_d<br>3'h1: SDIO_CLK<br>Others: Reserved                                                             |
| 7          | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 6:4        | RW          | 0x0                | gpio1b1_sel<br>3'h0: GPIO1_B1_u<br>3'h1: SDMMC0_CMD<br>3'h2: UART3_CTSN_M1<br>3'h4: MCU_JTAG_TDI<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                             |
| 2:0        | RW          | 0x0                | gpio1b0_sel<br>3'h0: GPIO1_B0_u<br>3'h1: SDMMC0_CLK<br>3'h2: UART3_RTSN_M1<br>3'h4: MCU_JTAG_TDO<br>Others: Reserved |

**GRF GPIO1B\_IOMUX\_H**

Address: Operational Base + offset (0x1001C)

| <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                | gpio1b7_sel<br>3'h0: GPIO1_B7_u<br>3'h1: SDIO_D3<br>Others: Reserved                                                              |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio1b6_sel<br>3'h0: GPIO1_B6_u<br>3'h1: SDIO_D2<br>Others: Reserved                                                              |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio1b5_sel<br>3'h0: GPIO1_B5_u<br>3'h1: SDIO_D1<br>Others: Reserved                                                              |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio1b4_sel<br>3'h0: GPIO1_B4_u<br>3'h1: SDIO_D0<br>Others: Reserved                                                              |

**GRF GPIO1C\_IOMUX\_L**

Address: Operational Base + offset (0x10020)

| <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: GPIO1_C3_u<br>3'h1: UART0_TX<br>Others: Reserved                                                             |
| 11         | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 10:8       | RW          | 0x0                | gpio1c2_sel<br>3'h0: GPIO1_C2_u<br>3'h1: UART0_RX<br>Others: Reserved   |
| 7          | RO          | 0x0                | reserved                                                                |
| 6:4        | RW          | 0x0                | gpio1c1_sel<br>3'h0: GPIO1_C1_u<br>3'h1: UART0_CTSN<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                |
| 2:0        | RW          | 0x0                | gpio1c0_sel<br>3'h0: GPIO1_C0_u<br>3'h1: UART0_RTSN<br>Others: Reserved |

**GRF GPIO1C IOMUX H**

Address: Operational Base + offset (0x10024)

| <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                | gpio1c7_sel<br>3'h0: GPIO1_C7_d<br>3'h1: I2S2_LRCK_M0<br>3'h3: SPI1_CS0N_M1<br>3'h5: UART1_CTSN_M1<br>Others: Reserved                           |
| 11         | RO          | 0x0                | reserved                                                                                                                                         |
| 10:8       | RW          | 0x0                | gpio1c6_sel<br>3'h0: GPIO1_C6_d<br>3'h1: I2S2_SCLK_M0<br>3'h3: SPI1_CLK_M1<br>3'h4: PRELIGHT_TRIG_OUT<br>3'h5: UART1_RTSN_M1<br>Others: Reserved |
| 7          | RO          | 0x0                | reserved                                                                                                                                         |
| 6:4        | RW          | 0x0                | gpio1c5_sel<br>3'h0: GPIO1_C5_d<br>3'h1: I2S2_SDI_M0<br>3'h3: SPI1_MISO_M1<br>3'h4: FLASH_TRIG_IN<br>Others: Reserved                            |
| 3          | RO          | 0x0                | reserved                                                                                                                                         |
| 2:0        | RW          | 0x0                | gpio1c4_sel<br>3'h0: GPIO1_C4_d<br>3'h1: I2S2_SDO_M0<br>3'h3: SPI1_MOSI_M1<br>3'h4: FLASH_TRIG_OUT<br>Others: Reserved                           |

**GRF GPIO1D IOMUX L**

Address: Operational Base + offset (0x10028)

| <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                | gpio1d3_sel<br>3'h0: GPIO1_D3_u<br>3'h1: I2C1_SCL<br>3'h3: UART4_CTSN_M2<br>Others: Reserved                                                                |
| 11         | RO          | 0x0                | reserved                                                                                                                                                    |
| 10:8       | RW          | 0x0                | gpio1d2_sel<br>3'h0: GPIO1_D2_u<br>3'h1: I2C1_SDA<br>3'h3: UART4_RTSN_M2<br>Others: Reserved                                                                |
| 7          | RO          | 0x0                | reserved                                                                                                                                                    |
| 6:4        | RW          | 0x0                | gpio1d1_sel<br>3'h0: GPIO1_D1_d<br>3'h2: SDIO_PWR<br>3'h4: I2C5_SDA_M2<br>3'h5: UART1_RX_M1<br>Others: Reserved                                             |
| 3          | RO          | 0x0                | reserved                                                                                                                                                    |
| 2:0        | RW          | 0x0                | gpio1d0_sel<br>3'h0: GPIO1_D0_d<br>3'h1: I2S2_MCLK_M0<br>3'h2: SDIO_DET<br>3'h3: SPI1_CS1N_M1<br>3'h4: I2C5_SCL_M2<br>3'h5: UART1_TX_M1<br>Others: Reserved |

**GRF GPIO1D\_IOMUX\_H**

Address: Operational Base + offset (0x1002C)

| <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                | gpio1d7_sel<br>3'h0: GPIO1_D7_d<br>3'h1: SPI0_MISO_M1<br>3'h2: I2S1_LRCK_M1<br>3'h3: I2C3_SDA_M2<br>Others: Reserved              |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio1d6_sel<br>3'h0: GPIO1_D6_d<br>3'h1: SPI0_MOSI_M1<br>3'h2: I2S1_SCLK_M1<br>3'h3: I2C3_SCL_M2<br>Others: Reserved              |
| 7          | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 6:4        | RW          | 0x0                | gpio1d5_sel<br>3'h0: GPIO1_D5_d<br>3'h1: SPI0_CS1N_M1<br>3'h2: I2S1_MCLK_M1<br>3'h3: UART4_TX_M2<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                             |
| 2:0        | RW          | 0x0                | gpio1d4_sel<br>3'h0: GPIO1_D4_d<br>3'h3: UART4_RX_M2<br>Others: Reserved                                             |

**GRF GPIO2A\_IOMUX\_L**

Address: Operational Base + offset (0x10030)

| <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                | gpio2a3_sel<br>3'h0: GPIO2_A3_d<br>3'h1: MIPICSI_CLK0<br>3'h3: UART5_CTSN_M2<br>Others: Reserved                                  |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio2a2_sel<br>3'h0: GPIO2_A2_d<br>3'h1: MIPICSI_CLK1<br>3'h3: UART5_RTSN_M2<br>Others: Reserved                                  |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio2a1_sel<br>3'h0: GPIO2_A1_d<br>3'h1: SPI0_CLK_M1<br>3'h2: I2S1_SDO_M1<br>3'h3: UART5_RX_M2<br>Others: Reserved                |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio2a0_sel<br>3'h0: GPIO2_A0_d<br>3'h1: SPI0_CS0N_M1<br>3'h2: I2S1_SDI_M1<br>3'h3: UART5_TX_M2<br>Others: Reserved               |

**GRF GPIO2A\_IOMUX\_H**

Address: Operational Base + offset (0x10034)

| <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                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:12      | RW          | 0x0                | gpio2a7_sel<br>3'h0: GPIO2_A7_d<br>3'h1: LCDC_D3<br>3'h2: I2S2_SDO_M1<br>3'h4: UART4_RX_M1<br>3'h5: PWM4_PIN_M1<br>3'h6: SPI0_CS0N_M2<br>Others: Reserved |
| 11         | RO          | 0x0                | reserved                                                                                                                                                  |
| 10:8       | RW          | 0x0                | gpio2a6_sel<br>3'h0: GPIO2_A6_d<br>3'h1: LCDC_D2<br>3'h2: RGMII_COL_M1<br>3'h3: CIF_D2_M1<br>3'h4: UART4_TX_M1<br>3'h5: PWM5_PIN_M1<br>Others: Reserved   |
| 7          | RO          | 0x0                | reserved                                                                                                                                                  |
| 6:4        | RW          | 0x0                | gpio2a5_sel<br>3'h0: GPIO2_A5_d<br>3'h1: LCDC_D1<br>3'h2: RGMII_CRS_M1<br>3'h3: CIF_D1_M1<br>3'h4: UART4_CTSN_M1<br>3'h7: I2C5_SCL_M0<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                                                                  |
| 2:0        | RW          | 0x0                | gpio2a4_sel<br>3'h0: GPIO2_A4_d<br>3'h1: LCDC_D0<br>3'h2: RGMII_TXD3_M1<br>3'h3: CIF_D0_M1<br>3'h4: UART4_RTSN_M1<br>Others: Reserved                     |

**GRF GPIO2B\_IOMUX\_L**

Address: Operational Base + offset (0x10038)

| <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                | gpio2b3_sel<br>3'h0: GPIO2_B3_d<br>3'h1: LCDC_D7<br>3'h2: I2S2_MCLK_M1<br>3'h3: CIF_D3_M1<br>3'h4: UART5_CTSN_M1<br>3'h5: PWM0_PIN_M1<br>3'h6: SPI0_CS1N_M2<br>3'h7: I2C5_SDA_M0 |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RW          | 0x0                | gpio2b2_sel<br>3'h0: GPIO2_B2_d<br>3'h1: LCDC_D6<br>3'h2: I2S2_LRCK_M1<br>3'h4: UART5_RTSN_M1<br>3'h5: PWM1_PIN_M1<br>3'h6: SPI0_CLK_M2<br>Others: Reserved |
| 7          | RO          | 0x0                | reserved                                                                                                                                                    |
| 6:4        | RW          | 0x0                | gpio2b1_sel<br>3'h0: GPIO2_B1_d<br>3'h1: LCDC_D5<br>3'h2: I2S2_SCLK_M1<br>3'h4: UART5_RX_M1<br>3'h5: PWM2_PIN_M1<br>3'h6: SPI0_MISO_M2<br>Others: Reserved  |
| 3          | RO          | 0x0                | reserved                                                                                                                                                    |
| 2:0        | RW          | 0x0                | gpio2b0_sel<br>3'h0: GPIO2_B0_d<br>3'h1: LCDC_D4<br>3'h2: I2S2_SDI_M1<br>3'h4: UART5_TX_M1<br>3'h5: PWM3_PIN_M1<br>3'h6: SPI0_MOSI_M2<br>Others: Reserved   |

**GRF GPIO2B\_IOMUX\_H**

Address: Operational Base + offset (0x1003C)

| <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                | gpio2b7_sel<br>3'h0: GPIO2_B7_d<br>3'h1: LCDC_D11<br>3'h2: RGMII_CLK_M1<br>3'h3: CIF_D7_M1<br>Others: Reserved                    |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio2b6_sel<br>3'h0: GPIO2_B6_d<br>3'h1: LCDC_D10<br>3'h2: RGMII_RXD1_M1<br>3'h3: CIF_D6_M1<br>Others: Reserved                   |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio2b5_sel<br>3'h0: GPIO2_B5_d<br>3'h1: LCDC_D9<br>3'h2: RGMII_RXD0_M1<br>3'h3: CIF_D5_M1<br>Others: Reserved                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------|
| 3          | RO          | 0x0                | reserved                                                                                                       |
| 2:0        | RW          | 0x0                | gpio2b4_sel<br>3'h0: GPIO2_B4_d<br>3'h1: LCDC_D8<br>3'h2: RGMII_RXDV_M1<br>3'h3: CIF_D4_M1<br>Others: Reserved |

**GRF GPIO2C IOMUX L**

Address: Operational Base + offset (0x10040)

| <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                | gpio2c3_sel<br>3'h0: GPIO2_C3_d<br>3'h1: LCDC_D15<br>3'h2: RGMII_TXD0_M1<br>3'h3: CIF_D11_M1<br>Others: Reserved                  |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio2c2_sel<br>3'h0: GPIO2_C2_d<br>3'h1: LCDC_D14<br>3'h2: RGMII_MDC_M1<br>3'h3: CIF_D10_M1<br>Others: Reserved                   |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio2c1_sel<br>3'h0: GPIO2_C1_d<br>3'h1: LCDC_D13<br>3'h2: RGMII_MDIO_M1<br>3'h3: CIF_D9_M1<br>Others: Reserved                   |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio2c0_sel<br>3'h0: GPIO2_C0_d<br>3'h1: LCDC_D12<br>3'h2: RGMII_RXER_M1<br>3'h3: CIF_D8_M1<br>Others: Reserved                   |

**GRF GPIO2C IOMUX H**

Address: Operational Base + offset (0x10044)

| <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                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 14:12      | RW          | 0x0                | gpio2c7_sel<br>3'h0: GPIO2_C7_d<br>3'h1: LCDC_D19<br>3'h2: RGMII_RXD2_M1<br>3'h3: CIF_D15_M1<br>3'h6: I2S1_MCLK_M2<br>Others: Reserved |
| 11         | RO          | 0x0                | reserved                                                                                                                               |
| 10:8       | RW          | 0x0                | gpio2c6_sel<br>3'h0: GPIO2_C6_d<br>3'h1: LCDC_D18<br>3'h2: RGMII_TXEN_M1<br>3'h3: CIF_D14_M1<br>Others: Reserved                       |
| 7          | RO          | 0x0                | reserved                                                                                                                               |
| 6:4        | RW          | 0x0                | gpio2c5_sel<br>3'h0: GPIO2_C5_d<br>3'h1: LCDC_D17<br>3'h2: CLK_OUT_ETHERNET_M1<br>3'h3: CIF_D13_M1<br>Others: Reserved                 |
| 3          | RO          | 0x0                | reserved                                                                                                                               |
| 2:0        | RW          | 0x0                | gpio2c4_sel<br>3'h0: GPIO2_C4_d<br>3'h1: LCDC_D16<br>3'h2: RGMII_TXD1_M1<br>3'h3: CIF_D12_M1<br>Others: Reserved                       |

**GRF GPIO2D\_IOMUX\_L**

Address: Operational Base + offset (0x10048)

| <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                | gpio2d3_sel<br>3'h0: GPIO2_D3_d<br>3'h1: LCDC_D23<br>3'h2: RGMII_RXCLK_M1<br>3'h3: CIF_HSYNC_M1<br>3'h6: I2S1_SDI_M2<br>Others: Reserved  |
| 11         | RO          | 0x0                | reserved                                                                                                                                  |
| 10:8       | RW          | 0x0                | gpio2d2_sel<br>3'h0: GPIO2_D2_d<br>3'h1: LCDC_D22<br>3'h2: RGMII_TXCLK_M1<br>3'h3: CIF_CLKIN_M1<br>3'h6: I2S1_LRCK_M2<br>Others: Reserved |
| 7          | RO          | 0x0                | reserved                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4        | RW          | 0x0                | gpio2d1_sel<br>3'h0: GPIO2_D1_d<br>3'h1: LCDC_D21<br>3'h2: RGMII_TXD2_M1<br>3'h3: CIF_CLKOUT_M1<br>3'h6: I2S1_SCLK_M2<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                                                  |
| 2:0        | RW          | 0x0                | gpio2d0_sel<br>3'h0: GPIO2_D0_d<br>3'h1: LCDC_D20<br>3'h2: RGMII_RXD3_M1<br>3'h3: CIF_VSYNC_M1<br>3'h6: I2S1_SDO_M2<br>Others: Reserved   |

**GRF GPIO2D\_IOMUX\_H**

Address: Operational Base + offset (0x1004C)

| <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                | gpio2d7_sel<br>3'h0: GPIO2_D7_d<br>3'h1: LCDC_CLK<br>3'h4: UART3_CTSN_M2<br>3'h5: PWM8_PIN_M1<br>3'h6: SPI1_MISO_M2<br>Others: Reserved   |
| 11         | RO          | 0x0                | reserved                                                                                                                                  |
| 10:8       | RW          | 0x0                | gpio2d6_sel<br>3'h0: GPIO2_D6_d<br>3'h1: LCDC_VSYNC<br>3'h4: UART3_RTSN_M2<br>3'h5: PWM9_PIN_M1<br>3'h6: SPI1_MOSI_M2<br>Others: Reserved |
| 7          | RO          | 0x0                | reserved                                                                                                                                  |
| 6:4        | RW          | 0x0                | gpio2d5_sel<br>3'h0: GPIO2_D5_d<br>3'h1: LCDC_HSYNC<br>3'h5: PWM10_PIN_M1<br>3'h6: SPI1_CLK_M2<br>3'h7: I2C3_SDA_M1<br>Others: Reserved   |
| 3          | RO          | 0x0                | reserved                                                                                                                                  |
| 2:0        | RW          | 0x0                | gpio2d4_sel<br>3'h0: GPIO2_D4_d<br>3'h1: LCDC_DEN<br>3'h5: PWM6_PIN_M1<br>3'h6: SPI1_CS0N_M2<br>3'h7: I2C3_SCL_M1<br>Others: Reserved     |

**GRF GPIO3A IOMUX L**

Address: Operational Base + offset (0x10050)

| <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                | gpio3a3_sel<br>3'h0: GPIO3_A3_u<br>3'h1: UART2_RX_M1<br>3'h2: A7_JTAG_TMS_M1<br>Others: Reserved                                                             |
| 11         | RO          | 0x0                | reserved                                                                                                                                                     |
| 10:8       | RW          | 0x0                | gpio3a2_sel<br>3'h0: GPIO3_A2_u<br>3'h1: UART2_TX_M1<br>3'h2: A7_JTAG_TCK_M1<br>Others: Reserved                                                             |
| 7          | RO          | 0x0                | reserved                                                                                                                                                     |
| 6:4        | RW          | 0x0                | gpio3a1_sel<br>3'h0: GPIO3_A1_u<br>3'h3: CAN_RXD_M0<br>3'h4: UART3_RX_M2<br>3'h5: PWM11_PIN_M1<br>3'h7: I2C4_SDA_M0<br>Others: Reserved                      |
| 3          | RO          | 0x0                | reserved                                                                                                                                                     |
| 2:0        | RW          | 0x0                | gpio3a0_sel<br>3'h0: GPIO3_A0_u<br>3'h3: CAN_RXD_M0<br>3'h4: UART3_TX_M2<br>3'h5: PWM7_PIN_M1<br>3'h6: SPI1_CS1N_M2<br>3'h7: I2C4_SCL_M0<br>Others: Reserved |

**GRF GPIO3A IOMUX H**

Address: Operational Base + offset (0x10054)

| <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                | gpio3a7_sel<br>3'h0: GPIO3_A7_d<br>3'h1: CIF_D3_M0<br>3'h2: RGMII_RXD2_M0<br>3'h3: I2S0_SDI0_M1<br>3'h4: UART5_RX_M0<br>3'h5: CAN_RXD_M1<br>3'h6: PWM11_PIN_M0<br>Others: Reserved |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8       | RW          | 0x0                | gpio3a6_sel<br>3'h0: GPIO3_A6_d<br>3'h1: CIF_D2_M0<br>3'h2: RGMII_COL_M0<br>3'h3: I2S0_SDO0_M1<br>3'h4: UART5_TX_M0<br>3'h5: CAN_RXD_M1<br>3'h6: PWM10_PIN_M0<br>Others: Reserved    |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                             |
| 6:4        | RW          | 0x0                | gpio3a5_sel<br>3'h0: GPIO3_A5_d<br>3'h1: CIF_D1_M0<br>3'h2: RGMII_CRS_M0<br>3'h3: I2S0_LRCK_TX_M1<br>3'h4: UART4_RX_M0<br>3'h5: I2C3_SDA_M0<br>3'h6: PWM9_PIN_M0<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                             |
| 2:0        | RW          | 0x0                | gpio3a4_sel<br>3'h0: GPIO3_A4_d<br>3'h1: CIF_D0_M0<br>3'h3: I2S0_SCLK_TX_M1<br>3'h4: UART4_TX_M0<br>3'h5: I2C3_SCL_M0<br>3'h6: PWM8_PIN_M0<br>Others: Reserved                       |

**GRF GPIO3B\_IOMUX\_L**

Address: Operational Base + offset (0x10058)

| <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                | gpio3b3_sel<br>3'h0: GPIO3_B3_d<br>3'h1: CIF_D7_M0<br>3'h2: RGMII_TXD0_M0<br>3'h3: I2S0_SDO1_SDI3_M1<br>3'h4: UART4_CTSN_M0<br>Others: Reserved |
| 11         | RO          | 0x0                | reserved                                                                                                                                        |
| 10:8       | RW          | 0x0                | gpio3b2_sel<br>3'h0: GPIO3_B2_d<br>3'h1: CIF_D6_M0<br>3'h2: RGMII_TXD3_M0<br>3'h3: I2S0_LRCK_RX_M1<br>3'h4: UART4_RTSN_M0<br>Others: Reserved   |
| 7          | RO          | 0x0                | reserved                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4        | RW          | 0x0                | gpio3b1_sel<br>3'h0: GPIO3_B1_d<br>3'h1: CIF_D5_M0<br>3'h2: RGMII_TXD2_M0<br>3'h3: I2S0_SCLK_RX_M1<br>3'h4: UART5_CTSN_M0<br>3'h5: I2C5_SDA_M1<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                                                                           |
| 2:0        | RW          | 0x0                | gpio3b0_sel<br>3'h0: GPIO3_B0_d<br>3'h1: CIF_D4_M0<br>3'h2: RGMII_RXD3_M0<br>3'h3: I2S0_MCLK_M1<br>3'h4: UART5_RTSN_M0<br>3'h5: I2C5_SCL_M1<br>Others: Reserved    |

**GRF GPIO3B\_IOMUX\_H**

Address: Operational Base + offset (0x1005C)

| <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                | gpio3b7_sel<br>3'h0: GPIO3_B7_d<br>3'h1: CIF_D11_M0<br>3'h2: RGMII_RXD1_M0<br>3'h3: PDM_SDI3_M1<br>3'h5: SPI1_MISO_M0<br>Others: Reserved      |
| 11         | RO          | 0x0                | reserved                                                                                                                                       |
| 10:8       | RW          | 0x0                | gpio3b6_sel<br>3'h0: GPIO3_B6_d<br>3'h1: CIF_D10_M0<br>3'h2: RGMII_RXD0_M0<br>3'h3: PDM_SDI2_M1<br>3'h5: SPI1_MOSI_M0<br>Others: Reserved      |
| 7          | RO          | 0x0                | reserved                                                                                                                                       |
| 6:4        | RW          | 0x0                | gpio3b5_sel<br>3'h0: GPIO3_B5_d<br>3'h1: CIF_D9_M0<br>3'h2: RGMII_TXEN_M0<br>3'h3: I2S0_SDO3_SDI1_M1<br>3'h5: SPI1_CS0N_M0<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                                                       |

| Bit | Attr | Reset Value | Description                                                                                                                                    |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | RW   | 0x0         | gpio3b4_sel<br>3'h0: GPIO3_B4_d<br>3'h1: CIF_D8_M0<br>3'h2: RGMII_TXD1_M0<br>3'h3: I2S0_SDO2_SDI2_M1<br>3'h5: SPI1_CS1N_M0<br>Others: Reserved |

**GRF GPIO3C\_IOMUX\_L**

Address: Operational Base + offset (0x10060)

| 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         | gpio3c3_sel<br>3'h0: GPIO3_C3_d<br>3'h1: CIF_D15_M0<br>3'h2: RGMII_MDIO_M0<br>3'h3: PDM_CLK1_M1<br>Others: Reserved                     |
| 11    | RO   | 0x0         | reserved                                                                                                                                |
| 10:8  | RW   | 0x0         | gpio3c2_sel<br>3'h0: GPIO3_C2_d<br>3'h1: CIF_D14_M0<br>3'h2: RGMII_RXER_M0<br>3'h3: PDM_SDI1_M1<br>Others: Reserved                     |
| 7     | RO   | 0x0         | reserved                                                                                                                                |
| 6:4   | RW   | 0x0         | gpio3c1_sel<br>3'h0: GPIO3_C1_d<br>3'h1: CIF_D13_M0<br>3'h2: RGMII_RXDV_M0<br>3'h3: PDM_SDI0_M1<br>Others: Reserved                     |
| 3     | RO   | 0x0         | reserved                                                                                                                                |
| 2:0   | RW   | 0x0         | gpio3c0_sel<br>3'h0: GPIO3_C0_d<br>3'h1: CIF_D12_M0<br>3'h2: RGMII_CLK_M0<br>3'h3: PDM_CLK0_M1<br>3'h5: SPI1_CLK_M0<br>Others: Reserved |

**GRF GPIO3C\_IOMUX\_H**

Address: Operational Base + offset (0x10064)

| 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                | gpio3c7_sel<br>3'h0: GPIO3_C7_d<br>3'h1: CIF_HSYNC_M0<br>3'h2: RGMII_RXCLK_M0<br>3'h4: UART3_RX_M0<br>Others: Reserved        |
| 11         | RO          | 0x0                | reserved                                                                                                                      |
| 10:8       | RW          | 0x0                | gpio3c6_sel<br>3'h0: GPIO3_C6_d<br>3'h1: CIF_CLKOUT_M0<br>3'h2: RGMII_TXCLK_M0<br>3'h4: UART3_TX_M0<br>Others: Reserved       |
| 7          | RO          | 0x0                | reserved                                                                                                                      |
| 6:4        | RW          | 0x0                | gpio3c5_sel<br>3'h0: GPIO3_C5_d<br>3'h1: CIF_CLKIN_M0<br>3'h2: CLK_OUT_ETHERNET_M0<br>3'h4: UART3_CTSN_M0<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                                      |
| 2:0        | RW          | 0x0                | gpio3c4_sel<br>3'h0: GPIO3_C4_d<br>3'h1: CIF_VSYNC_M0<br>3'h2: RGMII_MDC_M0<br>3'h4: UART3_RTSN_M0<br>Others: Reserved        |

**GRF GPIO3D\_IOMUX\_L**

Address: Operational Base + offset (0x10068)

| <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: GPIO3_D3_d<br>3'h1: I2S0_LRCK_TX_M0<br>3'h3: ACODEC_DAC_SYNC<br>3'h4: AUDPWM_L_M1<br>3'h5: AUDDSM_LN<br>Others: Reserved |
| 11         | RO          | 0x0                | reserved                                                                                                                                      |
| 10:8       | RW          | 0x0                | gpio3d2_sel<br>3'h0: GPIO3_D2_d<br>3'h1: I2S0_MCLK_M0<br>Others: Reserved                                                                     |
| 7          | RO          | 0x0                | reserved                                                                                                                                      |
| 6:4        | RW          | 0x0                | gpio3d1_sel<br>3'h0: GPIO3_D1_d<br>3'h1: I2S0_SCLK_RX_M0<br>3'h2: PDM_CLK1_M0<br>3'h3: ACODEC_ADC_CLK<br>Others: Reserved                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 3          | RO          | 0x0                | reserved                                                                                             |
| 2:0        | RW          | 0x0                | gpio3d0_sel<br>3'h0: GPIO3_D0_d<br>3'h1: I2S0_SCLK_TX_M0<br>3'h3: ACODEC_DAC_CLK<br>Others: Reserved |

**GRF GPIO3D\_IOMUX\_H**

Address: Operational Base + offset (0x1006C)

| <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                | gpio3d7_sel<br>3'h0: GPIO3_D7_d<br>3'h1: I2S0_SDO1_SDI3_M0<br>3'h2: PDM_SDI3_M0<br>3'h3: ACODEC_ADC_DATA<br>Others: Reserved                |
| 11         | RO          | 0x0                | reserved                                                                                                                                    |
| 10:8       | RW          | 0x0                | gpio3d6_sel<br>3'h0: GPIO3_D6_d<br>3'h1: I2S0_SDI0_M0<br>3'h2: PDM_SDI0_M0<br>3'h3: ACODEC_DAC_DATAL<br>Others: Reserved                    |
| 7          | RO          | 0x0                | reserved                                                                                                                                    |
| 6:4        | RW          | 0x0                | gpio3d5_sel<br>3'h0: GPIO3_D5_d<br>3'h1: I2S0_SDO0_M0<br>3'h3: ACODEC_DAC_DATAR<br>3'h4: AUDPWM_R_M1<br>3'h5: AUDDSM_LP<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                                                    |
| 2:0        | RW          | 0x0                | gpio3d4_sel<br>3'h0: GPIO3_D4_d<br>3'h1: I2S0_LRCK_RX_M0<br>3'h2: PDM_CLK0_M0<br>3'h3: ACODEC_ADC_SYNC<br>Others: Reserved                  |

**GRF GPIO4A\_IOMUX\_L**

Address: Operational Base + offset (0x10070)

| <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                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4        | RW          | 0x0                | gpio4a1_sel<br>3'h0: GPIO4_A1_d<br>3'h1: I2S0_SDO3_SDI1_M0<br>3'h2: PDM_SDI1_M0<br>3'h3: AUDPWM_R_M0<br>3'h4: I2C4_SDA_M1<br>3'h5: AUDDSM_RP<br>Others: Reserved |
| 3          | RO          | 0x0                | reserved                                                                                                                                                         |
| 2:0        | RW          | 0x0                | gpio4a0_sel<br>3'h0: GPIO4_A0_d<br>3'h1: I2S0_SDO2_SDI2_M0<br>3'h2: PDM_SDI2_M0<br>3'h3: AUDPWM_L_M0<br>3'h4: I2C4_SCL_M1<br>3'h5: AUDDSM_RN<br>Others: Reserved |

**GRF GPIO0C DS H**

Address: Operational Base + offset (0x10080)

| <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      | RW          | 0x1                | gpio0c7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio0c6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio0c5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio0c4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO0D DS L**

Address: Operational Base + offset (0x10084)

| <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      | RW          | 0x1                | gpio0d3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio0d2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio0d1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio0d0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIOOD DS H**

Address: Operational Base + offset (0x10088)

| <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      | RW          | 0x2                | gpio0d7_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x1                | gpio0d6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 7:4        | RW          | 0x1                | gpio0d5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 3:0        | RW          | 0x1                | gpio0d4_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

**GRF GPIO1A DS L**

Address: Operational Base + offset (0x10090)

| <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      | RW          | 0x2                | gpio1a3_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x1                | gpio1a2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio1a1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio1a0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO1A DS H**

Address: Operational Base + offset (0x10094)

| <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      | RW          | 0x1                | gpio1a7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio1a6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio1a5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio1a4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO1B DS L**

Address: Operational Base + offset (0x10098)

| <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      | RW          | 0x1                | gpio1b3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 11:8       | RW          | 0x2                | gpio1b2_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 7:4        | RW          | 0x1                | gpio1b1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 3:0        | RW          | 0x2                | gpio1b0_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

**GRF GPIO1B DS H**

Address: Operational Base + offset (0x1009C)

| <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      | RW          | 0x1                | gpio1b7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio1b6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio1b5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio1b4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO1C DS L**

Address: Operational Base + offset (0x100A0)

| <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      | RW          | 0x1                | gpio1c3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio1c2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio1c1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x1                | gpio1c0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO1C DS H**

Address: Operational Base + offset (0x100A4)

| <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      | RW          | 0x1                | gpio1c7_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 11:8       | RW          | 0x1                | gpio1c6_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 7:4        | RW          | 0x1                | gpio1c5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x1                | gpio1c4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO1D DS L**

Address: Operational Base + offset (0x100A8)

| <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      | RW          | 0x1                | gpio1d3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 11:8       | RW          | 0x1                | gpio1d2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 7:4        | RW          | 0x1                | gpio1d1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 3:0        | RW          | 0x1                | gpio1d0_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

**GRF GPIO1D DS H**

Address: Operational Base + offset (0x100AC)

| <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      | RW          | 0x1                | gpio1d7_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 11:8       | RW          | 0x1                | gpio1d6_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 7:4        | RW          | 0x1                | gpio1d5_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x1                | gpio1d4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO2A DS L**

Address: Operational Base + offset (0x100B0)

| <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      | RW          | 0x2                | gpio2a3_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 11:8       | RW          | 0x2                | gpio2a2_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x1                | gpio2a1_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 3:0        | RW          | 0x1                | gpio2a0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |

**GRF GPIO2A DS H**

Address: Operational Base + offset (0x100B4)

| <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      | RW          | 0x1                | gpio2a7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio2a6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio2a5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio2a4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO2B DS L**

Address: Operational Base + offset (0x100B8)

| <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      | RW          | 0x1                | gpio2b3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio2b2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio2b1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio2b0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO2B DS H**

Address: Operational Base + offset (0x100BC)

| <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      | RW          | 0x1                | gpio2b7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio2b6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x1                | gpio2b5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio2b4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO2C DS L**

Address: Operational Base + offset (0x100C0)

| <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      | RW          | 0x1                | gpio2c3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio2c2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio2c1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio2c0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO2C DS H**

Address: Operational Base + offset (0x100C4)

| <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:12      | RW          | 0x1                | gpio2c7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                           |
| 11:8       | RW          | 0x1                | gpio2c6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                           |
| 7:4        | RW          | 0x1                | gpio2c5_ds<br>4'd0: Level 0 strength<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio2c4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                           |

**GRF GPIO2D DS L**

Address: Operational Base + offset (0x100C8)

| <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      | RW          | 0x1                | gpio2d3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio2d2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio2d1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x1                | gpio2d0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO2D DS H**

Address: Operational Base + offset (0x100CC)

| <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      | RW          | 0x2                | gpio2d7_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 11:8       | RW          | 0x1                | gpio2d6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 7:4        | RW          | 0x1                | gpio2d5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 3:0        | RW          | 0x1                | gpio2d4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |

**GRF GPIO3A DS L**

Address: Operational Base + offset (0x100D0)

| <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      | RW          | 0x1                | gpio3a3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio3a2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio3a1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio3a0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO3A DS H**

Address: Operational Base + offset (0x100D4)

| <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      | RW          | 0x1                | gpio3a7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio3a6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio3a5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x1                | gpio3a4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO3B DS L**

Address: Operational Base + offset (0x100D8)

| <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      | RW          | 0x1                | gpio3b3_ds<br>x'bxxx(bits < 4), x'xxxx(bits >= 4)                                                                                          |
| 11:8       | RW          | 0x1                | gpio3b2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio3b1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio3b0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO3B DS H**

Address: Operational Base + offset (0x100DC)

| <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      | RW          | 0x1                | gpio3b7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio3b6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4        | RW          | 0x1                | gpio3b5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio3b4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO3C DS L**

Address: Operational Base + offset (0x100E0)

| <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      | RW          | 0x1                | gpio3c3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio3c2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio3c1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio3c0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO3C DS H**

Address: Operational Base + offset (0x100E4)

| <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:12      | RW          | 0x1                | gpio3c7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio3c6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio3c5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio3c4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO3D DS L**

Address: Operational Base + offset (0x100E8)

| <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      | RW          | 0x1                | gpio3d3_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x1                | gpio3d2_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 7:4        | RW          | 0x1                | gpio3d1_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 3:0        | RW          | 0x1                | gpio3d0_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

**GRF GPIO3D DS H**

Address: Operational Base + offset (0x100EC)

| <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      | RW          | 0x1                | gpio3d7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 11:8       | RW          | 0x1                | gpio3d6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 7:4        | RW          | 0x1                | gpio3d5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 3:0        | RW          | 0x1                | gpio3d4_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

**GRF GPIO4A DS L**

Address: Operational Base + offset (0x100F0)

| <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:4        | RW          | 0x1                | gpio4a1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x1                | gpio4a0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**GRF GPIO0C\_P\_H**

Address: Operational Base + offset (0x10100)

| <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          | 0x1                | gpio0c7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x1                | gpio0c6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x1                | gpio0c5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 9:8        | RW          | 0x1                | gpio0c4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 7:0        | RO          | 0xaa               | reserved                                                                                                                          |

**GRF GPIO0D\_P**

Address: Operational Base + offset (0x10104)

| <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          | 0x2                | gpio0d7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio0d6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 11:10      | RW          | 0x1                | gpio0d5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 9:8        | RW          | 0x1                | gpio0d4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 7:6        | RW          | 0x1                | gpio0d3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 5:4        | RW          | 0x1                | gpio0d2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 3:2        | RW          | 0x1                | gpio0d1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 1:0        | RW          | 0x1                | gpio0d0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO1A\_P**

Address: Operational Base + offset (0x10108)

| <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          | 0x1                | gpio1a7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x1                | gpio1a6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x1                | gpio1a5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x1                | gpio1a4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 7:6        | RW          | 0x2                | gpio1a3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 5:4        | RW          | 0x1                | gpio1a2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 3:2        | RW          | 0x1                | gpio1a1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 1:0        | RW          | 0x2                | gpio1a0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO1B\_P**

Address: Operational Base + offset (0x1010C)

| <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          | 0x1                | gpio1b7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x1                | gpio1b6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x1                | gpio1b5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 9:8        | RW          | 0x1                | gpio1b4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 7:6        | RW          | 0x1                | gpio1b3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 5:4        | RW          | 0x2                | gpio1b2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 3:2        | RW          | 0x1                | gpio1b1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 1:0        | RW          | 0x1                | gpio1b0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO1C\_P**

Address: Operational Base + offset (0x10110)

| <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          | 0x2                | gpio1c7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio1c6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x2                | gpio1c5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 9:8        | RW          | 0x2                | gpio1c4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 7:6        | RW          | 0x1                | gpio1c3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 5:4        | RW          | 0x1                | gpio1c2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 3:2        | RW          | 0x1                | gpio1c1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 1:0        | RW          | 0x1                | gpio1c0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO1D\_P**

Address: Operational Base + offset (0x10114)

| <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          | 0x2                | gpio1d7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio1d6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x2                | gpio1d5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 9:8        | RW          | 0x2                | gpio1d4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 7:6        | RW          | 0x1                | gpio1d3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 5:4        | RW          | 0x1                | gpio1d2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 3:2        | RW          | 0x2                | gpio1d1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 1:0        | RW          | 0x2                | gpio1d0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO2A\_P**

Address: Operational Base + offset (0x10118)

| <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          | 0x2                | gpio2a7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio2a6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x2                | gpio2a5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 9:8        | RW          | 0x2                | gpio2a4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 7:6        | RW          | 0x2                | gpio2a3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 5:4        | RW          | 0x2                | gpio2a2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 3:2        | RW          | 0x2                | gpio2a1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x2                | gpio2a0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO2B\_P**

Address: Operational Base + offset (0x1011C)

| <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          | 0x2                | gpio2b7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio2b6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x2                | gpio2b5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 9:8        | RW          | 0x2                | gpio2b4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 7:6        | RW          | 0x2                | gpio2b3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 5:4        | RW          | 0x2                | gpio2b2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 3:2        | RW          | 0x2                | gpio2b1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 1:0        | RW          | 0x2                | gpio2b0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

**GRF GPIO2C\_P**

Address: Operational Base + offset (0x10120)

| <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          | 0x2                | gpio2c7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio2c6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x2                | gpio2c5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 9:8        | RW          | 0x2                | gpio2c4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 7:6        | RW          | 0x2                | gpio2c3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 5:4        | RW          | 0x2                | gpio2c2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 3:2        | RW          | 0x2                | gpio2c1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 1:0        | RW          | 0x2                | gpio2c0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

**GRF GPIO2D\_P**

Address: Operational Base + offset (0x10124)

| <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:14      | RW          | 0x2                | gpio2d7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 13:12      | RW          | 0x2                | gpio2d6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 11:10      | RW          | 0x2                | gpio2d5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 9:8        | RW          | 0x2                | gpio2d4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 7:6        | RW          | 0x2                | gpio2d3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 5:4        | RW          | 0x2                | gpio2d2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 3:2        | RW          | 0x2                | gpio2d1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 1:0        | RW          | 0x2                | gpio2d0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO3A\_P**

Address: Operational Base + offset (0x10128)

| <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          | 0x2                | gpio3a7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 13:12      | RW          | 0x2                | gpio3a6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 11:10      | RW          | 0x2                | gpio3a5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 9:8        | RW          | 0x2                | gpio3a4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 7:6        | RW          | 0x1                | gpio3a3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 5:4        | RW          | 0x1                | gpio3a2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 3:2        | RW          | 0x1                | gpio3a1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 1:0        | RW          | 0x1                | gpio3a0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO3B\_P**

Address: Operational Base + offset (0x1012C)

| <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          | 0x2                | gpio3b7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio3b6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 11:10      | RW          | 0x2                | gpio3b5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 9:8        | RW          | 0x2                | gpio3b4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 7:6        | RW          | 0x2                | gpio3b3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 5:4        | RW          | 0x2                | gpio3b2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 3:2        | RW          | 0x2                | gpio3b1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 1:0        | RW          | 0x2                | gpio3b0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO3C\_P**

Address: Operational Base + offset (0x10130)

| <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          | 0x2                | gpio3c7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio3c6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x2                | gpio3c5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 9:8        | RW          | 0x2                | gpio3c4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 7:6        | RW          | 0x2                | gpio3c3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 5:4        | RW          | 0x2                | gpio3c2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 3:2        | RW          | 0x2                | gpio3c1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 1:0        | RW          | 0x2                | gpio3c0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO3D\_P**

Address: Operational Base + offset (0x10134)

| <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          | 0x2                | gpio3d7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio3d6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x2                | gpio3d5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 9:8        | RW          | 0x2                | gpio3d4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 7:6        | RW          | 0x2                | gpio3d3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 5:4        | RW          | 0x2                | gpio3d2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 3:2        | RW          | 0x2                | gpio3d1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |
| 1:0        | RW          | 0x2                | gpio3d0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**GRF GPIO4A\_P**

Address: Operational Base + offset (0x10138)

| <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          | 0x2                | gpio4a1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 1:0        | RW          | 0x2                | gpio4a0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

**GRF GPIO0C IE H**

Address: Operational Base + offset (0x10140)

| <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                | gpio0c7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio0c6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 5          | RW          | 0x1                | gpio0c5_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 4          | RW          | 0x1                | gpio0c4_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 3:0        | RO          | 0xf                | reserved                                                |

**GRF GPIOOD IE**

Address: Operational Base + offset (0x10144)

| <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                | gpio0d7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio0d6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5          | RW          | 0x1                | gpio0d5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4          | RW          | 0x1                | gpio0d4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3          | RW          | 0x1                | gpio0d3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2          | RW          | 0x1                | gpio0d2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 1          | RW          | 0x1                | gpio0d1_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 0          | RW          | 0x1                | gpio0d0_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

**GRF GPIO1A IE**

Address: Operational Base + offset (0x10148)

| <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                | gpio1a7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio1a6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 5          | RW          | 0x1                | gpio1a5_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 4          | RW          | 0x1                | gpio1a4_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 3          | RW          | 0x1                | gpio1a3_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 2          | RW          | 0x1                | gpio1a2_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 1          | RW          | 0x1                | gpio1a1_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 0          | RW          | 0x1                | gpio1a0_ie<br>1'b0: Input disable<br>1'b1: Input enable |

**GRF GPIO1B IE**

Address: Operational Base + offset (0x1014C)

| <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                | gpio1b7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio1b6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5          | RW          | 0x1                | gpio1b5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4          | RW          | 0x1                | gpio1b4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3          | RW          | 0x1                | gpio1b3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2          | RW          | 0x1                | gpio1b2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 1          | RW          | 0x1                | gpio1b1_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 0          | RW          | 0x1                | gpio1b0_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

**GRF GPIO1C IE**

Address: Operational Base + offset (0x10150)

| <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_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio1c6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5          | RW          | 0x1                | gpio1c5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4          | RW          | 0x1                | gpio1c4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3          | RW          | 0x1                | gpio1c3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2          | RW          | 0x1                | gpio1c2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 1          | RW          | 0x1                | gpio1c1_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 0          | RW          | 0x1                | gpio1c0_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

**GRF GPIO1D IE**

Address: Operational Base + offset (0x10154)

| <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                | gpio1d7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio1d6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5          | RW          | 0x1                | gpio1d5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4          | RW          | 0x1                | gpio1d4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3          | RW          | 0x1                | gpio1d3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 2          | RW          | 0x1                | gpio1d2_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 1          | RW          | 0x1                | gpio1d1_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 0          | RW          | 0x1                | gpio1d0_ie<br>1'b0: Input disable<br>1'b1: Input enable |

**GRF GPIO2A IE**

Address: Operational Base + offset (0x10158)

| <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>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio2a6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5          | RW          | 0x1                | gpio2a5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4          | RW          | 0x1                | gpio2a4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3          | RW          | 0x1                | gpio2a3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2          | RW          | 0x1                | gpio2a2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 1          | RW          | 0x1                | gpio2a1_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 0          | RW          | 0x1                | gpio2a0_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

**GRF GPIO2B IE**

Address: Operational Base + offset (0x1015C)

| <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                | gpio2b7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 6          | RW          | 0x1                | gpio2b6_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 5          | RW          | 0x1                | gpio2b5_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 4          | RW          | 0x1                | gpio2b4_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 3          | RW          | 0x1                | gpio2b3_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 2          | RW          | 0x1                | gpio2b2_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 1          | RW          | 0x1                | gpio2b1_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 0          | RW          | 0x1                | gpio2b0_ie<br>1'b0: Input disable<br>1'b1: Input enable |

**GRF GPIO2C IE**

Address: Operational Base + offset (0x10160)

| <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                | gpio2c7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio2c6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5          | RW          | 0x1                | gpio2c5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4          | RW          | 0x1                | gpio2c4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3          | RW          | 0x1                | gpio2c3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2          | RW          | 0x1                | gpio2c2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 1          | RW          | 0x1                | gpio2c1_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 0          | RW          | 0x1                | gpio2c0_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

**GRF GPIO2D IE**

Address: Operational Base + offset (0x10164)

| 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         | gpio2d7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6     | RW   | 0x1         | gpio2d6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5     | RW   | 0x1         | gpio2d5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4     | RW   | 0x1         | gpio2d4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3     | RW   | 0x1         | gpio2d3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2     | RW   | 0x1         | gpio2d2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 1     | RW   | 0x1         | gpio2d1_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 0     | RW   | 0x1         | gpio2d0_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

**GRF GPIO3A IE**

Address: Operational Base + offset (0x10168)

| 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         | gpio3a7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6     | RW   | 0x1         | gpio3a6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5     | RW   | 0x1         | gpio3a5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4     | RW   | 0x1         | gpio3a4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3     | RW   | 0x1         | gpio3a3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 2          | RW          | 0x1                | gpio3a2_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 1          | RW          | 0x1                | gpio3a1_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 0          | RW          | 0x1                | gpio3a0_ie<br>1'b0: Input disable<br>1'b1: Input enable |

**GRF GPIO3B IE**

Address: Operational Base + offset (0x1016C)

| <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                | gpio3b7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio3b6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5          | RW          | 0x1                | gpio3b5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4          | RW          | 0x1                | gpio3b4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3          | RW          | 0x1                | gpio3b3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2          | RW          | 0x1                | gpio3b2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 1          | RW          | 0x1                | gpio3b1_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 0          | RW          | 0x1                | gpio3b0_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

**GRF GPIO3C IE**

Address: Operational Base + offset (0x10170)

| <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>1'b0: Input disable<br>1'b1: Input enable                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 6          | RW          | 0x1                | gpio3c6_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 5          | RW          | 0x1                | gpio3c5_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 4          | RW          | 0x1                | gpio3c4_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 3          | RW          | 0x1                | gpio3c3_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 2          | RW          | 0x1                | gpio3c2_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 1          | RW          | 0x1                | gpio3c1_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 0          | RW          | 0x1                | gpio3c0_ie<br>1'b0: Input disable<br>1'b1: Input enable |

**GRF GPIO3D IE**

Address: Operational Base + offset (0x10174)

| <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                | gpio3d7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio3d6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5          | RW          | 0x1                | gpio3d5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4          | RW          | 0x1                | gpio3d4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3          | RW          | 0x1                | gpio3d3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2          | RW          | 0x1                | gpio3d2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 1          | RW          | 0x1                | gpio3d1_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 0          | RW          | 0x1                | gpio3d0_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

**GRF GPIO4A IE**

Address: Operational Base + offset (0x10178)

| 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:2  | RO   | 0x3f        | reserved                                                                                                                          |
| 1     | RW   | 0x1         | gpio4a1_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 0     | RW   | 0x1         | gpio4a0_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

**GRF GPIO0C SMT H**

Address: Operational Base + offset (0x10180)

| 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   | 0x0         | gpio0c7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6     | RW   | 0x0         | gpio0c6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5     | RW   | 0x0         | gpio0c5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4     | RW   | 0x0         | gpio0c4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3:0   | RO   | 0x0         | reserved                                                                                                                          |

**GRF GPIO0D SMT**

Address: Operational Base + offset (0x10184)

| 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   | 0x0         | gpio0d7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6     | RW   | 0x0         | gpio0d6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5     | RW   | 0x0         | gpio0d5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 4          | RW          | 0x0                | gpio0d4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 3          | RW          | 0x0                | gpio0d3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 2          | RW          | 0x0                | gpio0d2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 1          | RW          | 0x0                | gpio0d1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 0          | RW          | 0x0                | gpio0d0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |

**GRF GPIO1A SMT**

Address: Operational Base + offset (0x10188)

| <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                | gpio1a7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio1a6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio1a5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio1a4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio1a3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 2          | RW          | 0x0                | gpio1a2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 1          | RW          | 0x0                | gpio1a1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio1a0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**GRF GPIO1B SMT**

Address: Operational Base + offset (0x1018C)

| <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                | gpio1b7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio1b6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio1b5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio1b4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio1b3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 2          | RW          | 0x0                | gpio1b2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 1          | RW          | 0x0                | gpio1b1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio1b0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**GRF GPIO1C SMT**

Address: Operational Base + offset (0x10190)

| <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_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio1c6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio1c5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio1c4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio1c3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 2          | RW          | 0x0                | gpio1c2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 1          | RW          | 0x0                | gpio1c1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 0          | RW          | 0x0                | gpio1c0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |

**GRF GPIO1D SMT**

Address: Operational Base + offset (0x10194)

| <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                | gpio1d7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio1d6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio1d5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio1d4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio1d3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 2          | RW          | 0x0                | gpio1d2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 1          | RW          | 0x0                | gpio1d1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio1d0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**GRF GPIO2A SMT**

Address: Operational Base + offset (0x10198)

| <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_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 6          | RW          | 0x0                | gpio2a6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 5          | RW          | 0x0                | gpio2a5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 4          | RW          | 0x0                | gpio2a4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 3          | RW          | 0x0                | gpio2a3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 2          | RW          | 0x0                | gpio2a2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 1          | RW          | 0x0                | gpio2a1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 0          | RW          | 0x0                | gpio2a0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |

**GRF GPIO2B SMT**

Address: Operational Base + offset (0x1019C)

| <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                | gpio2b7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio2b6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio2b5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio2b4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio2b3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 2          | RW          | 0x0                | gpio2b2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 1          | RW          | 0x0                | gpio2b1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio2b0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**GRF GPIO2C SMT**

Address: Operational Base + offset (0x101A0)

| <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                | gpio2c7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio2c6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio2c5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio2c4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio2c3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 2          | RW          | 0x0                | gpio2c2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 1          | RW          | 0x0                | gpio2c1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio2c0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**GRF GPIO2D SMT**

Address: Operational Base + offset (0x101A4)

| <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                | gpio2d7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio2d6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio2d5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio2d4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio2d3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 2          | RW          | 0x0                | gpio2d2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 1          | RW          | 0x0                | gpio2d1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 0          | RW          | 0x0                | gpio2d0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |

**GRF GPIO3A SMT**

Address: Operational Base + offset (0x101A8)

| <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_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio3a6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio3a5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio3a4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio3a3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 2          | RW          | 0x0                | gpio3a2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 1          | RW          | 0x0                | gpio3a1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio3a0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**GRF GPIO3B SMT**

Address: Operational Base + offset (0x101AC)

| <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                | gpio3b7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 6          | RW          | 0x0                | gpio3b6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 5          | RW          | 0x0                | gpio3b5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 4          | RW          | 0x0                | gpio3b4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 3          | RW          | 0x0                | gpio3b3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 2          | RW          | 0x0                | gpio3b2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 1          | RW          | 0x0                | gpio3b1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 0          | RW          | 0x0                | gpio3b0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |

**GRF GPIO3C SMT**

Address: Operational Base + offset (0x101B0)

| <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_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio3c6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio3c5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio3c4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio3c3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 2          | RW          | 0x0                | gpio3c2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 1          | RW          | 0x0                | gpio3c1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio3c0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**GRF GPIO3D SMT**

Address: Operational Base + offset (0x101B4)

| <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                | gpio3d7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio3d6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio3d5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio3d4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio3d3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 2          | RW          | 0x0                | gpio3d2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 1          | RW          | 0x0                | gpio3d1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio3d0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**GRF GPIO4A SMT**

Address: Operational Base + offset (0x101B8)

| <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_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio4a0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**GRF CSIPHY0 CON**

Address: Operational Base + offset (0x10200)

| <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                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | csiphy0_clk_inv<br>CSIPHY0 clock inverted.<br>1'b0: Disable<br>1'b1: Enable               |
| 8          | RW          | 0x0                | csiphy0_clklane_en<br>CSIPHY0 clock lane enable.<br>1'b0: Disable<br>1'b1: Enable         |
| 7          | RW          | 0x0                | csiphy0_enable_dat_3<br>CSIPHY0 lane3 data enable.<br>1'b0: Disable<br>1'b1: Enable       |
| 6          | RW          | 0x0                | csiphy0_enable_dat_2<br>CSIPHY0 lane2 data enable.<br>1'b0: Disable<br>1'b1: Enable       |
| 5          | RW          | 0x0                | csiphy0_enable_dat_1<br>CSIPHY0 lane1 data enable.<br>1'b0: Disable<br>1'b1: Enable       |
| 4          | RW          | 0x0                | csiphy0_enable_dat_0<br>CSIPHY0 lane0 data enable.<br>1'b0: Disable<br>1'b1: Enable       |
| 3          | RW          | 0x0                | csiphy0_forcerxmode_3<br>CSIPHY0 lane3 force to RX mode.<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x0                | csiphy0_forcerxmode_2<br>CSIPHY0 lane2 force to RX mode.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | csiphy0_forcerxmode_1<br>CSIPHY0 lane1 force to RX mode.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | csiphy0_forcerxmode_0<br>CSIPHY0 lane0 force to RX mode.<br>1'b0: Disable<br>1'b1: Enable |

**GRF CSIPHY0 STATUS**

Address: Operational Base + offset (0x10208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:11      | RO          | 0x000000           | reserved                                                                      |
| 10         | RW          | 0x0                | csiphy0_pin_errcontentionlp1_0<br>LP1 Contention error status                 |
| 9          | RW          | 0x0                | csiphy0_pin_errcontentionlp0_0<br>LP0 Contention error status                 |
| 8          | RW          | 0x0                | csiphy0_pin_rxskewcalhs_3<br>Lane3 high-speed receive skew calibration status |
| 7          | RW          | 0x0                | csiphy0_pin_rxskewcalhs_2<br>Lane2 high-speed receive skew calibration status |
| 6          | RW          | 0x0                | csiphy0_pin_rxskewcalhs_1<br>Lane1 high-speed receive skew calibration status |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | csiphy0_pin_rxskewcalhs_0<br>Lane0 high-speed receive skew calibration status                                                         |
| 4          | RW          | 0x0                | csiphy0_direction<br>Transmit/receive direction.<br>1'b0: Transmit mode<br>1'b1: Receive mode                                         |
| 3          | RW          | 0x0                | csiphy0_ulpssactivenot_3<br>Lane3 ULP active status.<br>This active low signal is asserted to indicate that the lane is in ULP state. |
| 2          | RW          | 0x0                | csiphy0_ulpssactivenot_2<br>Lane2 ULP active status.<br>This active low signal is asserted to indicate that the lane is in ULP state. |
| 1          | RW          | 0x0                | csiphy0_ulpssactivenot_1<br>Lane1 ULP active status.<br>This active low signal is asserted to indicate that the lane is in ULP state. |
| 0          | RW          | 0x0                | csiphy0_ulpssactivenot_0<br>Lane0 ULP active status.<br>This active low signal is asserted to indicate that the lane is in ULP state. |

**GRF CSIPHY1 CON**

Address: Operational Base + offset (0x10210)

| <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          | 0x0                | csiphy_clk_inv<br>CSIPHY1 clock inverted.<br>1'b0: Disable<br>1'b1: Enable                                                        |
| 8          | RW          | 0x0                | csiphy_clklane_en<br>CSIPHY1 clock lane enable.<br>1'b0: Disable<br>1'b1: Enable                                                  |
| 7          | RW          | 0x0                | csiphy1_enable_dat_3<br>CSIPHY1 lane3 data enable.<br>1'b0: Disable<br>1'b1: Enable                                               |
| 6          | RW          | 0x0                | csiphy1_enable_dat_2<br>CSIPHY1 lane2 data enable.<br>1'b0: Disable<br>1'b1: Enable                                               |
| 5          | RW          | 0x0                | csiphy1_enable_dat_1<br>CSIPHY1 lane1 data enable.<br>1'b0: Disable<br>1'b1: Enable                                               |
| 4          | RW          | 0x0                | csiphy1_enable_dat_0<br>CSIPHY1 lane0 data enable.<br>1'b0: Disable<br>1'b1: Enable                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | csiphy1_forcerxmode_3<br>CSIPHY1 lane3 force to RX mode.<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x0                | csiphy1_forcerxmode_2<br>CSIPHY1 lane2 force to RX mode.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | csiphy1_forcerxmode_1<br>CSIPHY1 lane1 force to RX mode.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | csiphy1_forcerxmode_0<br>CSIPHY1 lane 0force to RX mode.<br>1'b0: Disable<br>1'b1: Enable |

**GRF CSIPHY1 STATUS**

Address: Operational Base + offset (0x10218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:11      | RO          | 0x000000           | reserved                                                                                                                              |
| 10         | RW          | 0x0                | csiphy1_pin_errcontentionlp1_0<br>LP1 Contention error status                                                                         |
| 9          | RW          | 0x0                | csiphy1_pin_errcontentionlp0_0<br>LPO Contention error status                                                                         |
| 8          | RW          | 0x0                | csiphy1_pin_rxskewcalhs_3<br>Lane3 high-speed receive skew calibration status                                                         |
| 7          | RW          | 0x0                | csiphy1_pin_rxskewcalhs_2<br>Lane2 high-speed receive skew calibration status                                                         |
| 6          | RW          | 0x0                | csiphy1_pin_rxskewcalhs_1<br>Lane1 high-speed receive skew calibration status                                                         |
| 5          | RW          | 0x0                | csiphy1_pin_rxskewcalhs_0<br>Lane0 high-speed receive skew calibration status                                                         |
| 4          | RW          | 0x0                | csiphy1_direction<br>Transmit/Receive direction.<br>1'b0: Transmit mode<br>1'b1: Receive mode                                         |
| 3          | RW          | 0x0                | csiphy1_ulpssactivenot_3<br>Lane3 ULP active status.<br>This active low signal is asserted to indicate that the lane is in ULP state. |
| 2          | RW          | 0x0                | csiphy1_ulpssactivenot_2<br>Lane2 ULP active status.<br>This active low signal is asserted to indicate that the lane is in ULP state. |
| 1          | RW          | 0x0                | csiphy1_ulpssactivenot_1<br>Lane1 ULP active status.<br>This active low signal is asserted to indicate that the lane is in ULP state. |
| 0          | RW          | 0x0                | csiphy1_ulpssactivenot_0<br>Lane0 ULP active status.<br>This active low signal is asserted to indicate that the lane is in ULP state. |

**GRF DSIPHY CON**

Address: Operational Base + offset (0x10220)

| <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                | dsiphy_txskewcalhs_3<br>Request to transmit skew calibration on lane3.<br>1'b0: Disable<br>1'b1: Enable                                                                                |
| 14         | RW          | 0x0                | dsiphy_txskewcalhs_2<br>Request to transmit skew calibration on lane2.<br>1'b0: Disable<br>1'b1: Enable                                                                                |
| 13         | RW          | 0x0                | dsiphy_txskewcalhs_1<br>Request to transmit skew calibration on lane1.<br>1'b0: Disable<br>1'b1: Enable                                                                                |
| 12         | RW          | 0x0                | dsiphy_txskewcalhs_0<br>Request to transmit skew calibration on lane0.<br>1'b0: Disable<br>1'b1: Enable                                                                                |
| 11         | RW          | 0x0                | dsiphy_txskewcalhs_ck<br>Request to transmit skew calibration on clock lane.<br>1'b0: Disable<br>1'b1: Enable                                                                          |
| 10:8       | RO          | 0x0                | reserved                                                                                                                                                                               |
| 7          | RW          | 0x0                | dsiphy_lane3_frctxstpm<br>Force DSIPHY lane3 into transmit mode and generate stop state.<br>1'b0: Disable<br>1'b1: Enable                                                              |
| 6          | RW          | 0x0                | dsiphy_lane2_frctxstpm<br>Force DSIPHY lane2 into transmit mode and generate stop state.<br>1'b0: Disable<br>1'b1: Enable                                                              |
| 5          | RW          | 0x0                | dsiphy_lane1_frctxstpm<br>Force DSIPHY lane1 into transmit mode and generate stop state.<br>1'b0: Disable<br>1'b1: Enable                                                              |
| 4          | RW          | 0x0                | dsiphy_lane0_frctxstpm<br>Force DSIPHY lane0 into transmit mode and generate stop state.<br>1'b0: Disable<br>1'b1: Enable                                                              |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                               |
| 2          | RW          | 0x0                | dsiphy_lane0_turndisable<br>Disable Turn-around. This signal is used to prevent lane from going into transmit mode, even if it observes a turn-around request on the Lane interconnect |
| 1          | RW          | 0x0                | dsiphy_lvds_mode<br>DSIPHY LVDS mode 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                | dsiphy_forcerxmode<br>Force DSIPHY TX lane module into receive mode, wait for stop state.<br>1'b0: Disable<br>1'b1: Enable |

**GRF USBPHY CON0**

Address: Operational Base + offset (0x10230)

| <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                | usbotg_data_bus16_8<br>Software configure for OTGPHY data_bus16_8                                                                 |
| 14         | RW          | 0x0                | usbotg_pll_en<br>Software configure for OTGPHY pll_en                                                                             |
| 13         | RW          | 0x0                | usbotg_dischrgvbus<br>Software configure for OTGPHY dischrgvbus                                                                   |
| 12         | RW          | 0x0                | usbotg_chrgvbus<br>Software configure for OTGPHY chrgvbus                                                                         |
| 11         | RW          | 0x1                | usbotg_idpulup<br>Software configure for OTGPHY idpulup                                                                           |
| 10         | RW          | 0x1                | usbotg_utmi_iddig<br>Software configure for OTGPHY utmi_iddig                                                                     |
| 9          | RW          | 0x0                | usbotg_utmi_iddig_sel<br>IDDIG selection.<br>1'b0: USBPHY output<br>1'b1: Software output, USBPHY_CON0[10]                        |
| 8          | RW          | 0x0                | usbotg_dmpulldown<br>Software configure for OTGPHY dmpulldown                                                                     |
| 7          | RW          | 0x0                | usbotg_dppilldown<br>Software configure for OTGPHY dppilldown                                                                     |
| 6          | RW          | 0x1                | usbotg_termselect<br>Software configure for OTGPHY termselect                                                                     |
| 5:4        | RW          | 0x1                | usbotg_xcvrselect<br>Software configure for OTGPHY xcvrselect                                                                     |
| 3:2        | RW          | 0x0                | usbotg_opmode<br>Software configure for OTGPHY opmode                                                                             |
| 1          | RW          | 0x1                | usbotg_suspend_n<br>Software configure for OTGPHY suspend_n                                                                       |
| 0          | RW          | 0x0                | otgphy_input_sel<br>OTGPHY input selection.<br>1'b0: Hardware input<br>1'b1: Software input                                       |

**GRF USBPHY CON1**

Address: Operational Base + offset (0x10234)

| <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                | usbotg_chg_RST<br>Software configure for OTGPHY chg_RST                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | usbotg_chg_en<br>Software configure for OTGPHY chg_en                                                                                                                                                                                                                               |
| 13         | RW          | 0x0                | usbhost_suspendm_byps<br>Software configure for HOSTPHY suspendm_byps                                                                                                                                                                                                               |
| 12         | RW          | 0x0                | usbotg_suspendm_byps<br>Software configure for OTGPHY suspendm_byps                                                                                                                                                                                                                 |
| 11         | RW          | 0x0                | usbotg_txbitstuff_enable<br>Software configure for OTGPHY txbitstuff_enable                                                                                                                                                                                                         |
| 10         | RW          | 0x0                | usbotg_suspendm<br>Software configure for OTGPHY suspendm                                                                                                                                                                                                                           |
| 9          | RW          | 0x0                | usbotg_fs_se0<br>Software configure for OTGPHY fs_se0                                                                                                                                                                                                                               |
| 8          | RW          | 0x0                | usbotg_fs_data<br>Software configure for OTGPHY fs_data                                                                                                                                                                                                                             |
| 7          | RW          | 0x1                | usbotg_fs_oe<br>Software configure for OTGPHY fs_oe                                                                                                                                                                                                                                 |
| 6          | RW          | 0x0                | usbotg_fs_xver_own<br>Software configure for OTGPHY fs_xver_own                                                                                                                                                                                                                     |
| 5:3        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                            |
| 2          | RW          | 0x0                | usbotg_suspend_n_1<br>Software configure for OTGPHY suspend_n                                                                                                                                                                                                                       |
| 1:0        | RW          | 0x0                | usbotg_suspend_n_sel<br>usbotg_suspend_n selection.<br>2'b00: ~usbotg_utmi_suspend_com_n &<br>~usbotg_utmi_l1_suspend_com_n<br>2'b01: USBPHY_CON1[2]<br>2'b10: ~usbotg_utmi_suspend_com_n &<br>~usbotg_utmi_l1_suspend_com_n<br>2'b11: ~usbotg_uspend_n & ~usbotg_utmi_l1_suspend_n |

**GRF USBPHY CON2**

Address: Operational Base + offset (0x10238)

| <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                | usbhost_id_pull_up<br>Software configure for HOSTPHY id_pull_up                                                                   |
| 14         | RW          | 0x0                | usbhost_dischrgvbus<br>Software configure for HOSTPHY dischrgvbus                                                                 |
| 13         | RW          | 0x0                | usbhost_chrgvbus<br>Software configure for HOSTPHY chrgvbus                                                                       |
| 12         | RW          | 0x0                | usbhost_txbitstuff_enable<br>Software configure for HOSTPHY txbitstuff_enable                                                     |
| 11         | RW          | 0x1                | usbhost_otg_suspendm<br>Software configure for HOSTPHY suspendm                                                                   |
| 10         | RW          | 0x1                | usbhost_data_bus16_8<br>Software configure for HOSTPHY data_bus16_8                                                               |
| 9          | RW          | 0x0                | usbhost_pll_en<br>Software configure for HOSTPHY pll_en                                                                           |
| 8          | RW          | 0x1                | usbhost_chg_RST<br>Software configure for HOSTPHY chg_RST                                                                         |
| 7          | RW          | 0x0                | usbhost_chg_en<br>Software configure for HOSTPHY chg_en                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 6          | RW          | 0x1                | usbhost_termselect<br>Software configure for HOSTPHY termselect                               |
| 5:4        | RW          | 0x1                | usbhost_xcvrselect<br>Software configure for HOSTPHY xcvrselect                               |
| 3:2        | RW          | 0x0                | usbhost_opmode<br>Software configure for HOSTPHY opmode                                       |
| 1          | RW          | 0x0                | usbhost_suspend_n<br>Software configure for HOSTPHY suspend_n                                 |
| 0          | RW          | 0x0                | hostphy_input_sel<br>HOSTPHY input selection.<br>1'b0: Hardware input<br>1'b1: Software input |

**GRF USBPHY STATUS**

Address: Operational Base + offset (0x10248)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                               |
| 29         | RW          | 0x1                | usbhost_phy_connect<br>HOSTPHY start handshake.<br>1'b0: PHY handshake is prohibited<br>1'b1: PHY handshake is allowed |
| 28         | RW          | 0x0                | usbhost_chg_valid<br>HOSTPHY charge valid.<br>1'b0: Not charged<br>1'b1: Charged                                       |
| 27         | RW          | 0x0                | usbhost_phy_ls_fs_rcv<br>HOSTPHY ls_fs_rcv status                                                                      |
| 26         | RW          | 0x0                | usbhost_valid<br>HOSTPHY valid status                                                                                  |
| 25         | RW          | 0x0                | usbhost_bvalid<br>HOSTPHY bvalid status                                                                                |
| 24         | RO          | 0x0                | reserved                                                                                                               |
| 23         | RW          | 0x0                | usbhost_hostdisconnect<br>HOSTPHY hostdisconnect status                                                                |
| 22         | RW          | 0x0                | usbhost_utmi_iddig<br>HOSTPHY utmi_iddig status                                                                        |
| 21:20      | RW          | 0x0                | usbhost_linestate<br>HOSTPHY linestate status                                                                          |
| 19         | RW          | 0x1                | usbhost_sessend<br>HOSTPHY sessend status                                                                              |
| 18         | RW          | 0x0                | usbhost_vbusvalid<br>HOSTPHY vbusvalid status                                                                          |
| 17         | RW          | 0x0                | usbhost_vmi<br>HOSTPHY vmi status                                                                                      |
| 16         | RW          | 0x0                | usbhost_vpi<br>HOSTPHY vpi status                                                                                      |
| 15:14      | RO          | 0x0                | reserved                                                                                                               |
| 13         | RW          | 0x1                | usbottg_phy_connect<br>OTGPHY start handshake.<br>1'b0: PHY handshake is prohibited<br>1'b1: PHY handshake is allowed  |
| 12         | RW          | 0x0                | usbottg_chg_valid<br>OTGPHY charge valid.<br>1'b0: Not charged<br>1'b1: Charged                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 11         | RW          | 0x0                | usb0tg_phy_ls_fs_rcv<br>OTGPHY phy_ls_fs_rcv status   |
| 10         | RW          | 0x0                | usb0tg_avalid<br>OTGPHY avalid status                 |
| 9          | RW          | 0x0                | usb0tg_bvalid<br>OTGPHY bvalid status                 |
| 8          | RW          | 0x0                | usb0tg_fs_xver_own<br>OTGPHY fs_xver_own status       |
| 7          | RW          | 0x0                | usb0tg_hostdisconnect<br>OTGPHY hostdisconnect status |
| 6          | RW          | 0x1                | usb0tg_utmi_iddig<br>OTGPHY utmi_iddig status         |
| 5:4        | RW          | 0x0                | usb0tg_linestate<br>OTGPHY linestate status           |
| 3          | RW          | 0x1                | usb0tg_sessend<br>OTGPHY sessend status               |
| 2          | RW          | 0x0                | usb0tg_vbusvalid<br>OTGPHY vbusvalid status           |
| 1          | RW          | 0x0                | usb0tg_vmi<br>OTGPHY vmi status                       |
| 0          | RW          | 0x0                | usb0tg_vpi<br>OTGPHY vpi status                       |

**GRF CIFIO CON**

Address: Operational Base + offset (0x10250)

| <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         | RW          | 0x0                | cif_clk_inv_sel<br>cif_clk inverted enable.<br>1'b0: Not inverted<br>1'b1: Inverted                                               |
| 9          | RW          | 0x0                | cif_clk_delay_en<br>cif_clk delay enable.<br>1'b0: cif_clk bypassed<br>1'b1: cif_clk delayed by delayine                          |
| 8          | RW          | 0x0                | cif_datapath<br>Pixel input data path selection for CIF.<br>1'b0: Single edge sampling<br>1'b1: Double edge sampling              |
| 7:0        | RW          | 0x00               | cif_clk_delay_num<br>cif_clk delayline number                                                                                     |

**GRF SD JTAG SWITCH DLY CNT**

Address: Operational Base + offset (0x10254)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | sd_jtag_switch_dly_counter<br>JTAG switch delay counter. Count by 24MHz clock. |

**GRF UART2RX LOW CON**

Address: Operational Base + offset (0x10258)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | uart2rx_low_thres<br>UART2 RX pin low filter threshold. Count by 24MHz clock. |

**GRF IOFUNC CON0**

Address: Operational Base + offset (0x10260)

| <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                | i2s0_sdi3_oen<br>I2S0 sdi3 output enable.<br>1'b0: Output enable<br>1'b1: Output disable                                                                                                    |
| 14         | RW          | 0x0                | i2s0_sdi2_oen<br>I2S0 sdi2 output enable.<br>1'b0: Output enable<br>1'b1: Output disable                                                                                                    |
| 13         | RW          | 0x0                | i2s0_sdi1_oen<br>I2S0 sdi1 output enable.<br>1'b0: Output enable<br>1'b1: Output disable                                                                                                    |
| 12         | RW          | 0x0                | pdm_iomux_sel<br>PDM IOMUX selection.<br>1'b0: IOMUX group 0 (PDM*M0) selected<br>1'b1: IOMUX group 1 (PDM*M1) selected                                                                     |
| 11         | RW          | 0x0                | i2s2_lrck_sel<br>I2S2 lrck selection.<br>1'b0: i2s2_lrck_rx selected<br>1'b1: i2s2_lrck_tx selected                                                                                         |
| 10         | RW          | 0x0                | i2s1_lrck_sel<br>I2S1 lrck selection.<br>1'b0: i2s1_lrck_rx selected<br>1'b1: i2s1_lrck_tx selected                                                                                         |
| 9          | RW          | 0x0                | i2s0_mclk_sel<br>I2S0 mclk selection.<br>1'b0: i2s0_mclk_tx selected<br>1'b1: i2s0_mclk_rx selected                                                                                         |
| 8:5        | RO          | 0x0                | reserved                                                                                                                                                                                    |
| 4          | RW          | 0x0                | i2s2_iomux_sel<br>I2S2 IOMUX selection.<br>1'b0: IOMUX group 0 (I2S2*M0) selected<br>1'b1: IOMUX group 1 (I2S2*M1) selected                                                                 |
| 3:2        | RW          | 0x0                | i2s1_iomux_sel<br>I2S1 IOMUX selection.<br>2'b00: IOMUX group 0 (I2S1*M0) selected<br>2'b01: IOMUX group 1 (I2S1*M1) selected<br>2'b10: IOMUX group 2 (I2S1*M2) selected<br>2'b11: Reserved |
| 1          | RO          | 0x0                | reserved                                                                                                                                                                                    |
| 0          | RW          | 0x0                | i2s0_iomux_sel<br>I2S0 IOMUX selection.<br>1'b0: IOMUX group 0 (I2S0*M0) selected<br>1'b1: IOMUX group 1 (I2S0*M1) selected                                                                 |

**GRF IOFUNC CON1**

Address: Operational Base + offset (0x10264)

| 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         | jtag_iomux_sel<br>A7 JTAG IOMUX selection.<br>1'b0: IOMUX group 0 (A7JTAG*M0) selected<br>1'b1: IOMUX group 1 (A7JTAG*M1) selected                                                          |
| 14    | RO   | 0x0         | reserved                                                                                                                                                                                    |
| 13    | RW   | 0x0         | can_iomux_sel<br>CAN IOMUX selection.<br>1'b0: IOMUX group 0 (CAN*M0) selected<br>1'b1: IOMUX group 1 (CAN*M1) selected                                                                     |
| 12    | RW   | 0x0         | rgmii_iomux_sel<br>RGMII IOMUX selection.<br>1'b0: IOMUX group 0 (RGMII*M0) selected<br>1'b1: IOMUX group 1 (RGMII*M1) selected                                                             |
| 11:10 | RW   | 0x0         | spi1_iomux_sel<br>SPI1 IOMUX selection.<br>2'b00: IOMUX group 0 (SPI1*M0) selected<br>2'b01: IOMUX group 1 (SPI1*M1) selected<br>2'b10: IOMUX group 2 (SPI1*M2) selected<br>2'b11: Reserved |
| 9:8   | RW   | 0x0         | i2c5_iomux_sel<br>I2C5 IOMUX selection.<br>2'b00: IOMUX group 0 (I2C5*M0) selected<br>2'b01: IOMUX group 1 (I2C5*M1) selected<br>2'b10: IOMUX group 2 (I2C5*M2) selected<br>2'b11: Reserved |
| 7     | RO   | 0x0         | reserved                                                                                                                                                                                    |
| 6     | RW   | 0x0         | i2c4_iomux_sel<br>I2C4 IOMUX selection.<br>1'b0: IOMUX group 0 (I2C4*M0) selected<br>1'b1: IOMUX group 1 (I2C4*M1) selected                                                                 |
| 5:4   | RW   | 0x0         | i2c3_iomux_sel<br>I2C3 IOMUX selection.<br>2'b00: IOMUX group 0 (I2C3*M0) selected<br>2'b01: IOMUX group 1 (I2C3*M1) selected<br>2'b10: IOMUX group 2 (I2C3*M2) selected<br>2'b11: Reserved |
| 3:1   | RO   | 0x0         | reserved                                                                                                                                                                                    |
| 0     | RW   | 0x0         | cif_iomux_sel<br>CIF IOMUX selection.<br>1'b0: IOMUX group 0 (CIF*M0) selected<br>1'b1: IOMUX group 1 (CIF*M1) selected                                                                     |

**GRF IOFUNC CON2**

Address: Operational Base + offset (0x10268)

| 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:14      | RW          | 0x0                | uart5_iomux_sel<br>UART5 IOMUX selection.<br>2'b00: IOMUX group 0 (UART5*M0) selected<br>2'b01: IOMUX group 1 (UART5*M1) selected<br>2'b10: IOMUX group 2 (UART5*M2) selected<br>2'b11: Reserved |
| 13:12      | RW          | 0x0                | uart4_iomux_sel<br>UART4 IOMUX selection.<br>2'b00: IOMUX group 0 (UART4*M0) selected<br>2'b01: IOMUX group 1 (UART4*M1) selected<br>2'b10: IOMUX group 2 (UART4*M2) selected<br>2'b11: Reserved |
| 11:10      | RW          | 0x0                | uart3_iomux_sel<br>UART3 IOMUX selection.<br>2'b00: IOMUX group 0 (UART3*M0) selected<br>2'b01: IOMUX group 1 (UART3*M1) selected<br>2'b10: IOMUX group 2 (UART3*M2) selected<br>2'b11: Reserved |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                         |
| 8          | RW          | 0x0                | uart2_iomux_sel<br>UART2 IOMUX selection.<br>1'b0: IOMUX group 0 (UART2*M0) selected<br>1'b1: IOMUX group 1 (UART2*M1) selected                                                                  |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                         |
| 6          | RW          | 0x0                | pwm11_iomux_sel<br>PWM11 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM11*M0) selected<br>1'b1: IOMUX group 1 (PWM11*M1) selected                                                                  |
| 5          | RO          | 0x0                | reserved                                                                                                                                                                                         |
| 4          | RW          | 0x0                | pwm10_iomux_sel<br>PWM10 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM10*M0) selected<br>1'b1: IOMUX group 1 (PWM10*M1) selected                                                                  |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                         |
| 2          | RW          | 0x0                | pwm9_iomux_sel<br>PWM9 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM9*M0) selected<br>1'b1: IOMUX group 1 (PWM9*M1) selected                                                                      |
| 1          | RO          | 0x0                | reserved                                                                                                                                                                                         |
| 0          | RW          | 0x0                | pwm8_iomux_sel<br>PWM8 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM8*M0) selected<br>1'b1: IOMUX group 1 (PWM8*M1) selected                                                                      |

**GRF IOFUNC CON3**

Address: Operational Base + offset (0x1026C)

| <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         | RW          | 0x0                | i2s2_mclk_ioe_<br>i2s2_mclk_ioe_<br>I2S2 mclk_tx output enable.<br>1'b0: Disable<br>1'b1: Enable                                     |
| 14         | RW          | 0x0                | i2s1_mclk_ioe_<br>i2s1_mclk_ioe_<br>I2S1 mclk output enable.<br>1'b0: Disable<br>1'b1: Enable                                        |
| 13         | RW          | 0x0                | i2s0_mclk_rx_ioe_<br>i2s0_mclk_rx_ioe_<br>I2S0 mclk_rx output enable.<br>1'b0: Disable<br>1'b1: Enable                               |
| 12         | RW          | 0x0                | i2s0_mclk_tx_ioe_<br>i2s0_mclk_tx_ioe_<br>I2S0 mclk_tx output enable.<br>1'b0: Disable<br>1'b1: Enable                               |
| 11         | RW          | 0x0                | ciflite_csiphy_sel<br>CSIPHY source selection for CIFLITE.<br>1'b0: From CSIPHY0<br>1'b1: From CSIPHY1                               |
| 10         | RW          | 0x0                | isp_csiphy_sel<br>CSIPHY source selection for ISP.<br>1'b0: From CSIPHY0<br>1'b1: From CSIPHY1                                       |
| 9          | RW          | 0x0                | cif_csiphy_sel<br>CSIPHY source selection for CIF.<br>1'b0: From CSIPHY0<br>1'b1: From CSIPHY1                                       |
| 8:6        | RO          | 0x0                | reserved                                                                                                                             |
| 5          | RW          | 0x0                | force_jtag_m1<br>Force IO to JTAG IOMUX group 1 enable.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 4          | RW          | 0x1                | force_jtag<br>Force IO to JTAG IOMUX group 0 enable.<br>1'b0: Disable<br>1'b1: Enable                                                |
| 3          | RO          | 0x0                | reserved                                                                                                                             |
| 2          | RW          | 0x0                | lcdc_dclk_inv_sel<br>Lcdc_dclk output inverted enable.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 1          | RO          | 0x0                | reserved                                                                                                                             |
| 0          | RW          | 0x0                | lcdc_bypass<br>LCDC IO output path selection.<br>1'b0: IO through flip-flop before output<br>1'b1: IO bypass flip-flop before output |

**GRF USBPHY0 CFG CON**

Address: Operational Base + offset (0x10270)

| <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          | 0x1                | sel_apb<br>APB selection input                                                                                                    |
| 1          | RW          | 0x0                | cfg_rden<br>APB read enable input                                                                                                 |
| 0          | RW          | 0x0                | cfg_wren<br>APB write enable input                                                                                                |

**GRF USBPHY0 CFG ADDRIN**

Address: Operational Base + offset (0x10274)

| <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:0       | RW          | 0x0000             | cfg_addr<br>APB configuration address input                                                                                       |

**GRF USBPHY0 CFG ADDROUT**

Address: Operational Base + offset (0x10278)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                     |
| 15:0       | RW          | 0x0000             | cfg_addr<br>APB configuration address status |

**GRF USBPHY0 CFG DLY CON**

Address: Operational Base + offset (0x1027C)

| <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:4        | RW          | 0x0                | prdy_cnt<br>APB pready counter                                                                                                    |
| 3:0        | RW          | 0x0                | rden_cnt<br>APB read enable counter                                                                                               |

**GRF USBPHY1 CFG CON**

Address: Operational Base + offset (0x10280)

| <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          | 0x1                | sel_apb<br>APB selection input                                                                                                    |
| 1          | RW          | 0x0                | cfg_rden<br>APB read enable input                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 0          | RW          | 0x0                | cfg_wren<br>APB write enable input |

**GRF USBPHY1 CFG ADDRIN**

Address: Operational Base + offset (0x10284)

| <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:0       | RW          | 0x0000             | cfg_addr<br>APB configuration address input                                                                                       |

**GRF USBPHY1 CFG ADDROUT**

Address: Operational Base + offset (0x10288)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                     |
| 15:0       | RW          | 0x0000             | cfg_addr<br>APB configuration address status |

**GRF USBPHY1 CFG DLY CON**

Address: Operational Base + offset (0x1028C)

| <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:4        | RW          | 0x0                | prdy_cnt<br>APB_pready counter                                                                                                    |
| 3:0        | RW          | 0x0                | rden_cnt<br>APB read enable counter                                                                                               |

**GRF USB SIG DETECT CON**

Address: Operational Base + offset (0x10300)

| <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          | 0x0                | host_disconnect_fall_irq_en<br>host_disconnect falling edge status irq enable.<br>1'b0: Disable<br>1'b1: Enable                   |
| 8          | RW          | 0x0                | host_disconnect_rise_irq_en<br>host_disconnect rising edge status irq enable.<br>1'b0: Disable<br>1'b1: Enable                    |
| 7          | RW          | 0x0                | otg_disconnect_fall_irq_en<br>otg_disconnect falling edge status irq 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                | otg_disconnect_rise_irq_en<br>otg_disconnect rising edge status irq enable.<br>1'b0: Disable<br>1'b1: Enable |
| 5          | RW          | 0x0                | otg_id_fall_irq_en<br>otg_id falling edge status irq enable.<br>1'b0: Disable<br>1'b1: Enable                |
| 4          | RW          | 0x0                | otg_id_rise_irq_en<br>otg_id rising edge status irq enable.<br>1'b0: Disable<br>1'b1: Enable                 |
| 3          | RW          | 0x0                | otg_bvalid_fall_irq_en<br>otg_bvalid falling edge status irq enable.<br>1'b0: Disable<br>1'b1: Enable        |
| 2          | RW          | 0x0                | otg_bvalid_rise_irq_en<br>otg_bvalid rising edge status irq enable.<br>1'b0: Disable<br>1'b1: Enable         |
| 1          | RW          | 0x0                | host_linestate_irq_en<br>host_linestate change status irq enable.<br>1'b0: Disable<br>1'b1: Enable           |
| 0          | RW          | 0x0                | otg_linestate_irq_en<br>otg_linestate change status irq enable.<br>1'b0: Disable<br>1'b1: Enable             |

**GRF USB SIG DETECT STATUS**

Address: Operational Base + offset (0x10304)

| <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          | 0x0                | host_disconnect_fall_irq<br>host_disconnect falling edge irq status                                                               |
| 8          | RW          | 0x0                | host_disconnect_rise_irq<br>host_disconnect rising edge irq status                                                                |
| 7          | RW          | 0x0                | otg_disconnect_fall_irq<br>otg_disconnect falling edge irq status                                                                 |
| 6          | RW          | 0x0                | otg_disconnect_rise_irq<br>otg_disconnect rising edge irq status                                                                  |
| 5          | RW          | 0x0                | otg_id_fall_irq<br>otg_id falling edge irq status                                                                                 |
| 4          | RW          | 0x0                | otg_id_rise_irq<br>otg_id rising edge irq status                                                                                  |
| 3          | RW          | 0x0                | otg_bvalid_fall_irq<br>otg_bvalid falling edge irq status                                                                         |
| 2          | RW          | 0x0                | otg_bvalid_rise_irq<br>otg_bvalid rising edge irq status                                                                          |
| 1          | RW          | 0x0                | host_linestate_irq<br>host_linestate change irq status                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 0          | RW          | 0x0                | otg_linestate_irq<br>otg_linestate change irq status |

**GRF USB SIG DETECT CLR**

Address: Operational Base + offset (0x10308)

| <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          | 0x0                | host_disconnect_fall_irq_clr<br>host_disconnect falling edge status irq enable.<br>1'b0: Disable<br>1'b1: Enable                  |
| 8          | RW          | 0x0                | host_disconnect_rise_irq_clr<br>host_disconnect rising edge status irq clear. Write 1 to clear irq status.                        |
| 7          | RW          | 0x0                | otg_disconnect_fall_irq_clr<br>otg_disconnect falling edge status irq clear. Write 1 to clear irq status.                         |
| 6          | RW          | 0x0                | otg_disconnect_rise_irq_clr<br>otg_disconnect rising edge status irq clear. Write 1 to clear irq status.                          |
| 5          | RW          | 0x0                | otg_id_fall_irq_clr<br>otg_id falling edge status irq clear. Write 1 to clear irq status.                                         |
| 4          | RW          | 0x0                | otg_id_rise_irq_clr<br>otg_id rising edge status irq clear. Write 1 to clear irq status.                                          |
| 3          | RW          | 0x0                | otg_bvalid_fall_irq_clr<br>otg_bvalid falling edge status irq clear. Write 1 to clear irq status.                                 |
| 2          | RW          | 0x0                | otg_bvalid_rise_irq_clr<br>otg_bvalid rising edge status irq clear. Write 1 to clear irq status.                                  |
| 1          | RW          | 0x0                | host_linestate_irq_clr<br>host_linestate change status irq clear. Write 1 to clear irq status.                                    |
| 0          | RW          | 0x0                | otg_linestate_irq_clr<br>otg_linestate change status irq clear. Write 1 to clear irq status.                                      |

**GRF USB LINESTATE CON**

Address: Operational Base + offset (0x10310)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                     |
| 19:0       | RW          | 0x30100            | linestate_detect_con<br>HOST/OTG port linestate filter time control register |

**GRF USB DISCONNECT CON**

Address: Operational Base + offset (0x10314)

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

**GRF USB BVALID CON**

Address: Operational Base + offset (0x10318)

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

**GRF USB ID CON**

Address: Operational Base + offset (0x1031C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                           |
| 27:0       | RW          | 0x0030100          | grf_id_detect_con<br>OTG ID port filter time control register, the unit is pclk with up to 100MHz. |

**6.4 DDRGRF Register Description****6.4.1 Registers Summary**

| <b>Name</b>                  | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>               |
|------------------------------|---------------|-------------|--------------------|----------------------------------|
| <u>DDRGRF DDR CON0</u>       | 0x0000        | W           | 0x00000000         | DDR control register 0           |
| <u>DDRGRF DDR CON1</u>       | 0x0004        | W           | 0x00000600         | DDR control register 1           |
| <u>DDRGRF DDR CON2</u>       | 0x0008        | W           | 0x00000000         | DDR control register 2           |
| <u>DDRGRF DDR SPLIT CON</u>  | 0x0010        | W           | 0x00000110         | DDR SPLIT control register       |
| <u>DDRGRF DDR LP CON</u>     | 0x0020        | W           | 0x00001101         | DDR lower power control register |
| <u>DDRGRF DDRPHY CON0</u>    | 0x0040        | W           | 0x00000000         | DDRPHY control register 0        |
| <u>DDRGRF DDRPHY CON1</u>    | 0x0044        | W           | 0x00000000         | DDRPHY control register 1        |
| <u>DDRGRF DDRPHY CON2</u>    | 0x0048        | W           | 0x00000000         | DDRPHY control register 2        |
| <u>DDRGRF DDRPHY CON3</u>    | 0x004c        | W           | 0x00000000         | DDRPHY control register 3        |
| <u>DDRGRF DDRPHY CON4</u>    | 0x0050        | W           | 0x00000000         | DDRPHY control register 4        |
| <u>DDRGRF DDRPHY CON5</u>    | 0x0054        | W           | 0x00000000         | DDRPHY control register 5        |
| <u>DDRGRF DDR STATUS0</u>    | 0x0100        | W           | 0x00000000         | DDR status register 0            |
| <u>DDRGRF DDR STATUS1</u>    | 0x0104        | W           | 0x00000000         | DDR status register 1            |
| <u>DDRGRF DDR STATUS2</u>    | 0x0108        | W           | 0x00000000         | DDR status register 2            |
| <u>DDRGRF DDR STATUS3</u>    | 0x010c        | W           | 0x00000000         | DDR status register 3            |
| <u>DDRGRF DDR STATUS4</u>    | 0x0110        | W           | 0x00000000         | DDR status register 4            |
| <u>DDRGRF DDR STATUS5</u>    | 0x0114        | W           | 0x00000000         | DDR status register 5            |
| <u>DDRGRF DDR STATUS6</u>    | 0x0118        | W           | 0x00000000         | DDR status register 6            |
| <u>DDRGRF DDR STATUS7</u>    | 0x011c        | W           | 0x00000000         | DDR status register 7            |
| <u>DDRGRF DDR STATUS8</u>    | 0x0120        | W           | 0x00000017         | DDR status register 8            |
| <u>DDRGRF DDR STATUS9</u>    | 0x0124        | W           | 0x80000000         | DDR status register 9            |
| <u>DDRGRF DDR STATUS10</u>   | 0x0128        | W           | 0x00000000         | DDR status register 10           |
| <u>DDRGRF DDR STATUS11</u>   | 0x012c        | W           | 0x00000000         | DDR status register 11           |
| <u>DDRGRF DDR STATUS12</u>   | 0x0130        | W           | 0x00000000         | DDR status register 12           |
| <u>DDRGRF DDR STATUS13</u>   | 0x0134        | W           | 0x00000000         | DDR status register 13           |
| <u>DDRGRF DDR STATUS14</u>   | 0x0138        | W           | 0x00000000         | DDR status register 14           |
| <u>DDRGRF DDR STATUS15</u>   | 0x013c        | W           | 0x00000000         | DDR status register 15           |
| <u>DDRGRF DDR STATUS16</u>   | 0x0140        | W           | 0x00000000         | DDR status register 16           |
| <u>DDRGRF DDR STATUS17</u>   | 0x0144        | W           | 0x00000000         | DDR status register 17           |
| <u>DDRGRF DDRHOLD STATUS</u> | 0x0150        | W           | 0x01010140         | DDR hold status register         |
| <u>DDRGRF DDRPHY STATUS0</u> | 0x0160        | W           | 0x3fffffff         | DDRPHY status register 0         |
| <u>DDRGRF DDRPHY STATUS1</u> | 0x0164        | W           | 0xffffffff         | DDRPHY status register 1         |

Notes: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access**6.4.2 Detail Register Description****DDRGRF DDR CON0**

Address: Operational Base + offset (0x0000)

| <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                | hold_ddr_trans<br>DDR transfer hold.<br>1'b0: Disable<br>1'b1: Enable                                                             |
| 14         | RW          | 0x0                | awpoison<br>AXI write poison control.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 13         | RW          | 0x0                | awurgent<br>AXI write urgent control.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 12         | RW          | 0x0                | arpoison<br>AXI read poison control.<br>1'b0: Disable<br>1'b1: Enable                                                             |
| 11         | RW          | 0x0                | arurgent<br>AXI bus read urgent control.<br>1'b0: Disable<br>1'b1: Enable                                                         |
| 10         | RW          | 0x0                | pa_wmask<br>When asserted(active high), it will prevent the corresponding write to PA.<br>1'b0: Disable<br>1'b1: Enable           |
| 9:8        | RW          | 0x0                | pa_rmask<br>When asserted(active high), it will prevent the corresponding read to PA.<br>1'b0: Disable<br>1'b1: Enable            |
| 7:6        | RO          | 0x0                | reserved                                                                                                                          |
| 5          | RW          | 0x0                | csysreq_upctl_ddrstdby<br>STDBY controls UPCTL csysreq_ddrc.<br>1'b0: Disable<br>1'b1: Enable                                     |
| 4          | RW          | 0x0                | csysreq_upctl_pmu<br>PMU controls UPCTL csysreq_ddrc.<br>1'b0: Disable<br>1'b1: Enable                                            |
| 3          | RW          | 0x0                | csysreq_aclk<br>1'b0: Request UPCTL aclk enter low power<br>1'b1: Request UPCTL aclk exit low power                               |
| 2          | RW          | 0x0                | dfi_init_start<br>Software for dfi_init_start.<br>1'b0: Disable<br>1'b1: Enable                                                   |
| 1          | RW          | 0x0                | dfi_init_start_sel<br>dfi_init_start selection.<br>1'b0: From UPCTL<br>1'b1: From GRF_DDR_CON0[2]                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | upctl_slverr_enable<br>UPCTL APB slave error response enable.<br>1'b0: Disable<br>1'b1: Enable |

**DDRGRF DDR 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 |
| 15:12      | RO          | 0x0                | reserved                                                                                                                          |
| 11:8       | RW          | 0x6                | auto_sr_dly<br>The delay of auto gated UPCTL core_clk. It should be to be 0x6.                                                    |
| 7:6        | RO          | 0x0                | reserved                                                                                                                          |
| 5          | RW          | 0x0                | con_upctl2_pdsrlp_cg_en<br>UPCTL clock gating after enter PD/SR state.<br>1'b0: Disable<br>1'b1: Enable                           |
| 4          | RW          | 0x0                | upctl_sysreq_cg_en<br>UPCTL core_clk gating when external ddrc_csysreq asserted.<br>1'b0: Disable<br>1'b1: Enable                 |
| 3          | RW          | 0x0                | selfref_type2_en<br>UPCTL core_clk auto gating in type2 self-refresh.<br>1'b0: Disable<br>1'b1: Enable                            |
| 2          | RW          | 0x0                | upctl_core_cg_en<br>UPCTL core_clk auto gating.<br>1'b0: Disable<br>1'b1: Enable                                                  |
| 1          | RW          | 0x0                | upctl_apb_cg_en<br>UPCTL pcclk auto gating.<br>1'b0: Disable<br>1'b1: Enable                                                      |
| 0          | RW          | 0x0                | upctl_axi_cg_en<br>UPCTL aclk auto gating.<br>1'b0: Disable<br>1'b1: Enable                                                       |

**DDRGRF DDR 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:11      | RO          | 0x00               | reserved                                                                                                                          |
| 10         | RW          | 0x0                | dif_freq_change_ack<br>DFI frequency change acknowledge.<br>1'b0: Disable<br>1'b1: Enable                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 9:0        | RW          | 0x3ff              | grf_con_ddr_clk_gate<br>Clock gating control for UPCTL, should be set to 0x3ff for DDR normal work. |

**DDRGRF DDR SPLIT CON**

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:11      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10:9       | RW          | 0x0                | spmode<br>Split mode select.<br>2'b00: DDR controller and PHY works at 32 bits mode. Low 16 bits are valid if access address is above split address.<br>2'b01: DDR controller and PHY works at 32 bits mode. High 16 bits are valid if access address is above split address.<br>2'b10: DDR controller and PHY works at 16 bits mode. Low 8 bits are valid if access address is above split address.<br>2'b11: DDR controller and PHY works at 16 bits mode. High 8 bits are valid if access address is above split address. |
| 8          | RW          | 0x1                | bypass<br>AXI split module bypass.<br>1'b0: Enable<br>1'b1: Bypass                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7:0        | RW          | 0x0a               | spaddr<br>Split address high 8 bits of 32bit address.<br>For example, if spaddr=0x10, then the split address is 0x10000000. The axi_split module will be bypassed if reading or writing DDR below split address, otherwise AXI burst will be split.                                                                                                                                                                                                                                                                          |

**DDRGRF DDR LP CON**

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'b0: Write access disable<br>1'b1: Write access enable |
| 15:14      | RO          | 0x0                | reserved                                                                                                                          |
| 13         | RW          | 0x0                | sr_ctl_en<br>sr exit/enter reload/inverse lpckdis_ini.<br>1'b0: Disable<br>1'b1: Enable                                           |
| 12         | RW          | 0x1                | pd_ctl_en<br>pd exit/enter reload/inverse lpckdis_ini.<br>1'b0: Disable<br>1'b1: Enable                                           |
| 11:10      | RO          | 0x0                | reserved                                                                                                                          |
| 9          | RW          | 0x0                | lpckdis_en<br>dfi_lp_ck_disable enable.<br>1'b0: Disable<br>1'b1: Enable                                                          |
| 8          | RW          | 0x1                | lpckdis_ini<br>dfi_lp_ck_disable intial value                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 7:3        | RO          | 0x00               | reserved                                                                 |
| 2          | RW          | 0x0                | lp23_mode<br>LPDDR2/LPDDR3 mode enable.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RO          | 0x0                | reserved                                                                 |
| 0          | RW          | 0x1                | ddr23_mode<br>DDR2/DDR3 mode enable.<br>1'b0: Disable<br>1'b1: Enable    |

**DDRGDF DDRPHY CON0**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31         | RW          | 0x0                | gpio_a_dq3_txen<br>DDRPHY's gpio_a_dq3_txen source |
| 30         | RW          | 0x0                | gpio_a_dq2_txen<br>DDRPHY's gpio_a_dq2_txen source |
| 29         | RW          | 0x0                | gpio_a_dq1_txen<br>DDRPHY's gpio_a_dq1_txen source |
| 28         | RW          | 0x0                | gpio_a_dq0_txen<br>DDRPHY's gpio_a_dq0_txen source |
| 27         | RW          | 0x0                | gpio_actn_txen<br>DDRPHY's gpio_actn_txen source   |
| 26         | RW          | 0x0                | gpio_odt1_txen<br>DDRPHY's gpio_odt1_txen source   |
| 25         | RW          | 0x0                | gpio_odt0_txen<br>DDRPHY's gpio_odt0_txen source   |
| 24         | RW          | 0x0                | gpio_csb1_txen<br>DDRPHY's gpio_csb1_txen source   |
| 23         | RW          | 0x0                | gpio_csb0_txen<br>DDRPHY's gpio_csb0_txen source   |
| 22         | RW          | 0x0                | gpio_ckb_txen<br>DDRPHY's gpio_ckb_txen source     |
| 21         | RW          | 0x0                | gpio_ck_txen<br>DDRPHY's gpio_ck_txen source       |
| 20         | RW          | 0x0                | gpio_bg1_txen<br>DDRPHY's gpio_bg1_txen source     |
| 19         | RW          | 0x0                | gpio_bg0_txen<br>DDRPHY's gpio_bg0_txen source     |
| 18         | RW          | 0x0                | gpio_ba1_txen<br>DDRPHY's gpio_ba1_txen source     |
| 17         | RW          | 0x0                | gpio_a17_txen<br>DDRPHY's gpio_a17_txen source     |
| 16         | RW          | 0x0                | gpio_a16_txen<br>DDRPHY's gpio_a16_txen source     |
| 15         | RW          | 0x0                | gpio_a15_txen<br>DDRPHY's gpio_a15_txen source     |
| 14         | RW          | 0x0                | gpio_a14_txen<br>DDRPHY's gpio_a14_txen source     |
| 13         | RW          | 0x0                | gpio_a13_txen<br>DDRPHY's gpio_a13_txen source     |
| 12         | RW          | 0x0                | gpio_a12_txen<br>DDRPHY's gpio_a12_txen source     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 11         | RW          | 0x0                | gpio_a11_txen<br>DDRPHY's gpio_a11_txen source |
| 10         | RW          | 0x0                | gpio_a10_txen<br>DDRPHY's gpio_a10_txen source |
| 9          | RW          | 0x0                | gpio_a9_txen<br>DDRPHY's gpio_a9_txen source   |
| 8          | RW          | 0x0                | gpio_a8_txen<br>DDRPHY's gpio_a8_txen source   |
| 7          | RW          | 0x0                | gpio_a7_txen<br>DDRPHY's gpio_a7_txen source   |
| 6          | RW          | 0x0                | gpio_a6_txen<br>DDRPHY's gpio_a6_txen source   |
| 5          | RW          | 0x0                | gpio_a5_txen<br>DDRPHY's gpio_a5_txen source   |
| 4          | RW          | 0x0                | gpio_a4_txen<br>DDRPHY's gpio_a4_txen source   |
| 3          | RW          | 0x0                | gpio_a3_txen<br>DDRPHY's gpio_a3_txen source   |
| 2          | RW          | 0x0                | gpio_a2_txen<br>DDRPHY's gpio_a2_txen source   |
| 1          | RW          | 0x0                | gpio_a1_txen<br>DDRPHY's gpio_a1_txen source   |
| 0          | RW          | 0x0                | gpio_a0_txen<br>DDRPHY's gpio_a0_txen source   |

**DDRGRF DDRPHY CON1**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                             |
| 29         | RW          | 0x0                | gpio_resetn_txen<br>DDRPHY's gpio_resetn_txen source |
| 28         | RW          | 0x0                | gpio_cke0_txen<br>DDRPHY's gpio_cke0_txen source     |
| 27         | RW          | 0x0                | gpio_b_dq15_txen<br>DDRPHY's gpio_b_dq15_txen source |
| 26         | RW          | 0x0                | gpio_b_dq14_txen<br>DDRPHY's gpio_b_dq14_txen source |
| 25         | RW          | 0x0                | gpio_b_dq13_txen<br>DDRPHY's gpio_b_dq13_txen source |
| 24         | RW          | 0x0                | gpio_b_dq12_txen<br>DDRPHY's gpio_b_dq12_txen source |
| 23         | RW          | 0x0                | gpio_b_dq11_txen<br>DDRPHY's gpio_b_dq11_txen source |
| 22         | RW          | 0x0                | gpio_b_dq10_txen<br>DDRPHY's gpio_b_dq10_txen source |
| 21         | RW          | 0x0                | gpio_b_dq9_txen<br>DDRPHY's gpio_b_dq9_txen source   |
| 20         | RW          | 0x0                | gpio_b_dq8_txen<br>DDRPHY's gpio_b_dq8_txen source   |
| 19         | RW          | 0x0                | gpio_b_dq7_txen<br>DDRPHY's gpio_b_dq7_txen source   |
| 18         | RW          | 0x0                | gpio_b_dq6_txen<br>DDRPHY's gpio_b_dq6_txen source   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 17         | RW          | 0x0                | gpio_b_dq5_txen<br>DDRPHY's gpio_b_dq5_txen source   |
| 16         | RW          | 0x0                | gpio_b_dq4_txen<br>DDRPHY's gpio_b_dq4_txen source   |
| 15         | RW          | 0x0                | gpio_b_dq3_txen<br>DDRPHY's gpio_b_dq3_txen source   |
| 14         | RW          | 0x0                | gpio_b_dq2_txen<br>DDRPHY's gpio_b_dq2_txen source   |
| 13         | RW          | 0x0                | gpio_b_dq1_txen<br>DDRPHY's gpio_b_dq1_txen source   |
| 12         | RW          | 0x0                | gpio_b_dq0_txen<br>DDRPHY's gpio_b_dq0_txen source   |
| 11         | RW          | 0x0                | gpio_a_dq15_txen<br>DDRPHY's gpio_a_dq15_txen source |
| 10         | RW          | 0x0                | gpio_a_dq14_txen<br>DDRPHY's gpio_a_dq14_txen source |
| 9          | RW          | 0x0                | gpio_a_dq13_txen<br>DDRPHY's gpio_a_dq13_txen source |
| 8          | RW          | 0x0                | gpio_a_dq12_txen<br>DDRPHY's gpio_a_dq12_txen source |
| 7          | RW          | 0x0                | gpio_a_dq11_txen<br>DDRPHY's gpio_a_dq11_txen source |
| 6          | RW          | 0x0                | gpio_a_dq10_txen<br>DDRPHY's gpio_a_dq10_txen source |
| 5          | RW          | 0x0                | gpio_a_dq9_txen<br>DDRPHY's gpio_a_dq9_txen source   |
| 4          | RW          | 0x0                | gpio_a_dq8_txen<br>DDRPHY's gpio_a_dq8_txen source   |
| 3          | RW          | 0x0                | gpio_a_dq7_txen<br>DDRPHY's gpio_a_dq7_txen source   |
| 2          | RW          | 0x0                | gpio_a_dq6_txen<br>DDRPHY's gpio_a_dq6_txen source   |
| 1          | RW          | 0x0                | gpio_a_dq5_txen<br>DDRPHY's gpio_a_dq5_txen source   |
| 0          | RW          | 0x0                | gpio_a_dq4_txen<br>DDRPHY's gpio_a_dq4_txen source   |

**DDRGRF DDRPHY CON2**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 31         | RW          | 0x0                | gpio_a_dq3_txdata<br>DDRPHY's gpio_a_dq3_txdata source |
| 30         | RW          | 0x0                | gpio_a_dq2_txdata<br>DDRPHY's gpio_a_dq2_txdata source |
| 29         | RW          | 0x0                | gpio_a_dq1_txdata<br>DDRPHY's gpio_a_dq1_txdata source |
| 28         | RW          | 0x0                | gpio_a_dq0_txdata<br>DDRPHY's gpio_a_dq0_txdata source |
| 27         | RW          | 0x0                | gpio_actn_txdata<br>DDRPHY's gpio_actn_txdata source   |
| 26         | RW          | 0x0                | gpio_odt1_txdata<br>DDRPHY's gpio_odt1_txdata source   |
| 25         | RW          | 0x0                | gpio_odt0_txdata<br>DDRPHY's gpio_odt0_txdata source   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 24         | RW          | 0x0                | gpio_csb1_txdata<br>DDRPHY's gpio_csb1_txdata source |
| 23         | RW          | 0x0                | gpio_csb0_txdata<br>DDRPHY's gpio_csb0_txdata source |
| 22         | RW          | 0x0                | gpio_ckb_txdata<br>DDRPHY's gpio_ckb_txdata source   |
| 21         | RW          | 0x0                | gpio_ck_txdata<br>DDRPHY's gpio_ck_txdata source     |
| 20         | RW          | 0x0                | gpio_bg1_txdata<br>DDRPHY's gpio_bg1_txdata source   |
| 19         | RW          | 0x0                | gpio_bg0_txdata<br>DDRPHY's gpio_bg0_txdata source   |
| 18         | RW          | 0x0                | gpio_ba1_txdata<br>DDRPHY's gpio_ba1_txdata source   |
| 17         | RW          | 0x0                | gpio_a17_txdata<br>DDRPHY's gpio_a17_txdata source   |
| 16         | RW          | 0x0                | gpio_a16_txdata<br>DDRPHY's gpio_a16_txdata source   |
| 15         | RW          | 0x0                | gpio_a15_txdata<br>DDRPHY's gpio_a15_txdata source   |
| 14         | RW          | 0x0                | gpio_a14_txdata<br>DDRPHY's gpio_a14_txdata source   |
| 13         | RW          | 0x0                | gpio_a13_txdata<br>DDRPHY's gpio_a13_txdata source   |
| 12         | RW          | 0x0                | gpio_a12_txdata<br>DDRPHY's gpio_a12_txdata source   |
| 11         | RW          | 0x0                | gpio_a11_txdata<br>DDRPHY's gpio_a11_txdata source   |
| 10         | RW          | 0x0                | gpio_a10_txdata<br>DDRPHY's gpio_a10_txdata source   |
| 9          | RW          | 0x0                | gpio_a9_txdata<br>DDRPHY's gpio_a9_txdata source     |
| 8          | RW          | 0x0                | gpio_a8_txdata<br>DDRPHY's gpio_a8_txdata source     |
| 7          | RW          | 0x0                | gpio_a7_txdata<br>DDRPHY's gpio_a7_txdata source     |
| 6          | RW          | 0x0                | gpio_a6_txdata<br>DDRPHY's gpio_a6_txdata source     |
| 5          | RW          | 0x0                | gpio_a5_txdata<br>DDRPHY's gpio_a5_txdata source     |
| 4          | RW          | 0x0                | gpio_a4_txdata<br>DDRPHY's gpio_a4_txdata source     |
| 3          | RW          | 0x0                | gpio_a3_txdata<br>DDRPHY's gpio_a3_txdata source     |
| 2          | RW          | 0x0                | gpio_a2_txdata<br>DDRPHY's gpio_a2_txdata source     |
| 1          | RW          | 0x0                | gpio_a1_txdata<br>DDRPHY's gpio_a1_txdata source     |
| 0          | RW          | 0x0                | gpio_a0_txdata<br>DDRPHY's gpio_a0_txdata source     |

**DDRGRF DDRPHY CON3**

Address: Operational Base + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                 |
| 29         | RW          | 0x0                | gpio_resetn_txdata<br>DDRPHY's gpio_resetn_txdata source |
| 28         | RW          | 0x0                | gpio_cke0_txdata<br>DDRPHY's gpio_cke0_txdata source     |
| 27         | RW          | 0x0                | gpio_b_dq15_txdata<br>DDRPHY's gpio_b_dq15_txdata source |
| 26         | RW          | 0x0                | gpio_b_dq14_txdata<br>DDRPHY's gpio_b_dq14_txdata source |
| 25         | RW          | 0x0                | gpio_b_dq13_txdata<br>DDRPHY's gpio_b_dq13_txdata source |
| 24         | RW          | 0x0                | gpio_b_dq12_txdata<br>DDRPHY's gpio_b_dq12_txdata source |
| 23         | RW          | 0x0                | gpio_b_dq11_txdata<br>DDRPHY's gpio_b_dq11_txdata source |
| 22         | RW          | 0x0                | gpio_b_dq10_txdata<br>DDRPHY's gpio_b_dq10_txdata source |
| 21         | RW          | 0x0                | gpio_b_dq9_txdata<br>DDRPHY's gpio_b_dq9_txdata source   |
| 20         | RW          | 0x0                | gpio_b_dq8_txdata<br>DDRPHY's gpio_b_dq8_txdata source   |
| 19         | RW          | 0x0                | gpio_b_dq7_txdata<br>DDRPHY's gpio_b_dq7_txdata source   |
| 18         | RW          | 0x0                | gpio_b_dq6_txdata<br>DDRPHY's gpio_b_dq6_txdata source   |
| 17         | RW          | 0x0                | gpio_b_dq5_txdata<br>DDRPHY's gpio_b_dq5_txdata source   |
| 16         | RW          | 0x0                | gpio_b_dq4_txdata<br>DDRPHY's gpio_b_dq4_txdata source   |
| 15         | RW          | 0x0                | gpio_b_dq3_txdata<br>DDRPHY's gpio_b_dq3_txdata source   |
| 14         | RW          | 0x0                | gpio_b_dq2_txdata<br>DDRPHY's gpio_b_dq2_txdata source   |
| 13         | RW          | 0x0                | gpio_b_dq1_txdata<br>DDRPHY's gpio_b_dq1_txdata source   |
| 12         | RW          | 0x0                | gpio_b_dq0_txdata<br>DDRPHY's gpio_b_dq0_txdata source   |
| 11         | RW          | 0x0                | gpio_a_dq15_txdata<br>DDRPHY's gpio_a_dq15_txdata source |
| 10         | RW          | 0x0                | gpio_a_dq14_txdata<br>DDRPHY's gpio_a_dq14_txdata source |
| 9          | RW          | 0x0                | gpio_a_dq13_txdata<br>DDRPHY's gpio_a_dq13_txdata source |
| 8          | RW          | 0x0                | gpio_a_dq12_txdata<br>DDRPHY's gpio_a_dq12_txdata source |
| 7          | RW          | 0x0                | gpio_a_dq11_txdata<br>DDRPHY's gpio_a_dq11_txdata source |
| 6          | RW          | 0x0                | gpio_a_dq10_txdata<br>DDRPHY's gpio_a_dq10_txdata source |
| 5          | RW          | 0x0                | gpio_a_dq9_txdata<br>DDRPHY's gpio_a_dq9_txdata source   |
| 4          | RW          | 0x0                | gpio_a_dq8_txdata<br>DDRPHY's gpio_a_dq8_txdata source   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                     |
|------------|-------------|--------------------|--------------------------------------------------------|
| 3          | RW          | 0x0                | gpio_a_dq7_txdata<br>DDRPHY's gpio_a_dq7_txdata source |
| 2          | RW          | 0x0                | gpio_a_dq6_txdata<br>DDRPHY's gpio_a_dq6_txdata source |
| 1          | RW          | 0x0                | gpio_a_dq5_txdata<br>DDRPHY's gpio_a_dq5_txdata source |
| 0          | RW          | 0x0                | gpio_a_dq4_txdata<br>DDRPHY's gpio_a_dq4_txdata source |

**DDRGRF DDRPHY CON4**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31         | RW          | 0x0                | gpio_a_dq3_rxen<br>DDRPHY's gpio_a_dq3_rxen source |
| 30         | RW          | 0x0                | gpio_a_dq2_rxen<br>DDRPHY's gpio_a_dq2_rxen source |
| 29         | RW          | 0x0                | gpio_a_dq1_rxen<br>DDRPHY's gpio_a_dq1_rxen source |
| 28         | RW          | 0x0                | gpio_a_dq0_rxen<br>DDRPHY's gpio_a_dq0_rxen source |
| 27         | RW          | 0x0                | gpio_actn_rxen<br>DDRPHY's gpio_actn_rxen source   |
| 26         | RW          | 0x0                | gpio_odt1_rxen<br>DDRPHY's gpio_odt1_rxen source   |
| 25         | RW          | 0x0                | gpio_odt0_rxen<br>DDRPHY's gpio_odt0_rxen source   |
| 24         | RW          | 0x0                | gpio_csb1_rxen<br>DDRPHY's gpio_csb1_rxen source   |
| 23         | RW          | 0x0                | gpio_csb0_rxen<br>DDRPHY's gpio_csb0_rxen source   |
| 22         | RW          | 0x0                | gpio_ckb_rxen<br>DDRPHY's gpio_ckb_rxen source     |
| 21         | RW          | 0x0                | gpio_ck_rxen<br>DDRPHY's gpio_ck_rxen source       |
| 20         | RW          | 0x0                | gpio_bg1_rxen<br>DDRPHY's gpio_bg1_rxen source     |
| 19         | RW          | 0x0                | gpio_bg0_rxen<br>DDRPHY's gpio_bg0_rxen source     |
| 18         | RW          | 0x0                | gpio_ba1_rxen<br>DDRPHY's gpio_ba1_rxen source     |
| 17         | RW          | 0x0                | gpio_a17_rxen<br>DDRPHY's gpio_a17_rxen source     |
| 16         | RW          | 0x0                | gpio_a16_rxen<br>DDRPHY's gpio_a16_rxen source     |
| 15         | RW          | 0x0                | gpio_a15_rxen<br>DDRPHY's gpio_a15_rxen source     |
| 14         | RW          | 0x0                | gpio_a14_rxen<br>DDRPHY's gpio_a14_rxen source     |
| 13         | RW          | 0x0                | gpio_a13_rxen<br>DDRPHY's gpio_a13_rxen source     |
| 12         | RW          | 0x0                | gpio_a12_rxen<br>DDRPHY's gpio_a12_rxen source     |
| 11         | RW          | 0x0                | gpio_a11_rxen<br>DDRPHY's gpio_a11_rxen source     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                             |
|------------|-------------|--------------------|------------------------------------------------|
| 10         | RW          | 0x0                | gpio_a10_rxen<br>DDRPHY's gpio_a10_rxen source |
| 9          | RW          | 0x0                | gpio_a9_rxen<br>DDRPHY's gpio_a9_rxen source   |
| 8          | RW          | 0x0                | gpio_a8_rxen<br>DDRPHY's gpio_a8_rxen source   |
| 7          | RW          | 0x0                | gpio_a7_rxen<br>DDRPHY's gpio_a7_rxen source   |
| 6          | RW          | 0x0                | gpio_a6_rxen<br>DDRPHY's gpio_a6_rxen source   |
| 5          | RW          | 0x0                | gpio_a5_rxen<br>DDRPHY's gpio_a5_rxen source   |
| 4          | RW          | 0x0                | gpio_a4_rxen<br>DDRPHY's gpio_a4_rxen source   |
| 3          | RW          | 0x0                | gpio_a3_rxen<br>DDRPHY's gpio_a3_rxen source   |
| 2          | RW          | 0x0                | gpio_a2_rxen<br>DDRPHY's gpio_a2_rxen source   |
| 1          | RW          | 0x0                | gpio_a1_rxen<br>DDRPHY's gpio_a1_rxen source   |
| 0          | RW          | 0x0                | gpio_a0_rxen<br>DDRPHY's gpio_a0_rxen source   |

**DDRGRF DDRPHY CONS**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                             |
| 29         | RW          | 0x0                | gpio_resetn_rxen<br>DDRPHY's gpio_resetn_rxen source |
| 28         | RW          | 0x0                | gpio_cke0_rxen<br>DDRPHY's gpio_cke0_rxen source     |
| 27         | RW          | 0x0                | gpio_b_dq15_rxen<br>DDRPHY's gpio_b_dq15_rxen source |
| 26         | RW          | 0x0                | gpio_b_dq14_rxen<br>DDRPHY's gpio_b_dq14_rxen source |
| 25         | RW          | 0x0                | gpio_b_dq13_rxen<br>DDRPHY's gpio_b_dq13_rxen source |
| 24         | RW          | 0x0                | gpio_b_dq12_rxen<br>DDRPHY's gpio_b_dq12_rxen source |
| 23         | RW          | 0x0                | gpio_b_dq11_rxen<br>DDRPHY's gpio_b_dq11_rxen source |
| 22         | RW          | 0x0                | gpio_b_dq10_rxen<br>DDRPHY's gpio_b_dq10_rxen source |
| 21         | RW          | 0x0                | gpio_b_dq9_rxen<br>DDRPHY's gpio_b_dq9_rxen source   |
| 20         | RW          | 0x0                | gpio_b_dq8_rxen<br>DDRPHY's gpio_b_dq8_rxen source   |
| 19         | RW          | 0x0                | gpio_b_dq7_rxen<br>DDRPHY's gpio_b_dq7_rxen source   |
| 18         | RW          | 0x0                | gpio_b_dq6_rxen<br>DDRPHY's gpio_b_dq6_rxen source   |
| 17         | RW          | 0x0                | gpio_b_dq5_rxen<br>DDRPHY's gpio_b_dq5_rxen source   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 16         | RW          | 0x0                | gpio_b_dq4_rxen<br>DDRPHY's gpio_b_dq4_rxen source   |
| 15         | RW          | 0x0                | gpio_b_dq3_rxen<br>DDRPHY's gpio_b_dq3_rxen source   |
| 14         | RW          | 0x0                | gpio_b_dq2_rxen<br>DDRPHY's gpio_b_dq2_rxen source   |
| 13         | RW          | 0x0                | gpio_b_dq1_rxen<br>DDRPHY's gpio_b_dq1_rxen source   |
| 12         | RW          | 0x0                | gpio_b_dq0_rxen<br>DDRPHY's gpio_b_dq0_rxen source   |
| 11         | RW          | 0x0                | gpio_a_dq15_rxen<br>DDRPHY's gpio_a_dq15_rxen source |
| 10         | RW          | 0x0                | gpio_a_dq14_rxen<br>DDRPHY's gpio_a_dq14_rxen source |
| 9          | RW          | 0x0                | gpio_a_dq13_rxen<br>DDRPHY's gpio_a_dq13_rxen source |
| 8          | RW          | 0x0                | gpio_a_dq12_rxen<br>DDRPHY's gpio_a_dq12_rxen source |
| 7          | RW          | 0x0                | gpio_a_dq11_rxen<br>DDRPHY's gpio_a_dq11_rxen source |
| 6          | RW          | 0x0                | gpio_a_dq10_rxen<br>DDRPHY's gpio_a_dq10_rxen source |
| 5          | RW          | 0x0                | gpio_a_dq9_rxen<br>DDRPHY's gpio_a_dq9_rxen source   |
| 4          | RW          | 0x0                | gpio_a_dq8_rxen<br>DDRPHY's gpio_a_dq8_rxen source   |
| 3          | RW          | 0x0                | gpio_a_dq7_rxen<br>DDRPHY's gpio_a_dq7_rxen source   |
| 2          | RW          | 0x0                | gpio_a_dq6_rxen<br>DDRPHY's gpio_a_dq6_rxen source   |
| 1          | RW          | 0x0                | gpio_a_dq5_rxen<br>DDRPHY's gpio_a_dq5_rxen source   |
| 0          | RW          | 0x0                | gpio_a_dq4_rxen<br>DDRPHY's gpio_a_dq4_rxen source   |

**DDRGRF DDR STATUS0**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data0_0<br>Mode register read data 0 bit[31:0] status |

**DDRGRF DDR STATUS1**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data0_1<br>Mode register read data 0 bit[63:32] status |

**DDRGRF DDR STATUS2**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data0_2<br>Mode register read data 0 bit[95:64] status |

**DDRGRF DDR STATUS3**

Address: Operational Base + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data0_3<br>Mode register read data 0 bit[127:96] status |

**DDRGRF DDR STATUS4**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data1_0<br>Mode register read data 1 bit[31:0] status |

**DDRGRF DDR STATUS5**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data1_1<br>Mode register read data 1 bit[63:32] status |

**DDRGRF DDR STATUS6**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data1_2<br>Mode register read data 1 bit[95:64] status |

**DDRGRF DDR STATUS7**

Address: Operational Base + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data1_3<br>Mode register read data 1 bit[127:96] status |

**DDRGRF DDR STATUS8**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 31:21      | RO          | 0x000              | reserved                                                                                                        |
| 20         | RO          | 0x0                | dfi_freq_change_type<br>DFI frequency change type status                                                        |
| 19         | RO          | 0x0                | dfi_freq_change_req<br>DFI frequency change request state.<br>1'b0: Inactive<br>1'b1: Active                    |
| 18         | RO          | 0x0                | cpu_port_probe_mainStatAlarm<br>The status of cpu_port_probe_mainStatAlarm.<br>1'b0: Inactive<br>1'b1: Active   |
| 17         | RO          | 0x0                | cpu_port_probe_mainTraceAlarm<br>The status of cpu_port_probe_mainTraceAlarm.<br>1'b0: Inactive<br>1'b1: Active |
| 16         | RO          | 0x0                | gpu_port_probe_mainStatAlarm<br>The status of gpu_port_probe_mainStatAlarm.<br>1'b0: Inactive<br>1'b1: Active   |
| 15         | RO          | 0x0                | gpu_port_probe_mainTraceAlarm<br>The status of gpu_port_probe_mainTraceAlarm.<br>1'b0: Inactive<br>1'b1: Active |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 14         | RO          | 0x0                | mmip_port_probe_mainStatAlarm<br>The status of mmip_port_probe_mainStatAlarm.<br>1'b0: Inactive<br>1'b1: Active   |
| 13         | RO          | 0x0                | mmip_port_probe_mainTraceAlarm<br>The status of mmip_port_probe_mainTraceAlarm.<br>1'b0: Inactive<br>1'b1: Active |
| 12         | RO          | 0x0                | peri_port_probe_mainStatAlarm<br>The status of peri_port_probe_mainStatAlarm.<br>1'b0: Inactive<br>1'b1: Active   |
| 11         | RO          | 0x0                | peri_port_probe_mainTraceAlarm<br>The status of peri_port_probe_mainTraceAlarm.<br>1'b0: Inactive<br>1'b1: Active |
| 10         | RO          | 0x0                | dfi_scramble_read_of<br>The status of dfi_scramble_read_of.<br>1'b0: Inactive<br>1'b1: Active                     |
| 9          | RO          | 0x0                | dfi_scramble_write_of<br>The status of dfi_scramble_write_of.<br>1'b0: Inactive<br>1'b1: Active                   |
| 8          | RO          | 0x0                | dfi_scramble_key_ready<br>The status of dfi_scramble_key_ready.<br>1'b0: Not ready<br>1'b1: Ready                 |
| 7:6        | RO          | 0x0                | ddrc_reg_selfref_type<br>The status of ddrc_reg_selfref_type.                                                     |
| 5          | RO          | 0x0                | cactive_aclk<br>The status of cactive_aclk.<br>1'b0: Inactive<br>1'b1: Active                                     |
| 4          | RO          | 0x1                | csysclk_aclk<br>The status of csysclk_aclk.<br>1'b0: Inactive<br>1'b1: Active                                     |
| 3          | RO          | 0x0                | csysreq_aclk<br>The status of csysreq_aclk.<br>1'b0: Inactive<br>1'b1: Active                                     |
| 2          | RO          | 0x1                | cactive_ddrc<br>The status of external cactive_ddrc.<br>1'b0: Inactive<br>1'b1: Active                            |
| 1          | RO          | 0x1                | csysack_ddrc<br>The status of external csysack_ddrc.<br>1'b0: Inactive<br>1'b1: Active                            |
| 0          | RO          | 0x1                | csysreq_ddrc<br>The status of external csysreq_ddrc.<br>1'b0: Inactive<br>1'b1: Active                            |

**DDRGRF DDR STATUS9**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31         | RO          | 0x1                | dfi_lp_ck_disable<br>The status of low power of DDR PHY    |
| 30         | RO          | 0x0                | reserved                                                   |
| 29:24      | RO          | 0x00               | hif_refresh_req_bank<br>The status of hif_refresh_req_bank |
| 23         | RO          | 0x0                | reserved                                                   |
| 22:16      | RO          | 0x00               | wr_credit_cnt<br>The status of wr_credit_cnt               |
| 15         | RO          | 0x0                | reserved                                                   |
| 14:8       | RO          | 0x00               | hpr_credit_cnt<br>The status of hpr_credit_cnt             |
| 7          | RO          | 0x0                | reserved                                                   |
| 6:0        | RO          | 0x00               | lpr_credit_cnt<br>The status of lpr_credit_cnt             |

**DDRGRF DDR STATUS10**

Address: Operational Base + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data2_0<br>Mode register read data 2 bit[31:0] status |

**DDRGRF DDR STATUS11**

Address: Operational Base + offset (0x012C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data2_1<br>Mode register read data 2 bit[63:32] status |

**DDRGRF DDR STATUS12**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data2_2<br>Mode register read data 2 bit[95:64] status |

**DDRGRF DDR STATUS13**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data2_3<br>Mode register read data 2 bit[127:96] status |

**DDRGRF DDR STATUS14**

Address: Operational Base + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data3_0<br>Mode register read data 3 bit[31:0] status |

**DDRGRF DDR STATUS15**

Address: Operational Base + offset (0x013C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data3_1<br>Mode register read data 3 bit[63:32] status |

**DDRGRF DDR STATUS16**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data3_2<br>Mode register read data 3 bit[95:64] status |

**DDRGRF DDR STATUS17**

Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                          |
|------------|-------------|--------------------|-------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | mrr_data3_3<br>Mode register read data 3 bit[127:96] status |

**DDRGRF DDRHOLD STATUS**

Address: Operational Base + offset (0x0150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                         |
| 28         | RO          | 0x0                | arvalid_from_msch<br>arvalid from msch status.<br>1'b0: Inactive<br>1'b1: Active |
| 27         | RO          | 0x0                | arvalid_to_next<br>arvalid to next status.<br>1'b0: Inactive<br>1'b1: Active     |
| 26         | RO          | 0x0                | arready_from_next<br>arready from next status.<br>1'b0: Inactive<br>1'b1: Active |
| 25         | RO          | 0x0                | arready_to_msch<br>arready to msch status.<br>1'b0: Inactive<br>1'b1: Active     |
| 24         | RO          | 0x1                | arready_low<br>arready low status.<br>1'b0: Inactive<br>1'b1: Active             |
| 23:21      | RO          | 0x0                | reserved                                                                         |
| 20         | RO          | 0x0                | wvalid_from_msch<br>wvalid from msch status.<br>1'b0: Inactive<br>1'b1: Active   |
| 19         | RO          | 0x0                | wvalid_to_next<br>wvalid to next status.<br>1'b0: Inactive<br>1'b1: Active       |
| 18         | RO          | 0x0                | wready_from_next<br>wready from next status.<br>1'b0: Inactive<br>1'b1: Active   |
| 17         | RO          | 0x0                | wready_to_msch<br>wready to msch status.<br>1'b0: Inactive<br>1'b1: Active       |
| 16         | RO          | 0x1                | wready_low<br>wready low status.<br>1'b0: Inactive<br>1'b1: Active               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------|
| 15:13      | RO          | 0x0                | reserved                                                                         |
| 12         | RO          | 0x0                | awvalid_from_msch<br>awvalid from msch status.<br>1'b0: Inactive<br>1'b1: Active |
| 11         | RO          | 0x0                | awvalid_to_next<br>awvalid to next status.<br>1'b0: Inactive<br>1'b1: Active     |
| 10         | RO          | 0x0                | awready_from_next<br>awready from next status.<br>1'b0: Inactive<br>1'b1: Active |
| 9          | RO          | 0x0                | awready_to_msch<br>awready to msch status.<br>1'b0: Inactive<br>1'b1: Active     |
| 8          | RO          | 0x1                | awready_low<br>awready low status.<br>1'b0: Inactive<br>1'b1: Active             |
| 7:0        | RO          | 0x40               | write_burst_cnt<br>Write burst count status                                      |

**DDRGRF DDRPHY STATUS0**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                 |
| 29         | RO          | 0x1                | gpio_resetn_rxdata<br>DDRPHY's gpio_resetn_rxdata output |
| 28         | RO          | 0x1                | gpio_cke0_rxdata<br>DDRPHY's gpio_cke0_rxdata output     |
| 27         | RO          | 0x1                | gpio_actn_rxdata<br>DDRPHY's gpio_actn_rxdata output     |
| 26         | RO          | 0x1                | gpio_odt1_rxdata<br>DDRPHY's gpio_odt1_rxdata output     |
| 25         | RO          | 0x1                | gpio_odt0_rxdata<br>DDRPHY's gpio_odt0_rxdata output     |
| 24         | RO          | 0x1                | gpio_csb1_rxdata<br>DDRPHY's gpio_csb1_rxdata output     |
| 23         | RO          | 0x1                | gpio_csb0_rxdata<br>DDRPHY's gpio_csb0_rxdata output     |
| 22         | RO          | 0x1                | gpio_ckb_rxdata<br>DDRPHY's gpio_ckb_rxdata output       |
| 21         | RO          | 0x1                | gpio_ck_rxdata<br>DDRPHY's gpio_ck_rxdata output         |
| 20         | RO          | 0x1                | gpio_bg1_rxdata<br>DDRPHY's gpio_bg1_rxdata output       |
| 19         | RO          | 0x1                | gpio_bg0_rxdata<br>DDRPHY's gpio_bg0_rxdata output       |
| 18         | RO          | 0x1                | gpio_ba1_rxdata<br>DDRPHY's gpio_ba1_rxdata output       |
| 17         | RO          | 0x1                | gpio_a17_rxdata<br>DDRPHY's gpio_a17_rxdata output       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 16         | RO          | 0x1                | gpio_a16_rxdata<br>DDRPHY's gpio_a16_rxdata output |
| 15         | RO          | 0x1                | gpio_a15_rxdata<br>DDRPHY's gpio_a15_rxdata output |
| 14         | RO          | 0x1                | gpio_a14_rxdata<br>DDRPHY's gpio_a14_rxdata output |
| 13         | RO          | 0x1                | gpio_a13_rxdata<br>DDRPHY's gpio_a13_rxdata output |
| 12         | RO          | 0x1                | gpio_a12_rxdata<br>DDRPHY's gpio_a12_rxdata output |
| 11         | RO          | 0x1                | gpio_a11_rxdata<br>DDRPHY's gpio_a11_rxdata output |
| 10         | RO          | 0x1                | gpio_a10_rxdata<br>DDRPHY's gpio_a10_rxdata output |
| 9          | RO          | 0x1                | gpio_a9_rxdata<br>DDRPHY's gpio_a9_rxdata output   |
| 8          | RO          | 0x1                | gpio_a8_rxdata<br>DDRPHY's gpio_a8_rxdata output   |
| 7          | RO          | 0x1                | gpio_a7_rxdata<br>DDRPHY's gpio_a7_rxdata output   |
| 6          | RO          | 0x1                | gpio_a6_rxdata<br>DDRPHY's gpio_a6_rxdata output   |
| 5          | RO          | 0x1                | gpio_a5_rxdata<br>DDRPHY's gpio_a5_rxdata output   |
| 4          | RO          | 0x1                | gpio_a4_rxdata<br>DDRPHY's gpio_a4_rxdata output   |
| 3          | RO          | 0x1                | gpio_a3_rxdata<br>DDRPHY's gpio_a3_rxdata output   |
| 2          | RO          | 0x1                | gpio_a2_rxdata<br>DDRPHY's gpio_a2_rxdata output   |
| 1          | RO          | 0x1                | gpio_a1_rxdata<br>DDRPHY's gpio_a1_rxdata output   |
| 0          | RO          | 0x1                | gpio_a0_rxdata<br>DDRPHY's gpio_a0_rxdata output   |

**DDRGRF\_DDRPHY\_STATUS1**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 31         | RO          | 0x1                | gpio_b_dq15_rxdata<br>DDRPHY's gpio_b_dq15_rxdata output |
| 30         | RO          | 0x1                | gpio_b_dq14_rxdata<br>DDRPHY's gpio_b_dq14_rxdata output |
| 29         | RO          | 0x1                | gpio_b_dq13_rxdata<br>DDRPHY's gpio_b_dq13_rxdata output |
| 28         | RO          | 0x1                | gpio_b_dq12_rxdata<br>DDRPHY's gpio_b_dq12_rxdata output |
| 27         | RO          | 0x1                | gpio_b_dq11_rxdata<br>DDRPHY's gpio_b_dq11_rxdata output |
| 26         | RO          | 0x1                | gpio_b_dq10_rxdata<br>DDRPHY's gpio_b_dq10_rxdata output |
| 25         | RO          | 0x1                | gpio_b_dq9_rxdata<br>DDRPHY's gpio_b_dq9_rxdata output   |
| 24         | RO          | 0x1                | gpio_b_dq8_rxdata<br>DDRPHY's gpio_b_dq8_rxdata output   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                       |
|------------|-------------|--------------------|----------------------------------------------------------|
| 23         | RO          | 0x1                | gpio_b_dq7_rxdata<br>DDRPHY's gpio_b_dq7_rxdata output   |
| 22         | RO          | 0x1                | gpio_b_dq6_rxdata<br>DDRPHY's gpio_b_dq6_rxdata output   |
| 21         | RO          | 0x1                | gpio_b_dq5_rxdata<br>DDRPHY's gpio_b_dq5_rxdata output   |
| 20         | RO          | 0x1                | gpio_b_dq4_rxdata<br>DDRPHY's gpio_b_dq4_rxdata output   |
| 19         | RO          | 0x1                | gpio_b_dq3_rxdata<br>DDRPHY's gpio_b_dq3_rxdata output   |
| 18         | RO          | 0x1                | gpio_b_dq2_rxdata<br>DDRPHY's gpio_b_dq2_rxdata output   |
| 17         | RO          | 0x1                | gpio_b_dq1_rxdata<br>DDRPHY's gpio_b_dq1_rxdata output   |
| 16         | RO          | 0x1                | gpio_b_dq0_rxdata<br>DDRPHY's gpio_b_dq0_rxdata output   |
| 15         | RO          | 0x1                | gpio_a_dq15_rxdata<br>DDRPHY's gpio_a_dq15_rxdata output |
| 14         | RO          | 0x1                | gpio_a_dq14_rxdata<br>DDRPHY's gpio_a_dq14_rxdata output |
| 13         | RO          | 0x1                | gpio_a_dq13_rxdata<br>DDRPHY's gpio_a_dq13_rxdata output |
| 12         | RO          | 0x1                | gpio_a_dq12_rxdata<br>DDRPHY's gpio_a_dq12_rxdata output |
| 11         | RO          | 0x1                | gpio_a_dq11_rxdata<br>DDRPHY's gpio_a_dq11_rxdata output |
| 10         | RO          | 0x1                | gpio_a_dq10_rxdata<br>DDRPHY's gpio_a_dq10_rxdata output |
| 9          | RO          | 0x1                | gpio_a_dq9_rxdata<br>DDRPHY's gpio_a_dq9_rxdata output   |
| 8          | RO          | 0x1                | gpio_a_dq8_rxdata<br>DDRPHY's gpio_a_dq8_rxdata output   |
| 7          | RO          | 0x1                | gpio_a_dq7_rxdata<br>DDRPHY's gpio_a_dq7_rxdata output   |
| 6          | RO          | 0x1                | gpio_a_dq6_rxdata<br>DDRPHY's gpio_a_dq6_rxdata output   |
| 5          | RO          | 0x1                | gpio_a_dq5_rxdata<br>DDRPHY's gpio_a_dq5_rxdata output   |
| 4          | RO          | 0x1                | gpio_a_dq4_rxdata<br>DDRPHY's gpio_a_dq4_rxdata output   |
| 3          | RO          | 0x1                | gpio_a_dq3_rxdata<br>DDRPHY's gpio_a_dq3_rxdata output   |
| 2          | RO          | 0x1                | gpio_a_dq2_rxdata<br>DDRPHY's gpio_a_dq2_rxdata output   |
| 1          | RO          | 0x1                | gpio_a_dq1_rxdata<br>DDRPHY's gpio_a_dq1_rxdata output   |
| 0          | RO          | 0x1                | gpio_a_dq0_rxdata<br>DDRPHY's gpio_a_dq0_rxdata output   |

## 6.5 PMUGRF Register Description

### 6.5.1 Registers Summary

| Name                   | Offset | Size | Reset Value | Description                                       |
|------------------------|--------|------|-------------|---------------------------------------------------|
| PMUGRF GPIO0A IOMUX_L  | 0x0000 | W    | 0x00001010  | GPIO0A low bits IOMUX control register            |
| PMUGRF GPIO0A IOMUX_H  | 0x0004 | W    | 0x00000000  | GPIO0A high bits IOMUX control register           |
| PMUGRF GPIO0B IOMUX_L  | 0x0008 | W    | 0x00000000  | GPIO0B low bits IOMUX control register            |
| PMUGRF GPIO0B IOMUX_H  | 0x000C | W    | 0x00000000  | GPIO0B high bits IOMUX control register           |
| PMUGRF GPIO0C IOMUX_L  | 0x0010 | W    | 0x00000000  | GPIO0C low bits IOMUX control register            |
| PMUGRF GPIO0A DS_L     | 0x0020 | W    | 0x00001111  | GPIO0A low bits driver strength control register  |
| PMUGRF GPIO0A DS_H     | 0x0024 | W    | 0x00001111  | GPIO0A high bits driver strength control register |
| PMUGRF GPIO0B DS_L     | 0x0028 | W    | 0x00001111  | GPIO0B low bits driver strength control register  |
| PMUGRF GPIO0B DS_H     | 0x002C | W    | 0x00001111  | GPIO0B high bits driver strength control register |
| PMUGRF GPIO0C DS_L     | 0x0030 | W    | 0x00001111  | GPIO0C low bits driver strength control register  |
| PMUGRF OSC DS          | 0x0034 | W    | 0x00000001  | OSC driver strength control register              |
| PMUGRF GPIO0A P        | 0x0040 | W    | 0x0000A542  | GPIO0A PU/PD control register                     |
| PMUGRF GPIO0B P        | 0x0044 | W    | 0x0000A5AA  | GPIO0B PU/PD control register                     |
| PMUGRF GPIO0C P_L      | 0x0048 | W    | 0x000000AA  | GPIO0C low bits PU/PD control register            |
| PMUGRF GPIO0A IE       | 0x0050 | W    | 0x000000FF  | GPIO0A IE control register                        |
| PMUGRF GPIO0B IE       | 0x0054 | W    | 0x000000FF  | GPIO0B IE control register                        |
| PMUGRF GPIO0C IE_L     | 0x0058 | W    | 0x0000000F  | GPIO0C low bits IE control register               |
| PMUGRF GPIO0A SMT      | 0x0060 | W    | 0x00000000  | GPIO0A SMT control register                       |
| PMUGRF GPIO0B SMT      | 0x0064 | W    | 0x00000000  | GPIO0B SMT control register                       |
| PMUGRF GPIO0C SMT_L    | 0x0068 | W    | 0x00000000  | GPIO0C low bits SMT control register              |
| PMUGRF PMU SOC CON0    | 0x0100 | W    | 0x00000000  | PMU SOC control register 0                        |
| PMUGRF PMU SOC CON1    | 0x0104 | W    | 0x00000000  | PMU SOC control register 1                        |
| PMUGRF PMU SOC CON2    | 0x0108 | W    | 0x00000000  | PMU SOC control register 2                        |
| PMUGRF PMU SOC CON3    | 0x010C | W    | 0x0000001C  | PMU SOC control register 3                        |
| PMUGRF PMU SOC CON4    | 0x0110 | W    | 0x00002805  | PMU SOC control register 4                        |
| PMUGRF IOFUNC CON4     | 0x0114 | W    | 0x00000000  | IO function control register 4                    |
| PMUGRF IOFUNC CON5     | 0x0118 | W    | 0x00000000  | IO function control register 5                    |
| PMUGRF IO_VSEL         | 0x0140 | W    | 0x00000000  | VCCIO voltage control register                    |
| PMUGRF IO_VRET         | 0x0144 | W    | 0x000003FE  | VCCIO retention control register                  |
| PMUGRF PMUPVTM CLKD_IV | 0x0180 | W    | 0x00000000  | PMU PVTM 32KHz clock divider register             |
| PMUGRF OS_REG0         | 0x0200 | W    | 0x00000000  | OS register 0                                     |
| PMUGRF OS_REG1         | 0x0204 | W    | 0x00000000  | OS register 1                                     |
| PMUGRF OS_REG2         | 0x0208 | W    | 0x00000000  | OS register 2                                     |
| PMUGRF OS_REG3         | 0x020C | W    | 0x00000000  | OS register 3                                     |

| Name                     | Offset | Size | Reset Value | Description                        |
|--------------------------|--------|------|-------------|------------------------------------|
| PMUGRF OS REG4           | 0x0210 | W    | 0x00000000  | OS register 4                      |
| PMUGRF OS REG5           | 0x0214 | W    | 0x00000000  | OS register 5                      |
| PMUGRF OS REG6           | 0x0218 | W    | 0x00000000  | OS register 6                      |
| PMUGRF OS REG7           | 0x021C | W    | 0x00000000  | OS register 7                      |
| PMUGRF OS REG8           | 0x0220 | W    | 0x00000000  | OS register 9                      |
| PMUGRF OS REG9           | 0x0224 | W    | 0x00000000  | OS register 9                      |
| PMUGRF OS REG10          | 0x0228 | W    | 0x00000000  | OS register 10                     |
| PMUGRF OS REG11          | 0x022C | W    | 0x00000000  | OS register 11                     |
| PMUGRF RSTFUNC STAT US   | 0x0230 | W    | 0x00000000  | System reset status register       |
| PMUGRF RSTFUNC CLR       | 0x0234 | W    | 0x00000000  | System reset status clear register |
| PMUGRF SD DETECT CON     | 0x0380 | W    | 0x00000000  | SDMMC detect irq enable register   |
| PMUGRF SD DETECT ST ATUS | 0x0390 | W    | 0x00000000  | SDMMC detect irq status register   |
| PMUGRF SD DETECT CLR     | 0x03A0 | W    | 0x00000000  | SDMMC detect irq clear register    |
| PMUGRF SD DETECT COUNT   | 0x03B0 | W    | 0x000003E8  | SDMMC detect counter register      |

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

## 6.5.2 Detail Register Description

### PMUGRF GPIO0A IOMUX L

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:12 | RW   | 0x1         | gpio0a3_sel<br>3'h0: GPIO0_A3_u<br>3'h1: SDMMC0_DET<br>Others: Reserved                                                           |
| 11    | RO   | 0x0         | reserved                                                                                                                          |
| 10:8  | RW   | 0x0         | gpio0a2_sel<br>3'h0: GPIO0_A2_z<br>3'h1: CLK_32K<br>Others: Reserved                                                              |
| 7     | RO   | 0x0         | reserved                                                                                                                          |
| 6:4   | RW   | 0x1         | gpio0a1_sel<br>3'h0: GPIO0_A1_z<br>3'h1: TSADC_SHUT_M0<br>3'h2: TSADC_SHUTORG<br>Others: Reserved                                 |
| 3     | RO   | 0x0         | reserved                                                                                                                          |
| 2:0   | RW   | 0x0         | gpio0a0_sel<br>3'h0: GPIO0_A0_d<br>3'h1: CLK_REF<br>Others: Reserved                                                              |

### PMUGRF GPIO0A IOMUX H

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 |
| 15         | RO          | 0x0                | reserved                                                                                                                          |
| 14:12      | RW          | 0x0                | gpio0a7_sel<br>3'h0: GPIO0_A7_d<br>3'h1: SPI0_MISO_M0<br>Others: Reserved                                                         |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio0a6_sel<br>3'h0: GPIO0_A6_d<br>3'h1: SPI0_MOSI_M0<br>Others: Reserved                                                         |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio0a5_sel<br>3'h0: GPIO0_A5_u<br>3'h1: SPI0_CS0N_M0<br>Others: Reserved                                                         |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio0a4_sel<br>3'h0: GPIO0_A4_u<br>3'h1: SPI0_CS1N_M0<br>Others: Reserved                                                         |

**PMUGRF GPIO0B\_IOMUX\_L**

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         | RO          | 0x0                | reserved                                                                                                                          |
| 14:12      | RW          | 0x0                | gpio0b3_sel<br>3'h0: GPIO0_B3_d<br>3'h1: FLASH_VOL_SEL<br>Others: Reserved                                                        |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio0b2_sel<br>3'h0: GPIO0_B2_d<br>3'h1: PMIC_SLEEP<br>3'h2: TSADC_SHUT_M1<br>3'h3: PWM6_PIN_M0<br>Others: Reserved               |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio0b1_sel<br>3'h0: GPIO0_B1_d<br>3'h1: PMIC_INT<br>3'h3: PWM7_PIN_M0<br>Others: Reserved                                        |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio0b0_sel<br>3'h0: GPIO0_B0_d<br>3'h1: SPI0_CLK_M0<br>Others: Reserved                                                          |

**PMUGRF GPIO0B IOMUX H**

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         | RO          | 0x0                | reserved                                                                                                                          |
| 14:12      | RW          | 0x0                | gpio0b7_sel<br>3'h0: GPIO0_B7_d<br>3'h2: UART1_RX_M0<br>3'h3: PWM1_PIN_M0<br>Others: Reserved                                     |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio0b6_sel<br>3'h0: GPIO0_B6_d<br>3'h2: UART1_TX_M0<br>3'h3: PWM0_PIN_M0<br>Others: Reserved                                     |
| 7          | RO          | 0x0                | reserved                                                                                                                          |
| 6:4        | RW          | 0x0                | gpio0b5_sel<br>3'h0: GPIO0_B5_u<br>3'h1: I2C0_SDA<br>Others: Reserved                                                             |
| 3          | RO          | 0x0                | reserved                                                                                                                          |
| 2:0        | RW          | 0x0                | gpio0b4_sel<br>3'h0: GPIO0_B4_u<br>3'h1: I2C0_SCL<br>Others: Reserved                                                             |

**PMUGRF GPIO0C IOMUX L**

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         | RO          | 0x0                | reserved                                                                                                                          |
| 14:12      | RW          | 0x0                | gpio0c3_sel<br>3'h0: GPIO0_C3_d<br>3'h1: I2C2_SDA<br>3'h3: PWM5_PIN_M0<br>Others: Reserved                                        |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10:8       | RW          | 0x0                | gpio0c2_sel<br>3'h0: GPIO0_C2_d<br>3'h1: I2C2_SCL<br>3'h3: PWM4_PIN_M0<br>Others: Reserved                                        |
| 7          | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 6:4        | RW          | 0x0                | gpio0c1_sel<br>3'h0: GPIO0_C1_d<br>3'h1: PMU_DEBUG<br>3'h2: UART1_CTSN_M0<br>3'h3: PWM3_PIN_M0<br>Others: Reserved  |
| 3          | RO          | 0x0                | reserved                                                                                                            |
| 2:0        | RW          | 0x0                | gpio0c0_sel<br>3'h0: GPIO0_C0_d<br>3'h1: SDMMC0_PWR<br>3'h2: UART1_RTSN_M0<br>3'h3: PWM2_PIN_M0<br>Others: Reserved |

**PMUGRF GPIO0A DS L**

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'b0: Write access disable<br>1'b1: Write access enable                                                                                                                                                                                                                                                                                                                      |
| 15:12      | RW          | 0x1                | gpio0a3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 11:8       | RW          | 0x1                | gpio0a2_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |
| 7:4        | RW          | 0x1                | gpio0a1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | RW   | 0x1         | <p>gpio0a0_ds</p> <p>4'd0: Level 0 strength</p> <p>4'd1: Level 1 strength</p> <p>4'd2: Level 2 strength</p> <p>4'd3: Level 3 strength</p> <p>4'd4: Level 4 strength</p> <p>4'd5: Level 5 strength</p> <p>4'd6: Level 6 strength</p> <p>4'd7: Level 7 strength</p> <p>4'd8: Level 8 strength</p> <p>4'd9: Level 9 strength</p> <p>4'd10: Level 10 strength</p> <p>4'd11: Level 11 strength</p> <p>4'd12: Level 12 strength</p> <p>4'd13: Level 13 strength</p> <p>4'd14: Level 14 strength</p> <p>4'd15: Level 15 strength</p> |

**PMUGRF GPIO0A DS H**

Address: Operational Base + offset (0x0024)

| Bit   | Attr | Reset Value | Description                                                                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | WO   | 0x0000      | <p>write_enable</p> <p>Write enable for lower 16bits, each bit is individual.</p> <p>1'b0: Write access disable</p> <p>1'b1: Write access enable</p>                  |
| 15:12 | RW   | 0x1         | <p>gpio0a7_ds</p> <p>4'd0: Level 0' strength</p> <p>4'd1: Level 1' strength</p> <p>4'd2: Level 2' strength</p> <p>4'd3: Level 3' strength</p> <p>Others: Reserved</p> |
| 11:8  | RW   | 0x1         | <p>gpio0a6_ds</p> <p>4'd0: Level 0' strength</p> <p>4'd1: Level 1' strength</p> <p>4'd2: Level 2' strength</p> <p>4'd3: Level 3' strength</p> <p>Others: Reserved</p> |
| 7:4   | RW   | 0x1         | <p>gpio0a5_ds</p> <p>4'd0: Level 0' strength</p> <p>4'd1: Level 1' strength</p> <p>4'd2: Level 2' strength</p> <p>4'd3: Level 3' strength</p> <p>Others: Reserved</p> |
| 3:0   | RW   | 0x1         | <p>gpio0a4_ds</p> <p>4'd0: Level 0' strength</p> <p>4'd1: Level 1' strength</p> <p>4'd2: Level 2' strength</p> <p>4'd3: Level 3' strength</p> <p>Others: Reserved</p> |

**PMUGRF GPIO0B DS L**

Address: Operational Base + offset (0x0028)

| <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      | RW          | 0x1                | gpio0b3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 11:8       | RW          | 0x1                | gpio0b2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 7:4        | RW          | 0x1                | gpio0b1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved                                                                                                                                                                                                                                                                                                             |
| 3:0        | RW          | 0x1                | gpio0b0_ds<br>4'd0: Level 0 strength<br>4'd1: Level 1 strength<br>4'd2: Level 2 strength<br>4'd3: Level 3 strength<br>4'd4: Level 4 strength<br>4'd5: Level 5 strength<br>4'd6: Level 6 strength<br>4'd7: Level 7 strength<br>4'd8: Level 8 strength<br>4'd9: Level 9 strength<br>4'd10: Level 10 strength<br>4'd11: Level 11 strength<br>4'd12: Level 12 strength<br>4'd13: Level 13 strength<br>4'd14: Level 14 strength<br>4'd15: Level 15 strength |

**PMUGRF GPIO0B DS H**

Address: Operational Base + offset (0x002C)

| <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      | RW          | 0x1                | gpio0b7_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8       | RW          | 0x1                | gpio0b6_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio0b5_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio0b4_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**PMUGRF GPIO0C DS L**

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:12      | RW          | 0x1                | gpio0c3_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 11:8       | RW          | 0x1                | gpio0c2_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 7:4        | RW          | 0x1                | gpio0c1_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |
| 3:0        | RW          | 0x1                | gpio0c0_ds<br>4'd0: Level 0' strength<br>4'd1: Level 1' strength<br>4'd2: Level 2' strength<br>4'd3: Level 3' strength<br>Others: Reserved |

**PMUGRF OSC DS**

Address: Operational Base + offset (0x0034)

| <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:0        | RW          | 0x1                | osc_ds<br>2'd0: Level 0" strength<br>2'd1: Level 1" strength<br>2'd2: Level 2" strength<br>2'd3: Level 3" strength                |

**PMUGRF GPIO0A\_P**

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 |
| 15:14      | RW          | 0x2                | gpio0a7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio0a6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x1                | gpio0a5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 9:8        | RW          | 0x1                | gpio0a4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 7:6        | RW          | 0x1                | gpio0a3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 5:4        | RW          | 0x0                | gpio0a2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 3:2        | RW          | 0x0                | gpio0a1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x2                | gpio0a0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved |

**PMUGRF GPIO0B\_P**

Address: Operational Base + offset (0x0044)

| <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:14      | RW          | 0x2                | gpio0b7_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 13:12      | RW          | 0x2                | gpio0b6_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 11:10      | RW          | 0x1                | gpio0b5_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 9:8        | RW          | 0x1                | gpio0b4_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 7:6        | RW          | 0x2                | gpio0b3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 5:4        | RW          | 0x2                | gpio0b2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 3:2        | RW          | 0x2                | gpio0b1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 1:0        | RW          | 0x2                | gpio0b0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

**PMUGRF GPIO0C\_P\_L**

Address: Operational Base + offset (0x0048)

| <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:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7:6        | RW          | 0x2                | gpio0c3_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 5:4        | RW          | 0x2                | gpio0c2_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 3:2        | RW          | 0x2                | gpio0c1_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |
| 1:0        | RW          | 0x2                | gpio0c0_p<br>2'b00: Z (Normal operation)<br>2'b01: Weak 1 (pull-up)<br>2'b10: Weak 0 (pull-down)<br>2'b11: Reserved               |

**PMUGRF GPIO0A IE**

Address: Operational Base + offset (0x0050)

| <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:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio0a7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio0a6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5          | RW          | 0x1                | gpio0a5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4          | RW          | 0x1                | gpio0a4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3          | RW          | 0x1                | gpio0a3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2          | RW          | 0x1                | gpio0a2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 1          | RW          | 0x1                | gpio0a1_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 0          | RW          | 0x1                | gpio0a0_ie<br>1'b0: Input disable<br>1'b1: Input enable |

**PMUGRF GPIO0B IE**

Address: Operational Base + offset (0x0054)

| <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:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | gpio0b7_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 6          | RW          | 0x1                | gpio0b6_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 5          | RW          | 0x1                | gpio0b5_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 4          | RW          | 0x1                | gpio0b4_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 3          | RW          | 0x1                | gpio0b3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2          | RW          | 0x1                | gpio0b2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 1          | RW          | 0x1                | gpio0b1_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 0          | RW          | 0x1                | gpio0b0_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

**PMUGRF GPIO0C IE L**

Address: Operational Base + offset (0x0058)

| <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          | 0x1                | gpio0c3_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |
| 2          | RW          | 0x1                | gpio0c2_ie<br>1'b0: Input disable<br>1'b1: Input enable                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 1          | RW          | 0x1                | gpio0c1_ie<br>1'b0: Input disable<br>1'b1: Input enable |
| 0          | RW          | 0x1                | gpio0c0_ie<br>1'b0: Input disable<br>1'b1: Input enable |

**PMUGRF GPIO0A SMT**

Address: Operational Base + offset (0x0060)

| <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:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x0                | gpio0a7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio0a6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 5          | RW          | 0x0                | gpio0a5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 4          | RW          | 0x0                | gpio0a4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 3          | RW          | 0x0                | gpio0a3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 2          | RW          | 0x0                | gpio0a2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 1          | RW          | 0x0                | gpio0a1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio0a0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**PMUGRF GPIO0B SMT**

Address: Operational Base + offset (0x0064)

| <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:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7          | RW          | 0x0                | gpio0b7_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 6          | RW          | 0x0                | gpio0b6_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 5          | RW          | 0x0                | gpio0b5_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 4          | RW          | 0x0                | gpio0b4_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 3          | RW          | 0x0                | gpio0b3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 2          | RW          | 0x0                | gpio0b2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 1          | RW          | 0x0                | gpio0b1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |
| 0          | RW          | 0x0                | gpio0b0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled |

**PMUGRF GPIO0C SMT L**

Address: Operational Base + offset (0x0068)

| <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                | gpio0c3_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 2          | RW          | 0x0                | gpio0c2_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 1          | RW          | 0x0                | gpio0c1_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |
| 0          | RW          | 0x0                | gpio0c0_smt<br>1'b0: No hysteresis<br>1'b1: Schmitt trigger enabled                                                               |

**PMUGRF PMU SOC CON0**

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         | RW          | 0x0                | hold_reset_ddrfailsafe<br>Hold ddrfailsafe reset. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable |
| 14         | RO          | 0x0                | reserved                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RW          | 0x0                | ddrphy_bufferen_core<br>1'b0: Enable DDRPHY io retention<br>1'b1: Disable DDRPHY io retention                                                                                                                      |
| 12         | RW          | 0x0                | ddrphy_bufferen_sel<br>DDRPHY bufferen selection.<br>1'b0: Select from pmu and ddr_fail_safe<br>1'b1: Select from ddrphy_bufferen_core                                                                             |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                           |
| 9          | RW          | 0x0                | pmic_sleep_sel<br>PMIC_SLEEP source selection.<br>1'b0: npor_out2chip_rst, from reset pulse generator, can reset external PMIC.<br>1'b1: pmu_sleep, from PMU block, only support sleep function for external PMIC. |
| 8:7        | RO          | 0x0                | reserved                                                                                                                                                                                                           |
| 6          | RW          | 0x0                | uart1_cts_inv<br>uart1_cts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                                                                                                            |
| 5          | RW          | 0x0                | uart1_rts_inv<br>uart1_rts polarity selection.<br>1'b0: Low active<br>1'b1: High active                                                                                                                            |
| 4:1        | RO          | 0x0                | reserved                                                                                                                                                                                                           |
| 0          | RW          | 0x0                | clk32k_ioe<br>32KHz clock output enable.<br>1'b0: Output disable<br>1'b1: Output enable                                                                                                                            |

**PMUGRF PMU SOC CON1**

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         | RW          | 0x0                | hold_preset_uart1<br>Hold preset_uart1. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable        |
| 14         | RW          | 0x0                | hold_preset_spi0<br>Hold preset_spi0. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable          |
| 13         | RW          | 0x0                | hold_preset_pwm1<br>Hold preset_pwm1. 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>                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | hold_preset_pwm0<br>Hold preset_pwm0. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable                   |
| 11         | RW          | 0x0                | hold_preset_pmusgrf<br>Hold preset_pmusgrf. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable             |
| 10         | RW          | 0x0                | hold_preset_pmusgrf_remap<br>Hold preset_pmusgrf_remap. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable |
| 9          | RW          | 0x0                | hold_preset_pmupvtm<br>Hold preset_pmupvtm. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable             |
| 8          | RW          | 0x0                | hold_preset_pmumem<br>Hold preset_pmumem. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable               |
| 7          | RW          | 0x0                | hold_preset_pmugrf<br>Hold preset_pmugrf. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable               |
| 6          | RW          | 0x0                | hold_preset_pmucru<br>Hold preset_pmucru. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable               |
| 5          | RW          | 0x0                | hold_preset_pdpmu_biu<br>Hold preset_pdpmu_biu. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable         |
| 4          | RW          | 0x0                | hold_preset_i2c2<br>Hold preset_i2c2. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable                   |
| 3          | RW          | 0x0                | hold_preset_i2c0<br>Hold preset_i2c0. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable                   |
| 2          | RW          | 0x0                | hold_preset_gpio0<br>Hold preset_gpio0. 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>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | hold_preset_chipverotp<br>Hold preset_chipverotp. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | hold_dbreset_gpio0<br>Hold dbreset_gpio0. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable         |

**PMUGRF PMU SOC CON2**

Address: Operational Base + offset (0x0108)

| <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:13      | RO          | 0x0                | reserved                                                                                                                          |
| 12:8       | RW          | 0x00               | reset_width<br>The chip output reset width, equals to reset_width*256                                                             |
| 7          | RW          | 0x0                | hold_sreset_uart1<br>Hold sreset_uart1. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable        |
| 6          | RW          | 0x0                | hold_reset_spi0<br>Hold reset_spi0. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable            |
| 5          | RW          | 0x0                | hold_reset_pwm1<br>Hold reset_pwm0. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable            |
| 4          | RW          | 0x0                | hold_reset_pwm0<br>Hold reset_pwm0. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable            |
| 3          | RW          | 0x0                | hold_reset_pmupvtm<br>Hold reset_pmupvtm. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable      |
| 2          | RW          | 0x0                | hold_reset_i2c2<br>Hold reset_i2c2. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable            |
| 1          | RW          | 0x0                | hold_reset_i2c0<br>Hold reset_i2c0. 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                | hold_reset_ddr_fail_safe<br>Hold reset_ddr_fail_safe. When enabled, the relative logic cannot be reset.<br>1'b0: Disable<br>1'b1: Enable |

**PMUGRF PMU SOC CON3**

Address: Operational Base + offset (0x010C)

| <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         | RW          | 0x0                | pmu_pwr_idlereq<br>PMU pwr_idlereq software enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                    |
| 10         | RW          | 0x0                | clk_gpll_ls_sel<br>GPLL clock path selection.<br>1'b0: Normal<br>1'b1: Through level-shift cell                                                                                                                                                         |
| 9          | RW          | 0x0                | clk_cpll_ls_sel<br>CPLL clock path selection.<br>1'b0: Normal<br>1'b1: Through level-shift cell                                                                                                                                                         |
| 8          | RW          | 0x0                | upctl_c_sysreq_cfg<br>1'b0: After DDR failsafe module enters self-refresh status, then request DDR controller to enter low power state.<br>1'b1: Always enable requesting DDR controller to enter low power state, when DDR failsafe module is working. |
| 7          | RW          | 0x0                | ddr_io_ret_oen_cfg<br>ddr_io_ret_oen_cfg bit control.<br>1'b0: ddr_io_ret output enable<br>1'b1: ddr_io_ret_output disable                                                                                                                              |
| 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>1'b0: DDR IO retention managed by hardware automatically<br>1'b1: Enable IO retention manually                                                                                                                                     |
| 4          | RW          | 0x1                | ddrc_gating_en<br>1'b0: Disable DDR clock gating during system failure<br>1'b1: Enable DDR clock gating during system failure                                                                                                                           |
| 3          | RW          | 0x1                | sref_enter_en<br>1'b0: Disable DDR self-refresh enter when system is failed<br>1'b1: Enable DDR self-refresh enter when system is failed                                                                                                                |
| 2          | RW          | 0x1                | ddrio_ret_en<br>1'b0: Remain DDR IO status when system is failed<br>1'b1: Enable DDR IO retention when system is failed                                                                                                                                 |
| 1          | RW          | 0x0                | wdt_reset_trigger_en<br>Enable failsafe wdt_reset input.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | tsadc_shut_reset_trigger_en<br>Enable failsafe tsadc_shut input.<br>1'b0: Disable<br>1'b1: Enable |

**PMUGRF PMU SOC CON4**

Address: Operational Base + offset (0x0110)

| <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:14      | RO          | 0x0                | reserved                                                                                                                                                                                                  |
| 13:0       | RW          | 0x2805             | pmusram_spracfg<br>SPRF memory EMA configuration for PMU_SRAM.<br>bit [0]: RME<br>bit [3:1]: RM<br>bit [4]: LS<br>bit [5]: BC1<br>bit [6]: BC2<br>bit [7]: TEST1<br>bit [10:8]: WPULSE<br>bit [13:11]: RM |

**PMUGRF IOFUNC CON4**

Address: Operational Base + offset (0x0114)

| <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         | RO          | 0x0                | reserved                                                                                                                          |
| 14         | RW          | 0x0                | pwm7_iomux_sel<br>PWM7 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM7*M0) selected<br>1'b1: IOMUX group 1 (PWM7*M1) selected       |
| 13         | RO          | 0x0                | reserved                                                                                                                          |
| 12         | RW          | 0x0                | pwm6_iomux_sel<br>PWM6 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM6*M0) selected<br>1'b1: IOMUX group 1 (PWM6*M1) selected       |
| 11         | RO          | 0x0                | reserved                                                                                                                          |
| 10         | RW          | 0x0                | pwm5_iomux_sel<br>PWM5 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM5*M0) selected<br>1'b1: IOMUX group 1 (PWM5*M1) selected       |
| 9          | RO          | 0x0                | reserved                                                                                                                          |
| 8          | RW          | 0x0                | pwm4_iomux_sel<br>PWM4 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM4*M0) selected<br>1'b1: IOMUX group 1 (PWM4*M1) selected       |
| 7          | RO          | 0x0                | reserved                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | pwm3_iomux_sel<br>PWM3 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM3*M0) selected<br>1'b1: IOMUX group 1 (PWM3*M1) selected |
| 5          | RO          | 0x0                | reserved                                                                                                                    |
| 4          | RW          | 0x0                | pwm2_iomux_sel<br>PWM2 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM2*M0) selected<br>1'b1: IOMUX group 1 (PWM2*M1) selected |
| 3          | RO          | 0x0                | reserved                                                                                                                    |
| 2          | RW          | 0x0                | pwm1_iomux_sel<br>PWM1 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM1*M0) selected<br>1'b1: IOMUX group 1 (PWM1*M1) selected |
| 1          | RO          | 0x0                | reserved                                                                                                                    |
| 0          | RW          | 0x0                | pwm0_iomux_sel<br>PWM0 IOMUX selection.<br>1'b0: IOMUX group 0 (PWM0*M0) selected<br>1'b1: IOMUX group 1 (PWM0*M1) selected |

**PMUGRF IOFUNC CON5**

Address: Operational Base + offset (0x0118)

| <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                | pwm7_switch_sel<br>PWM7 output selection.<br>1'b0: From PWM module<br>1'b1: From PMU module                                       |
| 14         | RW          | 0x0                | pwm6_switch_sel<br>PWM6 output selection.<br>1'b0: From PWM module<br>1'b1: From PMU module                                       |
| 13         | RW          | 0x0                | pwm5_switch_sel<br>PWM5 output selection.<br>1'b0: From PWM module<br>1'b1: From PMU module                                       |
| 12         | RW          | 0x0                | pwm4_switch_sel<br>PWM4 output selection.<br>1'b0: From PWM module<br>1'b1: From PMU module                                       |
| 11         | RW          | 0x0                | pwm3_switch_sel<br>PWM3 output selection.<br>1'b0: From PWM module<br>1'b1: From PMU module                                       |
| 10         | RW          | 0x0                | pwm2_switch_sel<br>PWM2 output selection.<br>1'b0: From PWM module<br>1'b1: From PMU module                                       |
| 9          | RW          | 0x0                | pwm1_switch_sel<br>PWM1 output selection.<br>1'b0: From PWM module<br>1'b1: From PMU module                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | pwm0_switch_sel<br>PWM0 output selection.<br>1'b0: From PWM module<br>1'b1: From PMU module                                                                                                 |
| 7:5        | RO          | 0x0                | reserved                                                                                                                                                                                    |
| 4          | RW          | 0x0                | i2c2_iomux_sel<br>I2C2 Controller selection.<br>1'b0: Reserved<br>1'b1: Controlled by I2C                                                                                                   |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                    |
| 2          | RW          | 0x0                | uart1_iomux_sel<br>UART1 IOMUX selection.<br>1'b0: IOMUX group 0 (UART1*M0) selected<br>1'b1: IOMUX group 1 (UART1*M0) selected                                                             |
| 1:0        | RW          | 0x0                | spi0_iomux_sel<br>SPI0 IOMUX selection.<br>2'b00: IOMUX group 0 (SPI0*M0) selected<br>2'b01: IOMUX group 1 (SPI0*M1) selected<br>2'b01: IOMUX group 2 (SPI0*M2) selected<br>2'b11: Reserved |

**PMUGRF IO VSEL**

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 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                | pmui01_vsel<br>PMUIO1 voltage selection.<br>1'b0: 3.3V<br>1'b1: 1.8V                                                              |
| 8          | RW          | 0x0                | pmui00_vsel<br>PMUIO0 voltage selection.<br>1'b0: 3.3V<br>1'b1: 1.8V                                                              |
| 7          | RW          | 0x0                | vccio7_vsel<br>VCCIO7 voltage selection.<br>1'b0: 3.3V<br>1'b1: 1.8V                                                              |
| 6          | RW          | 0x0                | vccio6_vsel<br>VCCIO6 voltage selection.<br>1'b0: 3.3V<br>1'b1: 1.8V                                                              |
| 5          | RW          | 0x0                | vccio5_vsel<br>VCCIO5 voltage selection.<br>1'b0: 3.3V<br>1'b1: 1.8V                                                              |
| 4          | RW          | 0x0                | vccio4_vsel<br>VCCIO4 voltage selection.<br>1'b0: 3.3V<br>1'b1: 1.8V                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | vccio3_vsel<br>VCCIO3 voltage selection.<br>1'b0: 3.3V<br>1'b1: 1.8V                                                           |
| 2          | RW          | 0x0                | vccio2_vsel<br>VCCIO2 voltage selection.<br>1'b0: 3.3V<br>1'b1: 1.8V                                                           |
| 1          | RW          | 0x0                | vccio1_vsel<br>VCCIO1 voltage selection.<br>1'b0: 3.3V<br>1'b1: 1.8V                                                           |
| 0          | RW          | 0x0                | flash_vosel<br>VCCIO1 IO domain voltage source selection.<br>1'b0: Controlled by GPIO0B3<br>1'b1: Controlled by GRF_IO_VSEL[1] |

**PMUGRF IO\_VRET**

Address: Operational Base + offset (0x0144)

| <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:8       | RO          | 0x03               | reserved                                                                                                                          |
| 7          | RW          | 0x1                | vccio7_ret<br>VCCIO7 retention control.<br>1'b0: Retention mode<br>1'b1: Normal mode                                              |
| 6          | RW          | 0x1                | vccio6_ret<br>VCCIO6 retention control.<br>1'b0: Retention mode<br>1'b1: Normal mode                                              |
| 5          | RW          | 0x1                | vccio5_ret<br>VCCIO5 retention control.<br>1'b0: Retention mode<br>1'b1: Normal mode                                              |
| 4          | RW          | 0x1                | vccio4_ret<br>VCCIO4 retention control.<br>1'b0: Retention mode<br>1'b1: Normal mode                                              |
| 3          | RW          | 0x1                | vccio3_ret<br>VCCIO3 retention control.<br>1'b0: Retention mode<br>1'b1: Normal mode                                              |
| 2          | RW          | 0x1                | vccio2_ret<br>VCCIO2 retention control.<br>1'b0: Retention mode<br>1'b1: Normal mode                                              |
| 1          | RW          | 0x1                | vccio1_ret<br>VCCIO1 retention control.<br>1'b0: Retention mode<br>1'b1: Normal mode                                              |
| 0          | RO          | 0x0                | reserved                                                                                                                          |

**PMUGRF PMUPVTM CLKDIV**

Address: Operational Base + offset (0x0180)

| <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:8       | RO          | 0x00               | reserved                                                                                                                          |
| 7:2        | RW          | 0x00               | pmupvtm_clkout_div<br>Divider for PVTM output clock to generate 32KHz clock.<br>Frequency is divided by (pmupvtm_clkout_div*4+1). |
| 1:0        | RO          | 0x0                | reserved                                                                                                                          |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF 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 |

**PMUGRF\_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<br>When high, ddr_fail_safe is active.        |
| 2          | RO          | 0x0                | tsadc_shut_reset_src<br>When high, reset by TSADC shut trigger. |
| 1          | RO          | 0x0                | wdt_reset_src<br>When high, reset by WDT trigger.               |
| 0          | RO          | 0x0                | first_reset_src<br>When high, reset by first reset trigger.     |

**PMUGRF\_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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------|
| 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           |
| 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 |

**PMUGRF SD DETECT CON**

Address: Operational Base + offset (0x0380)

| <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                | 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                                   |

**PMUGRF SD DETECT STATUS**

Address: Operational Base + offset (0x0390)

| <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  |

**PMUGRF SD DETECT CLR**

Address: Operational Base + offset (0x03A0)

| <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          | WO          | 0x0                | sig_detect_fall_clr<br>SDMMC detect pin falling edge irq clear.<br>1'b0: Disable<br>1'b1: Enable                                  |
| 0          | WO          | 0x0                | sig_detect_rise_clr<br>SDMMC detect pin rising edge irq clear.<br>1'b0: Disable<br>1'b1: Enable                                   |

**PMUGRF SD DETECT COUNT**

Address: Operational Base + offset (0x03B0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                 |
| 19:0       | RW          | 0x003e8            | sdmmc_det_count<br>SDMMC detect pin filter counter, in the unit of pclk. |

## Chapter 7 Timer

### 7.1 Overview

Timer is a programmable timer peripheral. This component is an APB slave device. In RV1109/RV1126 there are 6 timers (Timer0~5) and 2 Secure timers (STimer0~2). CNTP\_TVAL is provided by STimer1.

Timer5 and STimer0~1 count up from zero to a programmed value and generate an interrupt when the counter reaches the programmed value.

Timer0~4 count down from a programmed value to zero and generate an interrupt when the counter reaches zero.

Timer supports the following features:

- Timer0~5 is used for no-secure, STimer0~1 is used for secure.
- Two operation modes: free-running and user-defined count.
- Interrupt can be enabled or disabled individual for each timer.

### 7.2 Block Diagram



Fig. 7-1 Timer Block Diagram

The above figure shows the architecture of the APB timers (include six programmable timer channels). The Stimers that in the bus subsystem only include two programmable timer channels.

### 7.3 Function Description

#### 7.3.1 Timer clock

TIMER0~TIMER5 and STIMER0~1 are in the pd\_bus subsystem. The clock source is 24MHz.

#### 7.3.2 Programming sequence

1. Initialize the timer by the TIMERn\_CONTROLREG ( $0 \leq n \leq 5$ ) register:
  - Disable the timer by writing a "0" to the timer enable bit (bit 0). Accordingly, the timer\_en output signal is de-asserted.
  - Program the timer mode—free-running or user-defined—by writing a "0" or "1" respectively, to the timer mode bit (bit 1).
  - Set the interrupt mask as either masked or not masked by writing a "0" or "1" respectively, to the timer interrupt mask bit (bit 2).
2. Load the timer count value into the TIMERn\_LOAD\_COUNT1 ( $0 \leq n \leq 5$ ) and TIMERn\_LOAD\_COUNT0 ( $0 \leq n \leq 5$ ) register.
3. Enable the timer by writing a "1" to bit 0 of TIMERn\_CONTROLREG ( $0 \leq n \leq 5$ ).



Fig. 7-2 Timer Usage Flow

### 7.3.3 Loading a timer count value

For the descending Timers(Timer0~4).The initial value for each timer—that is, the value from which it counts down—is loaded into the timer using the load count register (TIMERn\_LOAD\_COUNT1 and 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 Timers(Timer5 and STimer0~1).The initial value for each timer is zero. The count register will count up to the value loaded in the register TIMERn\_LOAD\_COUNT1 and TIMERn\_LOAD\_COUNT0. Two events can cause a timer to load zero:

- Timer is enabled after reset or disabled.
- Timer counts up to the value stored in TIMERn\_LOAD\_COUNT1 and TIMERn\_LOAD\_COUNT0, when timer is configured into free-running mode.

### 7.3.4 Timer mode selection

- User-defined count mode – Timer loads TIMERn\_LOAD\_COUNT1 and TIMERn\_LOAD\_COUNT0 registers (for descending timers) or zero (for incremental timers) as initial value. When the timer counts down to 0 (for descending timers) or counts up to the value in TIMERn\_LOAD\_COUNT1 and TIMERn\_LOAD\_COUNT0 (for incremental timers), 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 TIMERn\_LOAD\_COUNT1 and TIMERn\_LOAD\_COUNT0(for descending timers) or zero (for incremental timers) register as initial value. Timer will automatically reload the COUNT register, when timer counts down to 0 (for descending timers) or counts up to the value in TIMERn\_LOAD\_COUNT1 and TIMERn\_LOAD\_COUNT0 (for incremental timers).

## 7.4 Register Description

### 7.4.1 Registers Summary

| Name                     | Offset | Size | Reset Value | Description                                  |
|--------------------------|--------|------|-------------|----------------------------------------------|
| TIMER_TIMERn_LOAD_COUNT0 | 0x0000 | W    | 0x00000000  | Low 32 bits value to be loaded into Timer0   |
| TIMER_TIMERn_LOAD_COUNT1 | 0x0004 | W    | 0x00000000  | High 32 bits value to be loaded into Timer0. |
| TIMER_TIMERn_CURR_VALUE0 | 0x0008 | W    | 0x00000000  | Low 32 bits of current value of Timer0.      |
| TIMER_TIMERn_CURR_VALUE1 | 0x000c | W    | 0x00000000  | High 32 bits of current value of Timer0.     |
| TIMER_TIMERn_CONTROL     | 0x0010 | W    | 0x00000000  | Timer Control Register                       |
| TIMER_TIMERn_INTSTATUS   | 0x0018 | W    | 0x00000000  | Timer Interrupt Stauts Register              |
| TIMER_REVISION_6CH       | 0x00f0 | W    | 0x11970006  | timer version for 6 channel timer            |

| Name               | Offset | Size | Reset Value | Description                        |
|--------------------|--------|------|-------------|------------------------------------|
| TIMER REVISION 2CH | 0x00f0 | W    | 0x11970002  | timer version for 2 channel stimer |

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

## 7.4.2 Detail Register Description

### **TIMERn LOAD COUNT0**

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 31:0 | RW   | 0x00000000  | count0<br>Load count low bits |

### **TIMERn LOAD COUNT1**

Address: Operational Base + offset (0x0004)

| Bit  | Attr | Reset Value | Description                    |
|------|------|-------------|--------------------------------|
| 31:0 | RW   | 0x00000000  | count1<br>Load count high bits |

### **TIMERn Curr Value0**

Address: Operational Base + offset (0x0008)

| Bit  | Attr | Reset Value | Description                            |
|------|------|-------------|----------------------------------------|
| 31:0 | RO   | 0x00000000  | current_value0<br>current_cnt_low bits |

### **TIMERn Curr Value1**

Address: Operational Base + offset (0x000c)

| Bit  | Attr | Reset Value | Description                             |
|------|------|-------------|-----------------------------------------|
| 31:0 | RO   | 0x00000000  | current_value1<br>current_cnt_high bits |

### **TIMERn CONTROL**

Address: Operational Base + offset (0x0010)

| Bit  | Attr | Reset Value | Description                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------|
| 31:3 | RO   | 0x00000000  | reserved                                                                       |
| 2    | RW   | 0x0         | 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 mode |
| 0    | RW   | 0x0         | timer_en<br>Timer enable<br>1i@b0: Disable<br>1'b1: Enable                     |

### **TIMERn INTSTATUS**

Address: Operational Base + offset (0x0018)

| Bit  | Attr | Reset Value | Description                                                                                                            |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------|
| 31:1 | RO   | 0x00000000  | reserved                                                                                                               |
| 0    | WO   | 0x0         | int_pd<br>This register contains the interrupt status for Timer.<br>Write 1 to this register will clear the interrupt. |

**TIMER REVISION 6CH**

Address: Operational Base + offset (0x00f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:16      | RO          | 0x1197             | svn_revision<br>svn revision<br>16'd4503            |
| 15:0       | RO          | 0x0006             | ip_function<br>Channel number<br>16'd6: Six channel |

**TIMER REVISION 2CH**

Address: Operational Base + offset (0x00f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                  |
|------------|-------------|--------------------|-----------------------------------------------------|
| 31:16      | RO          | 0x1197             | svn_revision<br>SVN revision<br>16'd4503            |
| 15:0       | RO          | 0x0002             | ip_function<br>Channel number<br>16'd2: Two channel |

**7.5 Application Notes****7.5.1 Register Base Address**

Table 7-1 Register Base Address

| <b>Module</b> | <b>CNT</b>      | <b>Base Addr</b> |
|---------------|-----------------|------------------|
| Timer         | TIMER0_BASE     | 0xFF660000       |
|               | TIMER1_BASE     | 0xFF660020       |
|               | TIMER2_BASE     | 0xFF660040       |
|               | TIMER3_BASE     | 0xFF660060       |
|               | TIMER4_BASE     | 0xFF660080       |
|               | TIMER5_BASE     | 0xFF6600A0       |
|               | TIMER_REVISION  | 0xff6600F0       |
| Stimer        | STIMER0_BASE    | 0xFF670000       |
|               | STIMER1_BASE    | 0xFF670020       |
|               | STIMER_REVISION | 0xFF6700F0       |

**7.5.2 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. 7-3 Timing between timer\_en and timer\_clk

Please refer to function description section for the timer usage flow.

## Chapter 8 Watchdog Timer(WDT)

### 8.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 is pclk
- 32 bits WDT counter width
- Counter counts down from a preset value to 0 to indicate the occurrence of a timeout
- WDT can perform two types of operations when timeout occurs:
  - Generate a system reset
  - First generate an interrupt and if this is not cleared by the service routine by the time a second timeout occurs then generate a system reset
- Programmable reset pulse length
- Total 16 defined-ranges of main timeout period
- There are one watchdog in LOGIC named WDT0, and one watchdog in DSP named WDT1
- Both WDT0 and WDT1 can drive CRU to generate global software reset

### 8.2 Block Diagram



Fig. 8-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.

### 8.3 Function Description

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

### 8.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. 8-2 WDT Operation Flow (RMOD=1)

## 8.4 Register Description

This section describes the control/status registers of the design. Software should read and write these registers using 32-bits accesses. There are two WDTs (WDT0 ~ WDT1), and each of them has same register group. Therefore, two WDTs' register groups have two different base addresses.

### 8.4.1 Registers Summary

| Name     | Offset | Size | Reset Value | Description                    |
|----------|--------|------|-------------|--------------------------------|
| WDT_CR   | 0x0000 | W    | 0x0000000a  | Control Register               |
| WDT_TORR | 0x0004 | W    | 0x00000000  | Timeout Range Register         |
| WDT_CCVR | 0x0008 | W    | 0x00000000  | Current Counter Value Register |
| WDT_CRR  | 0x000c | W    | 0x00000000  | Counter Restart Register       |
| WDT_STAT | 0x0010 | W    | 0x00000000  | Interrupt Status Register      |
| WDT_EOI  | 0x0014 | W    | 0x00000000  | Interrupt Clear Register       |

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

### 8.4.2 Detail Register 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   | 0x1         | <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>wdt_en<br/>           Writable when the configuration parameter WDT_ALWAYS_EN=0, otherwise,it is readable. This bit is used to enable and disable the DW_apb_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    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:</p> <p>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<br/>4'b1100: 0x0fffffff<br/>4'b1101: 0x1fffffff<br/>4'b1110: 0x3fffffff<br/>4'b1111: 0x7fffffff</p> |

**WDT\_CCVR**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>cur_cnt<br/>This register, when read, is the current value of the internal counter. This value is read coherently whenever it is read</p> |

**WDT\_CRR**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                  |
| 7:0        | WO          | 0x00               | <p>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.</p> |

**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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | <p>wdt_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.</p> |

**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                | <p>wdt_int_clr<br/>This can be used to clear the interrupt without restarting the watchdog counter.</p> |

**8.5 Application Notes**

- Configure CRU\_GLB\_RST\_CON to enable WDT triggered global software reset. Please refer to Chapter 3 for more information.

## Chapter 9 Power Management Unit (PMU)

### 9.1 Overview

In order to meet low power requirements, a power management unit (PMU) is designed for controlling power resources in RV1109/RV1126. The RV1109/RV1126 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 multi power domains in VD\_CORE: PD\_CPU\_0, PD\_CPU\_1, PD\_CPU\_2, PD\_CPU\_3
- Support multi power domains in VD\_LOGIC: PD\_VDPU, PD\_VI, PD\_VO, PD\_ISPP, PD\_NVM, PD\_SDIO, PD\_USB, PD\_DDR, PD\_USB, PD\_CRYPT
- Support PD\_NPU and PD\_VEPU act as power domain or voltage domain
- Support BIU idle operations: BIU\_DDR, BIU\_BUSHOLD, BIU\_BUSNOC1, BIU\_BUSNOC2, BIU\_BUSNOC3, BIU\_AUDIO, BIU\_VI, BIU\_VO, BIU\_ISPP, BIU\_VEPU, BIU\_VDPU, BIU\_NVM, BIU\_SDCARD, BIU\_SDIO, BIU\_GMAC, BIU\_USB, BIU\_PHP, BIU\_PMU, BIU\_NPU, BIU\_TOPAPB, BIU\_CRYPT
- Support CPU auto power down and SCU auto power down
- Support power down/up all power domains by software or hardware
- Support power down/up all voltage domains by software or hardware
- Support to send idle request to BIU
- Support global interrupt disable in low power mode
- Support low frequency clock source from PVTM
- 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 DDR controller clock auto gating in low power mode
- Support varies configurable wakeup source for low power mode

### 9.2 Block Diagram

The following figure is the PMU block diagram. The PMU includes the 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. 9-1 PMU Bock Diagram

## 9.3 Function Description

### 9.3.1 Domain Partition



Fig. 9-2 RV1109/RV1126 Voltage Domain and Power Domain Partition

The above diagram describes the power domain and voltage domain partition, and the following table lists IPs in every power domain.

Table 9-1 RV1109/RV1126 Voltage Domain and Power Domain Summary

| Voltage Domain | Power Domain | Description                                                                                                                  |
|----------------|--------------|------------------------------------------------------------------------------------------------------------------------------|
| VD_CORE        | PD_CPU_0     | CPU CORE 0                                                                                                                   |
|                | PD_CPU_1     | CPU CORE 1                                                                                                                   |
|                | PD_CPU_2     | CPU CORE 2                                                                                                                   |
|                | PD_CPU_3     | CPU CORE 3                                                                                                                   |
|                | ALIVE        | BIU_CPU<br>SCU,L2,GIC400<br>DAP<br>PVTM                                                                                      |
| VP_PMU         | PD_PMU       | BIU_PMU<br>GPLL<br>PMU_SRAM<br>SGRF<br>PMU<br>PMUCRU<br>PMUGRF<br>I2C0, I2C2<br>GPIO0<br>PVTM<br>UART1<br>PWM0, PWM1<br>SPI0 |
| VD_NPU         | PD_NPU       | BIU_NPU<br>VIPNN<br>PVTM                                                                                                     |

| <b>Voltage Domain</b> | <b>Power Domain</b> | <b>Description</b>                                                                                                           |
|-----------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------|
| VD_VEPU               | PD_VEPU             | BIU_VEPU<br>RKVENC                                                                                                           |
| VD_LOGIC              | PD_VI               | BIU_VI<br>ISP<br>CIF<br>CIFLITE<br>CSIHOST                                                                                   |
|                       | PD_VO               | BIU_VO<br>VOP<br>RGA<br>IEP<br>DSIHOST                                                                                       |
|                       | PD_ISPP             | BIU_ISPP<br>ISPP                                                                                                             |
|                       | PD_VDPU             | BIU_VDPU<br>VDEC<br>JPEG                                                                                                     |
|                       | PD_CRYPT            | BIU_CRYPT<br>CRYPTO                                                                                                          |
|                       | PD_DDR              | BIU_DDR<br>DDR_UMCTL2<br>DDR_DFICTL<br>DDR_MONITOR<br>DDR_STANDBY<br>DDR_SCRAMBLE<br>DDR_HOLD<br>AXI_SPLIT<br>DDR_GRF<br>DDR |
|                       | PD_NVM              | BIU_NVM<br>EMMC<br>NANDC<br>FSPI                                                                                             |
|                       | PD_SDIO             | BIU_SDIO<br>SDIO                                                                                                             |
|                       | PD_USB              | BIU_USB<br>USBHOST<br>USBOTG                                                                                                 |
|                       | ALIVE               | BIU_SDCARD<br>SDCARD<br>BIU_AUDIO<br>I2S0~2<br>PDM<br>audioPWM<br>ACDC_DIG<br>BIU_GMAC<br>GMAC                               |

| Voltage Domain | Power Domain | Description                                                                                                                                                                                                                                      |
|----------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |              | BIU_BUS<br>MCU<br>DCF<br>SPINLOCK<br>DECOM<br>DMAC<br>SYSTEM_SRAM<br>BootRom<br>MAILBOX<br>GRF, SGRF<br>OTPC<br>I2C1/3/4/5<br>TIMER_6CH, STIMER_2CH<br>WDT, WDT_S<br>GPIO1/2/3/4<br>SPI1<br>UART0/2/3/4/5<br>PWM2<br>CAN<br>CPU_TSADC, NPU_TSADC |
|                |              | DDRPHY                                                                                                                                                                                                                                           |
|                |              | CSIPHY0, CSIPHY1                                                                                                                                                                                                                                 |
|                |              | DSIPHY                                                                                                                                                                                                                                           |
|                |              | HOSTPHY, OTGPHY                                                                                                                                                                                                                                  |
|                |              | CPUPVT, NPUPVT                                                                                                                                                                                                                                   |
|                |              | SARADC PHY                                                                                                                                                                                                                                       |
|                |              | OPTPHY                                                                                                                                                                                                                                           |
|                |              | APLL, CPLL, DPLL, HPLL                                                                                                                                                                                                                           |
|                |              | BIU_TOP                                                                                                                                                                                                                                          |
|                |              | CRU                                                                                                                                                                                                                                              |

### 9.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, CPU can write PMU\_PWR\_GATE\_CON register to determine that power off/on which power domain independently.

When operating at low power mode, software manages power sources indirectly through FSM (Finite States Machine) in PMU and those settings always not take effect immediately. That means software also can configure PMU registers to power down/up some power resources, but these setting will not be executed immediately after configuration. They will 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. After PMU detects all CPUs 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 RV1109/RV1126 chip.

## 9.4 Register Description

### 9.4.1 Registers Summary

| Name               | Offset | Size | Reset Value | Description                |
|--------------------|--------|------|-------------|----------------------------|
| PMU_VERSION        | 0x0000 | W    | 0x030A0000  | PMU version register       |
| PMU_PWR_CON        | 0x0004 | W    | 0x0000000C  | PMU power control register |
| PMU_MAIN_PWR_STATE | 0x0008 | W    | 0x00000000  | PMU power status register  |

| Name                    | Offset | Size | Reset Value | Description                                  |
|-------------------------|--------|------|-------------|----------------------------------------------|
| 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 WAKEUP EDGE CON     | 0x0018 | W    | 0x00000000  | Edge wakeup source control register          |
| PMU WAKEUP EDGE ST      | 0x001C | W    | 0x00000000  | Edge wakeup source status register           |
| PMU SCU STABLE CNT      | 0x0020 | W    | 0x000FFFFF  | SCU power stable counter register            |
| PMU PMIC STABLE CNT     | 0x0024 | W    | 0x000FFFFF  | PMIC stable counter register                 |
| 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 SCU PWRUP CNT       | 0x0038 | W    | 0x00005DC0  | SCU power up stable counter register         |
| PMU SCU PWRDN CNT       | 0x003C | W    | 0x00005DC0  | SCU power down stable counter register       |
| PMU SCU VOLUP CNT       | 0x0040 | W    | 0x00005DC0  | SCU voltage up stable counter register       |
| PMU SCU VOLDN CNT       | 0x0044 | W    | 0x00005DC0  | SCU voltage down stable 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  | SCU power hardware control register          |
| PMU SCU PWR SFTCON      | 0x0084 | W    | 0x00000000  | SCU power software control register          |
| PMU SCU PWR STATE       | 0x008C | W    | 0x00000000  | SCU power status register                    |
| PMU CPU PWR SFTCON      | 0x0094 | W    | 0x00000000  | SCU software power control register          |
| PMU CLUSTER PWR ST      | 0x009C | W    | 0x00000000  | Cluster power status register                |
| PMU CLUSTER IDLE CON    | 0x00A0 | W    | 0x00000000  | Cluster idle hardware control register       |
| PMU CLUSTER IDLE SFTCON | 0x00A4 | W    | 0x00000000  | Cluster idle software control register       |
| PMU BUS IDLE CON0       | 0x00B0 | W    | 0x00000000  | Bus idle request hardware control register 0 |
| PMU BUS IDLE CON1       | 0x00B4 | W    | 0x00000000  | Bus idle request hardware control register 1 |
| PMU BUS IDLE SFTCON0    | 0x00C0 | W    | 0x00000000  | Bus idle request software control register 0 |
| PMU BUS IDLE SFTCON1    | 0x00C4 | W    | 0x00000000  | Bus idle request software control register 1 |
| PMU BUS IDLE ACK        | 0x00D0 | W    | 0x00000000  | Bus idle acknowledge status register         |
| PMU BUS IDLE ST         | 0x00D8 | W    | 0x00000000  | Bus idle status register                     |

| Name                | Offset | Size | Reset Value | Description                               |
|---------------------|--------|------|-------------|-------------------------------------------|
| PMU_NOC_AUTO_CON0   | 0x00E0 | W    | 0x00000000  | NOC automatic power control register 0    |
| PMU_NOC_AUTO_CON1   | 0x00E4 | W    | 0x00000000  | NOC automatic power control register 1    |
| 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_PWR_STATE   | 0x00F8 | W    | 0x00000000  | DDR power state machine register          |
| PMU_DDR_PWR_ST      | 0x00FC | W    | 0x00000000  | DDR power status register                 |
| PMU_PWR_GATE_CON    | 0x0100 | W    | 0x00000000  | Power domain hardware control register    |
| PMU_PWR_GATE_STATE  | 0x0104 | W    | 0x00000000  | Power domain state machine register       |
| PMU_PWR_DWN_ST      | 0x0108 | W    | 0x00000000  | Power domain status register              |
| PMU_PWR_GATE_SFTCON | 0x0110 | W    | 0x00000000  | Power domain software control register    |
| PMU_VOL_GATE_SFTCON | 0x0118 | W    | 0x00000000  | Voltage domain software control register  |
| PMU_CRU_PWR_CON     | 0x0120 | W    | 0x00000000  | CRU power hardware control register       |
| PMU_CRU_PWR_SFTCON  | 0x0124 | W    | 0x00000000  | CRU power software control register       |
| PMU_CRU_PWR_STATE   | 0x0128 | W    | 0x00000000  | CRU power state machine 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

## 9.4.2 Detail Register Description

### PMU VERSION

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                   |
|------|------|-------------|-------------------------------|
| 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         | RW          | 0x0                | pmu_sleep_pol<br>pmu_sleep polarity selection.<br>1'b0: High active<br>1'b1: Low active                                                           |
| 14:8       | RO          | 0x00               | reserved                                                                                                                                          |
| 7          | RW          | 0x0                | cru_bypass<br>Bypass CRU in low power procedure.<br>1'b0: Disable<br>1'b1: Enable                                                                 |
| 6          | RW          | 0x0                | pwrdn_bypass<br>Bypass power domain in low power procedure.<br>1'b0: Disable<br>1'b1: Enable                                                      |
| 5          | RW          | 0x0                | ddr_bypass<br>Bypass DDR in low power procedure.<br>1'b0: Disable<br>1'b1: Enable                                                                 |
| 4          | RW          | 0x0                | bus_bypass<br>Bypass bus idle in low power procedure.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 3:2        | RO          | 0x3                | reserved                                                                                                                                          |
| 1          | RW          | 0x0                | scu_bypass<br>Bypass SCU in low power procedure.<br>1'b0: Disable<br>1'b1: Enable                                                                 |
| 0          | R/W<br>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 MAIN PWR STATE**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3:0        | RO          | 0x0                | pmu_power_state<br>PMU main power state.<br>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 |

**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             | 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:1       | RO          | 0x0000             | reserved                                                                                                                           |
| 0          | RW          | 0x0                | glb_int_disable<br>Global interrupt disable.<br>1'b0: Disable<br>1'b1: Enable                                                      |

**PMU WAKEUP INT CON**

Address: Operational Base + offset (0x0010)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:11      | RO          | 0x000000           | reserved                                                                                               |
| 10         | RW          | 0x0                | wakeup_timerout_en<br>Enable PMU timeout interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable  |
| 9          | RW          | 0x0                | wakeup_sys_int_en<br>Enable system interrupt source as wakeup source.<br>1'b0: Disable<br>1'b1: Enable |
| 8          | RW          | 0x0                | wakeup_uart1_en<br>Enable UART1 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable           |
| 7          | RW          | 0x0                | wakeup_usb_en<br>Enable USB detect interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable        |
| 6          | RW          | 0x0                | wakeup_sdio_en<br>Enable SDIO interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable             |
| 5          | RW          | 0x0                | wakeup_sdmmc_en<br>Enable SDMMC detect interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable    |
| 4          | RW          | 0x0                | wakeup_gpio0_int_en<br>Enable GPIO0 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable       |
| 3          | RW          | 0x0                | wakeup_cpu3_int_en<br>Enable CPU3 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable         |
| 2          | RW          | 0x0                | wakeup_cpu2_int_en<br>Enable CPU2 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | wakeup_cpu1_int_en<br>Enable CPU1 interrupt as wakeup source.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | wakeup_cpu0_int_en<br>Enable CPU0 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:11      | RO          | 0x000000           | reserved                                                                                                   |
| 10         | RO          | 0x0                | wakeup_timerout_int_st<br>PMU timeout interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active |
| 9          | RO          | 0x0                | wakeup_sys_int_st<br>System interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active           |
| 8          | RO          | 0x0                | wakeup_uart1_int_st<br>UART1 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active          |
| 7          | RO          | 0x0                | wakeup_usb_int_st<br>USB detect interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active       |
| 6          | RO          | 0x0                | wakeup_sdio_int_st<br>SDIO interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active            |
| 5          | RO          | 0x0                | wakeup_sdmmc_int_st<br>SDMMC detect interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active   |
| 4          | RO          | 0x0                | wakeup_gpio0_int_st<br>GPIO0 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active          |
| 3          | RO          | 0x0                | wakeup_cpu3_int_st<br>CPU3 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active            |
| 2          | RO          | 0x0                | wakeup_cpu2_int_st<br>CPU2 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active            |
| 1          | RO          | 0x0                | wakeup_cpu1_int_st<br>CPU1 interrupt wakeup status.<br>1'b0: Inactive<br>1'b1: Active                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | wakeup_cpu0_int_st<br>CPU0 interrupt as wakeup source status.<br>1'b0: Inactive<br>1'b1: Active |

**PMU WAKEUP EDGE CON**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                 |
| 19:0       | RW          | 0x00000            | edge_wakeup_en<br>Enable both posedge and negedge of GPIO0 pins as wakeup source. Each pin has independent control bit.<br>1'b0: Disable<br>1'b1: Enable |

**PMU WAKEUP EDGE ST**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                             |
| 19:0       | W1C         | 0x00000            | edge_status<br>Edge interrupt wakeup status. Each pin has independent control bit.<br>1'b0: Inactive<br>1'b1: Active |

**PMU SCU STABLE CNT**

Address: Operational Base + offset (0x0020)

| <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>SCU power stable counter for SCU from power off to wakeup |

**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 SCU PWRUP CNT**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                  |
| 19:0       | RW          | 0x05dc0            | stable_cnt<br>SCU power up stable counter, reflect on the falling time of pd_scu_dwn_ack. |

**PMU SCU PWRDN CNT**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                   |
| 19:0       | RW          | 0x05dc0            | stable_cnt<br>SCU power down stable counter, reflect on the rising time of pd_scu_dwn_ack. |

**PMU SCU VOLUP CNT**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                   |
| 19:0       | RW          | 0x05dc0            | stable_cnt<br>SCU voltage up stable counter, reflect on the falling time of pd_scu_dwn_en. |

**PMU SCU VOLDN CNT**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                  |
| 19:0       | RW          | 0x05dc0            | stable_cnt<br>SCU voltage up stable counter, reflect on the rising time of pd_scu_dwn_en. |

**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          | 0x00005dc0         | 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:0       | RW          | 0x000fffff         | 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:16      | RO          | 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                | cluster_clk_src_gate_ena<br>Cluster clock gate enable.<br>1'b0: Disable<br>1'b1: Enable                                            |
| 6          | RW          | 0x0                | scu_vol_gate_ena<br>SCU voltage gate enable.<br>1'b0: Disable<br>1'b1: Enable                                                      |
| 5          | RW          | 0x0                | cluster_cpu_pwrdown_ena<br>CPU hardware power down enable.<br>1'b0: Disable<br>1'b1: Enable                                        |
| 4          | RO          | 0x0                | reserved                                                                                                                           |
| 3          | RW          | 0x0                | scu_pwroff_ena<br>SCU hardware power off enable.<br>1'b0: Disable<br>1'b1: Enable                                                  |
| 2          | RW          | 0x0                | scu_pwrdown_ena<br>SCU hardware power down enable.<br>1'b0: Disable<br>1'b1: Enable                                                |
| 1:0        | RO          | 0x0                | reserved                                                                                                                           |

**PMU SCU PWR SFTCON**

Address: Operational Base + offset (0x0084)

| <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                | scu_pwroff_ena<br>SCU software power off enable.<br>1'b0: Disable<br>1'b1: Enable                                                  |
| 2          | RW          | 0x0                | scu_pwrdown_ena<br>SCU software power down enable.<br>1'b0: Disable<br>1'b1: Enable                                                |
| 1:0        | RO          | 0x0                | reserved                                                                                                                           |

**PMU SCU PWR STATE**

Address: Operational Base + offset (0x008C)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RO          | 0x0                | scu_power_state<br>SCU power state.<br>4'h0: SCU normal state<br>4'h1: CPU power down state<br>4'h4: Cluster transfer idle state<br>4'h5: SCU power down state<br>4'h6: SCU sleep state<br>4'h7: SCU wakeup state<br>4'h8: SCU power up state<br>4'h9: Cluster transfer resume state<br>4'ha: CPU power up state<br>Others: Reserved |

**PMU CPU PWR SFTCON**

Address: Operational Base + offset (0x0094)

| <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                | cpu3_sft_pwrdown_ena<br>CPU3 software power down enable.<br>1'b0: Disable<br>1'b1: Enable                                          |
| 2          | RW          | 0x0                | cpu2_sft_pwrdown_ena<br>CPU2 software power down enable.<br>1'b0: Disable<br>1'b1: Enable                                          |
| 1          | RW          | 0x0                | cpu1_sft_pwrdown_ena<br>CPU1 software power down enable.<br>1'b0: Disable<br>1'b1: Enable                                          |
| 0          | RW          | 0x0                | cpu0_sft_pwrdown_ena<br>CPU0 software power down enable.<br>1'b0: Disable<br>1'b1: Enable                                          |

**PMU CLUSTER PWR ST**

Address: Operational Base + offset (0x009C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                     |
| 11         | RO          | 0x0                | cpu3_standbywfi<br>CPU3 STANDBYWIFI state.<br>1'b0: Inactive<br>1'b1: Active |
| 10         | RO          | 0x0                | cpu2_standbywfi<br>CPU2 STANDBYWIFI state.<br>1'b0: Inactive<br>1'b1: Active |
| 9          | RO          | 0x0                | cpu1_standbywfi<br>CPU1 STANDBYWIFI state.<br>1'b0: Inactive<br>1'b1: Active |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 8          | RO          | 0x0                | cpu0_standbywfi<br>CPU0 STANDBYWFI state.<br>1'b0: Inactive<br>1'b1: Active |
| 7          | RO          | 0x0                | cpu3_dwn_state<br>CPU3 power down state.<br>1'b0: Inactive<br>1'b1: Active  |
| 6          | RO          | 0x0                | cpu2_dwn_state<br>CPU2 power down state.<br>1'b0: Inactive<br>1'b1: Active  |
| 5          | RO          | 0x0                | cpu1_dwn_state<br>CPU1 power down state.<br>1'b0: Inactive<br>1'b1: Active  |
| 4          | RO          | 0x0                | cpu0_dwn_state<br>CPU0 power down state.<br>1'b0: Inactive<br>1'b1: Active  |
| 3          | RO          | 0x0                | reserved                                                                    |
| 2          | RO          | 0x0                | scu_dwn_state<br>SCU power down state.<br>1'b0: Inactive<br>1'b1: Active    |
| 1          | RO          | 0x0                | standbywfil2<br>L2 STANDBYWFI state.<br>1'b0: Inactive<br>1'b1: Active      |
| 0          | RO          | 0x0                | reserved                                                                    |

**PMU CLUSTER IDLE CON**

Address: Operational Base + offset (0x00A0)

| <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:5       | RO          | 0x000              | reserved                                                                                                                           |
| 4          | RW          | 0x0                | idle_req_cpu<br>Enable sending bus idle request to BIU_CPU by PMU.<br>1'b0: Disable<br>1'b1: Enable                                |
| 3:0        | RO          | 0x0                | reserved                                                                                                                           |

**PMU CLUSTER IDLE SFTCON**

Address: Operational Base + offset (0x00A4)

| <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:5       | RO          | 0x000              | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | idle_req_cpu<br>Enable sending bus idle request to BIU_CPU by software.<br>1'b0: Disable<br>1'b1: Enable |
| 3:0        | RO          | 0x0                | reserved                                                                                                 |

**PMU BUS IDLE CON0**

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         | RW          | 0x0                | idle_req_usb<br>Enable sending bus idle request to BIU_USB by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |
| 14         | RW          | 0x0                | idle_req_gmac<br>Enable sending bus idle request to BIU_GMAC by hardware.<br>1'b0: Disable<br>1'b1: Enable                         |
| 13         | RW          | 0x0                | idle_req_sdio<br>Enable sending bus idle request to BIU_SDIO by hardware.<br>1'b0: Disable<br>1'b1: Enable                         |
| 12         | RW          | 0x0                | idle_req_sdcard<br>Enable sending bus idle request to BIU_SDCARD by hardware.<br>1'b0: Disable<br>1'b1: Enable                     |
| 11         | RW          | 0x0                | idle_req_nvm<br>Enable sending bus idle request to BIU_NVM by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |
| 10         | RW          | 0x0                | idle_req_vdpu<br>Enable sending bus idle request to BIU_VDPU by hardware.<br>1'b0: Disable<br>1'b1: Enable                         |
| 9          | RW          | 0x0                | idle_req_vepu<br>Enable sending bus idle request to BIU_VEPU by hardware.<br>1'b0: Disable<br>1'b1: Enable                         |
| 8          | RW          | 0x0                | idle_req_ispp<br>Enable sending bus idle request to BIU_ISPP by hardware.<br>1'b0: Disable<br>1'b1: Enable                         |
| 7          | RW          | 0x0                | idle_req_vo<br>Enable sending bus idle request to BIU_VO by hardware.<br>1'b0: Disable<br>1'b1: Enable                             |
| 6          | RW          | 0x0                | idle_req_vi<br>Enable sending bus idle request to BIU_VI by hardware.<br>1'b0: Disable<br>1'b1: Enable                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | idle_req_audio<br>Enable sending bus idle request to BIU_AUDIO by hardware.<br>1'b0: Disable<br>1'b1: Enable     |
| 4          | RW          | 0x0                | idle_req_busnoc3<br>Enable sending bus idle request to BIU_BUSNOC3 by hardware.<br>1'b0: Disable<br>1'b1: Enable |
| 3          | RW          | 0x0                | idle_req_busnoc2<br>Enable sending bus idle request to BIU_BUSNOC2 by hardware.<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x0                | idle_req_busnoc1<br>Enable sending idle request to BIU_BUSNOC1 by hardware.<br>1'b0: Disable<br>1'b1: Enable     |
| 1          | RW          | 0x0                | idle_req_bushold<br>Enable sending bus idle request to BIU_BUSHOLD by hardware.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | idle_req_ddr<br>Enable sending bus idle request to BIU_DDR by hardware.<br>1'b0: Disable<br>1'b1: Enable         |

**PMU BUS IDLE CON1**

Address: Operational Base + offset (0x00B4)

| <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:5       | RO          | 0x000              | reserved                                                                                                                           |
| 4          | RW          | 0x0                | idle_req_crypt<br>Enable sending bus idle request to BIU_CRYPT by hardware.<br>1'b0: Disable<br>1'b1: Enable                       |
| 3          | RW          | 0x0                | idle_req_topapb<br>Enable sending bus idle request to BIU_TOPAPB by hardware.<br>1'b0: Disable<br>1'b1: Enable                     |
| 2          | RW          | 0x0                | idle_req_npu<br>Enable sending bus idle request to BIU_NPU by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |
| 1          | RW          | 0x0                | idle_req_pmu<br>Enable sending bus idle request to BIU_PMU by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |
| 0          | RW          | 0x0                | idle_req_php<br>Enable sending bus idle request to BIU_PHP by hardware.<br>1'b0: Disable<br>1'b1: Enable                           |

**PMU BUS IDLE SFTCON0**

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         | RW          | 0x0                | idle_req_usb<br>Enable sending bus idle request to BIU_USB by software.<br>1'b0: Disable<br>1'b1: Enable                           |
| 14         | RW          | 0x0                | idle_req_gmac<br>Enable sending bus idle request to BIU_GMAC by software.<br>1'b0: Disable<br>1'b1: Enable                         |
| 13         | RW          | 0x0                | idle_req_sdio<br>Enable sending bus idle request to BIU_SDIO by software.<br>1'b0: Disable<br>1'b1: Enable                         |
| 12         | RW          | 0x0                | idle_req_sdcard<br>Enable sending bus idle request to BIU_SDCARD by software.<br>1'b0: Disable<br>1'b1: Enable                     |
| 11         | RW          | 0x0                | idle_req_nvm<br>Enable sending bus idle request to BIU_NVM by software.<br>1'b0: Disable<br>1'b1: Enable                           |
| 10         | RW          | 0x0                | idle_req_vdpu<br>Enable sending bus idle request to BIU_VDPU by software.<br>1'b0: Disable<br>1'b1: Enable                         |
| 9          | RW          | 0x0                | idle_req_vepu<br>Enable sending bus idle request to BIU_VEPU by software.<br>1'b0: Disable<br>1'b1: Enable                         |
| 8          | RW          | 0x0                | idle_req_ispp<br>Enable sending bus idle request to BIU_ISPP by software.<br>1'b0: Disable<br>1'b1: Enable                         |
| 7          | RW          | 0x0                | idle_req_vo<br>Enable sending bus idle request to BIU_VO by software.<br>1'b0: Disable<br>1'b1: Enable                             |
| 6          | RW          | 0x0                | idle_req_vi<br>Enable sending bus idle request to BIU_VI by software.<br>1'b0: Disable<br>1'b1: Enable                             |
| 5          | RW          | 0x0                | idle_req_audio<br>Enable sending bus idle request to BIU_AUDIO by software.<br>1'b0: Disable<br>1'b1: Enable                       |
| 4          | RW          | 0x0                | idle_req_busnoc3<br>Enable sending bus idle request to BIU_BUSNOC3 by software.<br>1'b0: Disable<br>1'b1: Enable                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | idle_req_busnoc2<br>Enable sending bus idle request to BIU_BUSNOC2 by software.<br>1'b0: Disable<br>1'b1: Enable |
| 2          | RW          | 0x0                | idle_req_busnoc1<br>Enable sending idle request to BIU_BUSNOC1 by software.<br>1'b0: Disable<br>1'b1: Enable     |
| 1          | RW          | 0x0                | idle_req_bushold<br>Enable sending bus idle request to BIU_BUSHOLD by software.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | idle_req_ddr<br>Enable sending bus idle request to BIU_DDR by software.<br>1'b0: Disable<br>1'b1: Enable         |

**PMU BUS IDLE SFTCON1**

Address: Operational Base + offset (0x00C4)

| <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:5       | RO          | 0x000              | reserved                                                                                                                           |
| 4          | RW          | 0x0                | idle_req_crypt<br>Enable sending bus idle request to BIU_CRYPT by software.<br>1'b0: Disable<br>1'b1: Enable                       |
| 3          | RW          | 0x0                | idle_req_topapb<br>Enablesending bus idle request to BIU_TOPAPB by software.<br>1'b0: Disable<br>1'b1: Enable                      |
| 2          | RW          | 0x0                | idle_req_npu<br>Enable sending bus idle request to BIU_NPU by software.<br>1'b0: Disable<br>1'b1: Enable                           |
| 1          | RW          | 0x0                | idle_req_pmu<br>Enable sending bus idle request to BIU_PMU by software.<br>1'b0: Disable<br>1'b1: Enable                           |
| 0          | RW          | 0x0                | idle_req_php<br>Enable sending bus idle request to BIU_PHP by software.<br>1'b0: Disable<br>1'b1: Enable                           |

**PMU BUS IDLE ACK**

Address: Operational Base + offset (0x00D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:21      | RO          | 0x000              | reserved                                                                                              |
| 20         | RO          | 0x0                | idle_ack_crypt<br>BIU_CRYPT 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>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 19         | RO          | 0x0                | idle_ack_topapb<br>BIU_TOPAPB bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |
| 18         | RO          | 0x0                | idle_ack_npu<br>BIU_NPU bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge       |
| 17         | RO          | 0x0                | idle_ack_pmu<br>BIU_PMU bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge       |
| 16         | RO          | 0x0                | idle_ack_php<br>BIU_PHP bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge       |
| 15         | RO          | 0x0                | idle_ack_usb<br>BIU_USB bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge       |
| 14         | RO          | 0x0                | idle_ack_gmac<br>BIU_GMAC bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge     |
| 13         | RO          | 0x0                | idle_ack_sdio<br>BIU_SDIO bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge     |
| 12         | RO          | 0x0                | idle_ack_sdcard<br>BIU_SDCARD bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |
| 11         | RO          | 0x0                | idle_ack_nvm<br>BIU_NVM bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge       |
| 10         | RO          | 0x0                | idle_ack_vdpu<br>BIU_VDPU bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge     |
| 9          | RO          | 0x0                | idle_ack_vepu<br>BIU_VEPU bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge     |
| 8          | RO          | 0x0                | idle_ack_ispp<br>BIU_ISPP bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge     |
| 7          | RO          | 0x0                | idle_ack_vo<br>BIU_VO 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>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | idle_ack_vi<br>BIU_VI bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge           |
| 5          | RO          | 0x0                | idle_ack_audio<br>BIU_AUDIO bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge     |
| 4          | RO          | 0x0                | idle_ack_busnoc3<br>BIU_BUSNOC3 bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |
| 3          | RO          | 0x0                | idle_ack_busnoc2<br>BIU_BUSNOC2 bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |
| 2          | RO          | 0x0                | idle_ack_busnoc1<br>BIU_BUSNOC1 bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |
| 1          | RO          | 0x0                | idle_ack_bushold<br>BIU_BUSHOLD bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge |
| 0          | RO          | 0x0                | idle_ack_ddr<br>BIU_DDR bus idle acknowledge state.<br>1'b0: Not acknowledge<br>1'b1: Acknowledge         |

**PMU BUS IDLE ST**

Address: Operational Base + offset (0x00D8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------|
| 31:21      | RO          | 0x000              | reserved                                                              |
| 20         | RO          | 0x0                | idle_crypt<br>BIU_CRYPT idle state.<br>1'b0: Not idle<br>1'b1: Idle   |
| 19         | RO          | 0x0                | idle_topapb<br>BIU_TOPAPB idle state.<br>1'b0: Not idle<br>1'b1: Idle |
| 18         | RO          | 0x0                | idle_npu<br>BIU_NPU idle state.<br>1'b0: Not idle<br>1'b1: Idle       |
| 17         | RO          | 0x0                | idle_pmu<br>BIU_PMU idle state.<br>1'b0: Not idle<br>1'b1: Idle       |
| 16         | RO          | 0x0                | idle_php<br>BIU_PHP idle state.<br>1'b0: Not idle<br>1'b1: Idle       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 15         | RO          | 0x0                | idle_usb<br>BIU_USB idle state.<br>1'b0: Not idle<br>1'b1: Idle         |
| 14         | RO          | 0x0                | idle_gmac<br>BIU_GMAC idle state.<br>1'b0: Not idle<br>1'b1: Idle       |
| 13         | RO          | 0x0                | idle_sdio<br>BIU_SDIO idle state.<br>1'b0: Not idle<br>1'b1: Idle       |
| 12         | RO          | 0x0                | idle_sdcard<br>BIU_SDCARD idle state.<br>1'b0: Not idle<br>1'b1: Idle   |
| 11         | RO          | 0x0                | idle_nvm<br>BIU_NVM idle state.<br>1'b0: Not idle<br>1'b1: Idle         |
| 10         | RO          | 0x0                | idle_vdpu<br>BIU_VDPU idle state.<br>1'b0: Not idle<br>1'b1: Idle       |
| 9          | RO          | 0x0                | idle_vepu<br>BIU_VEPU idle state.<br>1'b0: Not idle<br>1'b1: Idle       |
| 8          | RO          | 0x0                | idle_ispp<br>BIU_ISPP idle state.<br>1'b0: Not idle<br>1'b1: Idle       |
| 7          | RO          | 0x0                | idle_vo<br>BIU_VO idle state.<br>1'b0: Not idle<br>1'b1: Idle           |
| 6          | RO          | 0x0                | idle_vi<br>BIU_VI idle state.<br>1'b0: Not idle<br>1'b1: Idle           |
| 5          | RO          | 0x0                | idle_audio<br>BIU_AUDIO idle state.<br>1'b0: Not idle<br>1'b1: Idle     |
| 4          | RO          | 0x0                | idle_busnoc3<br>BIU_BUSNOC3 idle state.<br>1'b0: Not idle<br>1'b1: Idle |
| 3          | RO          | 0x0                | idle_busnoc2<br>BIU_BUSNOC2 idle state.<br>1'b0: Not idle<br>1'b1: Idle |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 2          | RO          | 0x0                | idle_busnoc1<br>BIU_BUSNOC1 idle state.<br>1'b0: Not idle<br>1'b1: Idle |
| 1          | RO          | 0x0                | idle_bushold<br>BIU_BUSHOLD idle state.<br>1'b0: Not idle<br>1'b1: Idle |
| 0          | RO          | 0x0                | idle_ddr<br>BIU_DDR idle state.<br>1'b0: Not idle<br>1'b1: Idle         |

**PMU\_NOC\_AUTO\_CON0**

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         | RW          | 0x0                | auto_idle_usb<br>When perform idle operation, BIU_USB corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable       |
| 14         | RW          | 0x0                | auto_idle_gmac<br>When perform idle operation, BIU_GMAC corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable     |
| 13         | RW          | 0x0                | auto_idle_sdio<br>When perform idle operation, BIU_SDIO corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable     |
| 12         | RW          | 0x0                | auto_idle_sdcard<br>When perform idle operation, BIU_SDCARD corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable |
| 11         | RW          | 0x0                | auto_idle_nvm<br>When perform idle operation, BIU_NVM corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable       |
| 10         | RW          | 0x0                | auto_idle_vpdu<br>When perform idle operation, BIU_VDPU corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable     |
| 9          | RW          | 0x0                | auto_idle_vepu<br>When perform idle operation, BIU_VEPU corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | auto_idle_ispp<br>When perform idle operation, BIU_ISPP corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable   |
| 7          | RW          | 0x0                | auto_idle_vo<br>When perform idle operation, BIU_VO corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable       |
| 6          | RW          | 0x0                | auto_idle_vi<br>When perform idle operation, BIU_VI corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable       |
| 5          | RW          | 0x0                | auto_idle_audio<br>When perform idle operation, BIU_AUDIO corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable |
| 4:1        | RW          | 0x0                | auto_idle_bus<br>When perform idle operation, BIU_BUS corresponding clock can be opened or gated automatically.<br>3'b111: Enable<br>Others: Disable |
| 0          | RW          | 0x0                | auto_idle_ddr<br>When perform idle operation, BIU_DDR corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable     |

**PMU NOC AUTO CON1**

Address: Operational Base + offset (0x00E4)

| <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                | auto_idle_cpu<br>When perform idle operation, BIU_CPU corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable       |
| 4          | RW          | 0x0                | auto_idle_crypt<br>When perform idle operation, BIU_CRYPT corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable   |
| 3          | RW          | 0x0                | auto_idle_topapb<br>When perform idle operation, BIU_TOPAPB corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RW          | 0x0                | auto_idle_npu<br>When perform idle operation, BIU_NPU corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable |
| 1          | RW          | 0x0                | auto_idle_pmu<br>When perform idle operation, BIU_PMU corresponding clock can be opened or gated automatically.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | auto_idle_php<br>When perform idle operation, BIU_PHP corresponding clock can be opened or gated automatically.<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:5       | RO          | 0x000              | reserved                                                                                                                                                  |
| 4          | RW          | 0x0                | ddrphy_auto_gating_ena<br>Enable DDR phy auto clock gating function performed by PMU, when DDR enter self-refresh state.<br>1'b0: Disable<br>1'b1: Enable |
| 3          | RO          | 0x0                | reserved                                                                                                                                                  |
| 2          | RW          | 0x0                | ddrio_ret_exit_ena<br>Enable DDR IO retention de-asserted performed by PMU.<br>1'b0: Disable<br>1'b1: Enable                                              |
| 1          | RW          | 0x0                | ddrio_ret_ena<br>Enable DDR IO retention function performed by PMU.<br>1'b0: Disable<br>1'b1: Enable                                                      |
| 0          | RW          | 0x0                | ddr_sref_ena<br>Enable DDR self-refresh by PMU.<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 |
| 15:4       | RO          | 0x000              | reserved                                                                                                                           |
| 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                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 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_req<br>DDR self-refresh request by software.<br>1'b0: Disable<br>1'b1: Enable        |

**PMU DDR PWR STATE**

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>3'h0: Normal state<br>3'h1: Self-refresh enter state<br>3'h2: IO retention state<br>3'h3: Sleep state<br>3'h4: IO retention exit state<br>3'h5: Self-refresh exit state<br>Others: Reserved |

**PMU DDR PWR ST**

Address: Operational Base + offset (0x00FC)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                    |
| 2          | RO          | 0x0                | ddrio_ret<br>DDR IO retention state.<br>1'b0: Inactive<br>1'b1: Active      |
| 1          | RO          | 0x0                | ddrctl_c_active<br>ddrctl c_active state.<br>1'b0: Inactive<br>1'b1: Active |
| 0          | RO          | 0x0                | ddrctl_c_sysack<br>ddrctl c_sysack state.<br>1'b0: Inactive<br>1'b1: Active |

**PMU PWR GATE CON**

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 16 bits, each bit is individual.<br>1'b0: Write access disable<br>1'b1: Write access enable |
| 15:11      | RO          | 0x00               | reserved                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | pd_crypt_dwn_ena<br>Enable power down PD_CRYPT by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable |
| 9          | RW          | 0x0                | pd_usb_dwn_ena<br>Enable power down PD_USB by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable     |
| 8          | RW          | 0x0                | pd_sdio_dwn_ena<br>Enable power down PD_SDIO by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable   |
| 7          | RW          | 0x0                | pd_nvm_dwn_ena<br>Enable power down PD_NVM by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable     |
| 6          | RW          | 0x0                | pd_ddr_dwn_ena<br>Enable power down PD_DDR by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable     |
| 5          | RW          | 0x0                | pd_vo_dwn_ena<br>Enable power down PD_VO by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable       |
| 4          | RW          | 0x0                | pd_vi_dwn_ena<br>Enable power down PD_VI by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable       |
| 3          | RW          | 0x0                | pd_vdpu_dwn_ena<br>Enable power down PD_VDPU by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable   |
| 2          | RW          | 0x0                | pd_vepu_dwn_ena<br>Enable power down PD_VEPU by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable   |
| 1          | RW          | 0x0                | pd_ispp_dwn_ena<br>Enable power down PD_ISPP by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable   |
| 0          | RW          | 0x0                | pd_npu_dwn_ena<br>Enable power down PD_NPU by PMU automatically.<br>1'b0: Disable<br>1'b1: Enable     |

**PMU PWR GATE STATE**

Address: Operational Base + offset (0x0104)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0        | RO          | 0x0                | <p>power_gate_state<br/>Power domain state machine status.<br/>3'h0: Normal state<br/>3'h1: Power down start<br/>3'h2: Power down selected domain<br/>3'h3: Wait state<br/>3'h4: Power up start<br/>3'h5: Power up running selected domain<br/>Others: Reserved</p> |

**PMU PWR DWN ST**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:11      | RO          | 0x000000           | reserved                                                                                           |
| 10         | RO          | 0x0                | <p>pd_crypt_dwn_stat<br/>The power status of PD_CRYPT.<br/>1'b0: Power up<br/>1'b1: Power down</p> |
| 9          | RO          | 0x0                | <p>pd_usb_dwn_stat<br/>The power status of PD_USB.<br/>1'b0: Power up<br/>1'b1: Power down</p>     |
| 8          | RO          | 0x0                | <p>pd_sdio_dwn_stat<br/>The power status of PD_SDIO.<br/>1'b0: Power up<br/>1'b1: Power down</p>   |
| 7          | RO          | 0x0                | <p>pd_nvm_dwn_stat<br/>The power status of PD_NVM.<br/>1'b0: Power up<br/>1'b1: Power down</p>     |
| 6          | RO          | 0x0                | <p>pd_ddr_dwn_stat<br/>The power status of PD_DDR.<br/>1'b0: Power up<br/>1'b1: Power down</p>     |
| 5          | RO          | 0x0                | <p>pd_vo_dwn_stat<br/>The power status of PD_VO.<br/>1'b0: Power up<br/>1'b1: Power down</p>       |
| 4          | RO          | 0x0                | <p>pd_vi_dwn_stat<br/>The power status of PD_VI.<br/>1'b0: Power up<br/>1'b1: Power down</p>       |
| 3          | RO          | 0x0                | <p>pd_vdpu_dwn_stat<br/>The power status of PD_VDPU.<br/>1'b0: Power up<br/>1'b1: Power down</p>   |
| 2          | RO          | 0x0                | <p>pd_vepu_dwn_stat<br/>The power status of PD_VEPU.<br/>1'b0: Power up<br/>1'b1: Power down</p>   |
| 1          | RO          | 0x0                | <p>pd_ispp_dwn_stat<br/>The power status of PD_ISPP.<br/>1'b0: Power up<br/>1'b1: Power down</p>   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | pd_npu_dwn_stat<br>The power status of PD_NPU.<br>1'b0: Power up<br>1'b1: Power down |

**PMU PWR GATE SFTCON**

Address: Operational Base + offset (0x0110)

| <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                | pd_crypt_dwn_ena<br>Enable power down PD_CRYPT by software.<br>1'b0: Disable<br>1'b1: Enable                                       |
| 9          | RW          | 0x0                | pd_usb_dwn_ena<br>Enable power down PD_USB by software.<br>1'b0: Disable<br>1'b1: Enable                                           |
| 8          | RW          | 0x0                | pd_sdio_dwn_ena<br>Enable power down PD_SDIO by software.<br>1'b0: Disable<br>1'b1: Enable                                         |
| 7          | RW          | 0x0                | pd_nvm_dwn_ena<br>Enable power down PD_NVM by software.<br>1'b0: Disable<br>1'b1: Enable                                           |
| 6          | RW          | 0x0                | pd_ddr_dwn_ena<br>Enable power down PD_DDR by software.<br>1'b0: Disable<br>1'b1: Enable                                           |
| 5          | RW          | 0x0                | pd_vo_dwn_ena<br>Enable power down PD_VO by software.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 4          | RW          | 0x0                | pd_vi_dwn_ena<br>Enable power down PD_VI by software.<br>1'b0: Disable<br>1'b1: Enable                                             |
| 3          | RW          | 0x0                | pd_vdpu_dwn_ena<br>Enable power down PD_VDPU by software.<br>1'b0: Disable<br>1'b1: Enable                                         |
| 2          | RW          | 0x0                | pd_vepu_dwn_ena<br>Enable power down PD_VEPU by software.<br>1'b0: Disable<br>1'b1: Enable                                         |
| 1          | RW          | 0x0                | pd_ispp_dwn_ena<br>Enable power down PD_ISPP by software.<br>1'b0: Disable<br>1'b1: Enable                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | pd_npu_dwn_ena<br>Enable power down PD_NPU by software.<br>1'b0: Disable<br>1'b1: Enable |

**PMU VOL GATE SFTCON**

Address: Operational Base + offset (0x0118)

| <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:3       | RO          | 0x0000             | reserved                                                                                                                           |
| 2          | RW          | 0x0                | vd_vepu_ena<br>Enable PD_VEPU as a voltage domain.<br>1'b0: Disable<br>1'b1: Enable                                                |
| 1          | RO          | 0x0                | reserved                                                                                                                           |
| 0          | RW          | 0x0                | vd_npu_ena<br>Enable PD_NPU as a voltage domain.<br>1'b0: Disable<br>1'b1: Enable                                                  |

**PMU CRU PWR CON**

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:12      | RO          | 0x0                | reserved                                                                                                                           |
| 11         | RW          | 0x0                | pd_audio_clk_src_gate_ena<br>Gating BIU_AUDIO's bus clock source.<br>1'b0: Disable<br>1'b1: Enable                                 |
| 10         | RW          | 0x0                | pd_peri_clk_src_gate_ena<br>Gating BIU_PERI's bus clock source.<br>1'b0: Disable<br>1'b1: Enable                                   |
| 9          | RW          | 0x0                | pd_bus_clk_src_gate_ena<br>Gating BIU_BUS's bus clock source.<br>1'b0: Disable<br>1'b1: Enable                                     |
| 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                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                              |
| 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\_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  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 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 PWR STATE**

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>CRU power machine 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: CRU sleep state<br>4'h6: CRU wakeup state<br>4'h7: Input clamp release state<br>4'h8: Oscillator enable state<br>4'h9: Clock high frequency state<br>4'ha: Wakeup reset clear state<br>4'hb: PLL power up 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:5       | RO          | 0x000              | reserved                                                                                                                           |
| 4          | RW          | 0x0                | gpll_pd_ena<br>GPLL power down by PMU.<br>1'b0: Disable<br>1'b1: Enable                                                            |
| 3          | RW          | 0x0                | hpll_pd_ena<br>HPLL 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                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------|
| 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:5       | RO          | 0x000              | reserved                                                                                                                           |
| 4          | RW          | 0x0                | gpll_pd_ena<br>GPLL power down by software.<br>1'b0: Disable<br>1'b1: Enable                                                       |
| 3          | RW          | 0x0                | hpll_pd_ena<br>HPLL 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                                                                        |
| 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          | RO          | 0x0                | reserved                                                                                                                                                                                                  |
| 6:4        | RW          | 0x0                | info_tx_con<br>Power state output selection.<br>3'h0: PMU_MAIN_PWR_STATE<br>3'h1: PMU_SCU_PWR_STATE<br>3'h4: PMU_DDR_PWR_STATE<br>3'h5: PMU_PWR_GATE_STATE<br>3'h6: PMU_CRU_PWR_STATE<br>Others: Reserved |
| 3:1        | RO          | 0x0                | reserved                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | info_tx_en<br>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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RW          | 0x00000000         | pmu_sys_reg<br>PMU system register |

## 9.5 Timing Diagram

### 9.5.1 Each Domain Power Switch Timing

The following figure shows the timing for each domain power down and power up.



Fig. 9-3 Each Domain Power Switch Timing

### 9.5.2 External Wakeup PAD Timing

The PMU supports a lot of external wakeup sources, such as SDMMC, USBDEV, SDIO, GPIO0 wakeup source and so on. All these external wakeup sources must meet the timing requirement (at least 200us) when the wakeup event is asserted. The following figure gives the timing information.



Fig. 9-4 External Wakeup Source PAD Timing

## 9.6 Application Notes

### 9.6.1 Low Power Mode

PMU can work in the Low power mode by setting bit[0] of PMU\_PWR\_CON register. After setting this bit and all CPUs enter standby states, PMU low power FSM will start to run. In the low power mode, PMU will manage power resources by hardware or software, such as power on/off the specified power domain, send idle request to specified power domain, shut down/up PLL and so on. All of above are configurable by setting corresponding registers.

### 9.6.2 Debug IO

ALL FSM power states could be monitored through IO. RV1109/RV1126 provide PMU Debug IO for FSM observation in UART signal mode.

Table 9-2 Debug IO for PMU FSM state

| Module Pin | Direction | Pin Name                                          | IOMUX Setting                 |
|------------|-----------|---------------------------------------------------|-------------------------------|
| pmu_debug  | O         | PMU_DEBUG/UART1_CTSN_M0/PW<br>M3_IR_M0/GPIO0_C1_d | PMUGRF_GPIO0C_IOMUX[7:4]=4'h1 |

### **9.6.3 System Register**

PMU support 8 system registers: PMU\_SYS\_REG0~ PMU\_SYS\_REG7. These registers are always on no matter what low power mode. So software can use these registers to retain some information which is useful after wakeup from any mode.

### **9.6.4 Configuration Constraint**

In order to shut down the power domains which are managed by software correctly, the software must obey the rules bellow:

- Send BIU request to the BIU in power domain that you want to shut down by configure PMU\_BUS\_IDLE\_SFTCON0 or PMU\_BUS\_IDLE\_SFTCON1 register.
- Querying PMU\_BUS\_IDLE\_ST register to get the information until the pacific BIU is in idle state.
- Send power request to the power domain through PMU\_PWR\_GATE\_CON register.
- Querying PMU\_PWR\_DWN\_ST register to make sure the pacific power domain is power down.

## Chapter 10 System Debug

### 10.1 Overview

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

#### 10.1.1 Features

- Invasive debug with core halted
- SW-DP

#### 10.1.2 Debug Components Address Map

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

| Module  | Base Address |
|---------|--------------|
| DAP_ROM | 0xff000000   |

### 10.2 Block Diagram



Fig. 10-1 Debug system structure

### 10.3 Function Description

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

### 10.4 Register Description

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

### 10.5 Interface Description

#### 10.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. 10-2 DAP SWJ interface

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

Table 10-1 DAP-Lite Interface Description

| Module pin  | Direction | Pad name                                                         | IOMUX                                     |
|-------------|-----------|------------------------------------------------------------------|-------------------------------------------|
| jtag_tck_m0 | I         | SDMMC0_D2/UART3_RX_M1/A7_JTAG_TC_K_M0/RISC-V_JTAG_TCK/GPIO1_A6_u | GRF_GPIO1A_IOMUX_S<br>EL_H[11:8]=4'b0011  |
| jtag_tm_sm0 | I/O       | SDMMC0_D3/UART3_TX_M1/A7_JTAG_TM_S_M0/RISC-V_JTAG_TMS/GPIO1_A7_u | GRF_GPIO1A_IOMUX_S<br>EL_H[11:8]=4'b0100  |
| jtag_tck_m1 | I         | UART2_TX_M1/A7_JTAG_TCK_M1/GPIO3_A2_u                            | GRF_GPIO3A_IOMUX_S<br>EL_L[11:8]=4'b0010  |
| jtag_tm_sm1 | I/O       | UART2_RX_M1/A7_JTAG_TMS_M1/GPIO3_A3_u                            | GRF_GPIO3A_IOMUX_S<br>EL_L[15:12]=4'b0010 |

By default, jtag\_tckm0 and jtag\_tmsm0 are forced to connect to corresponding io pad, since the bit[4] of grf\_ifunc\_sel:grf\_force\_jtag = 1'b1.

## Chapter 11 SPINLOCK

### 11.1 Overview

The hardware spinlock used for spinlock status storage. All the CPU can access spinlock to get the lock status.

### 11.2 Block Diagram



Fig. 11-1 Spinlock Block Diagram

- Bus Interface

The Bus Interface implements the bus slave operation.

- Register Block

The Register block includes the lock status registers.

- Control Logic

The control logic implemented the spinlock function.

### 11.3 Function Description

The SPINLOCK includes 64 lock-status register groups. Each lock-status register has 4bits, which corresponding to the lock status.

When 4bits spinlock\_status is not zero, this lock-status register cannot be written.

When write data is 4'b0, 4bits spinlock\_status registers clean to all zero.

If write data is 4'b0, that means unlock process.

If write data is 4bits ID, that means lock process. If read back value is equal to write data ID, that means lock successfully.

### 11.4 Register Description

#### 11.4.1 Registers Summary

| Name                                             | Offset  | Size | Reset Value | Description                           |
|--------------------------------------------------|---------|------|-------------|---------------------------------------|
| <u>SPINLOCK status_n</u><br>(range of n is 0~63) | 0x0+4*n | W    | 0x00000000  | spinlock status controller register_n |

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

#### 11.4.2 Detail Registers Description

##### SPINLOCK status nnpu LINK 1 FROM

Address: Operational Base + offset (0x0000+4\*n)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:4 | RO   | 0x00        | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RW          | 0x0                | spinlock_status<br>When 4bits is 0, 4bits can be written with new value.<br>When 4bits is not 0, 4bits cannot be written. When write data is 0x0000, 4bits clean to 0. |

## **11.5 Application Notes**

Please refer to the “Function Description” section.

## Chapter 12 Mailbox

### 12.1 Overview

The Mailbox module is a simple APB peripheral that allows Cortex-A7, RISC-V 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 Cortex-A7, and RISC-V core
- Provide 32 lock registers for software to use to indicate whether mailbox is occupied

### 12.2 Block Diagram

The figure below shows Mailbox block diagram:



Fig. 12-1 Mailbox Block Diagram

### 12.3 Function Description

#### 12.3.1 Mailbox

- Regard Cortex-A7 as the “AP” side of the Mailbox. The four elements combined interrupt (|mailbox\_irq\_ap[3:0]) to Cortex-A7 is:
  - Enabled when IRQs[111] is enabled in the GIC and MAILBOX\_B2A\_INTEN[i] is set to 1. (i=0~3)
  - 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[i].
- Regard RISC-V core as the “BB” side of the Mailbox. The four elements combined interrupt (|mailbox\_irq\_bb[3:0]) to RISC-V core is:
  - Enabled when IRQs[112]/IRQs[13] is enabled in the INTC/IPIC of RISC-V core and MAILBOX\_A2B\_INTEN[i] is set to 1. (i=0~3)
  - 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[i].
- You can also regard Cortex-A7 as the “BB” side of the Mailbox and regard RISC-V core as the “AP” side of the Mailbox. The configuration flow is similar.

### 12.4 Register Description

This section describes the control/status registers of the design. Software should read and write these registers using 32-bits accesses.

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

| Name                   | Offset | Size | Reset Value | Description                        |
|------------------------|--------|------|-------------|------------------------------------|
| 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           |
| 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           |
| MAILBOX ATOMIC LOCK 00 | 0x0100 | W    | 0x00000000  | Atomic Lock 00 Register            |
| MAILBOX ATOMIC LOCK 01 | 0x0104 | W    | 0x00000000  | Atomic Lock 01 Register            |
| MAILBOX ATOMIC LOCK 02 | 0x0108 | W    | 0x00000000  | Atomic Lock 02 Register            |
| MAILBOX ATOMIC LOCK 03 | 0x010C | W    | 0x00000000  | Atomic Lock 03 Register            |
| MAILBOX ATOMIC LOCK 04 | 0x0110 | W    | 0x00000000  | Atomic Lock 04 Register            |
| MAILBOX ATOMIC LOCK 05 | 0x0114 | W    | 0x00000000  | Atomic Lock 05 Register            |
| MAILBOX ATOMIC LOCK 06 | 0x0118 | W    | 0x00000000  | Atomic Lock 06 Register            |
| MAILBOX ATOMIC LOCK 07 | 0x011C | W    | 0x00000000  | Atomic Lock 07 Register            |
| MAILBOX ATOMIC LOCK 08 | 0x0120 | W    | 0x00000000  | Atomic Lock 08 Register            |
| MAILBOX ATOMIC LOCK 09 | 0x0124 | W    | 0x00000000  | Atomic Lock 09 Register            |
| MAILBOX ATOMIC LOCK 10 | 0x0128 | W    | 0x00000000  | Atomic Lock 10 Register            |
| MAILBOX ATOMIC LOCK 11 | 0x012C | W    | 0x00000000  | Atomic Lock 11 Register            |
| MAILBOX ATOMIC LOCK 12 | 0x0130 | W    | 0x00000000  | Atomic Lock 12 Register            |
| MAILBOX ATOMIC LOCK 13 | 0x0134 | W    | 0x00000000  | Atomic Lock 13 Register            |
| MAILBOX ATOMIC LOCK 14 | 0x0138 | W    | 0x00000000  | Atomic Lock 14 Register            |
| MAILBOX ATOMIC LOCK 15 | 0x013C | W    | 0x00000000  | Atomic Lock 15 Register            |
| MAILBOX ATOMIC LOCK 16 | 0x0140 | W    | 0x00000000  | Atomic Lock 16 Register            |
| MAILBOX ATOMIC LOCK 17 | 0x0144 | W    | 0x00000000  | Atomic Lock 17 Register            |

| Name                   | Offset | Size | Reset Value | Description             |
|------------------------|--------|------|-------------|-------------------------|
| MAILBOX ATOMIC LOCK 18 | 0x0148 | W    | 0x00000000  | Atomic Lock 18 Register |
| MAILBOX ATOMIC LOCK 19 | 0x014C | W    | 0x00000000  | Atomic Lock 19 Register |
| MAILBOX ATOMIC LOCK 20 | 0x0150 | W    | 0x00000000  | Atomic Lock 20 Register |
| MAILBOX ATOMIC LOCK 21 | 0x0154 | W    | 0x00000000  | Atomic Lock 21 Register |
| MAILBOX ATOMIC LOCK 22 | 0x0158 | W    | 0x00000000  | Atomic Lock 22 Register |
| MAILBOX ATOMIC LOCK 23 | 0x015C | W    | 0x00000000  | Atomic Lock 23 Register |
| MAILBOX ATOMIC LOCK 24 | 0x0160 | W    | 0x00000000  | Atomic Lock 24 Register |
| MAILBOX ATOMIC LOCK 25 | 0x0164 | W    | 0x00000000  | Atomic Lock 25 Register |
| MAILBOX ATOMIC LOCK 26 | 0x0168 | W    | 0x00000000  | Atomic Lock 26 Register |
| MAILBOX ATOMIC LOCK 27 | 0x016C | W    | 0x00000000  | Atomic Lock 27 Register |
| MAILBOX ATOMIC LOCK 28 | 0x0170 | W    | 0x00000000  | Atomic Lock 28 Register |
| MAILBOX ATOMIC LOCK 29 | 0x0174 | W    | 0x00000000  | Atomic Lock 29 Register |
| MAILBOX ATOMIC LOCK 30 | 0x0178 | W    | 0x00000000  | Atomic Lock 30 Register |
| MAILBOX ATOMIC LOCK 31 | 0x017C | W    | 0x00000000  | Atomic Lock 31 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

## 12.4.2 Detail Registers 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)

| <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 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 |

| <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\_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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:0       | RW          | 0x00000000         | data<br>Data register. |

**MAILBOX\_B2A\_CMD\_1**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | command<br>Command register. |

**MAILBOX\_B2A\_DAT\_1**

Address: Operational Base + offset (0x003C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:0       | RW          | 0x00000000         | data<br>Data register. |

**MAILBOX\_B2A\_CMD\_2**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | command<br>Command register. |

**MAILBOX\_B2A\_DAT\_2**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:0       | RW          | 0x00000000         | data<br>Data register. |

**MAILBOX\_B2A\_CMD\_3**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>           |
|------------|-------------|--------------------|------------------------------|
| 31:0       | RW          | 0x00000000         | command<br>Command register. |

**MAILBOX\_B2A\_DAT\_3**

Address: Operational Base + offset (0x004C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:0       | RW          | 0x00000000         | data<br>Data register. |

**MAILBOX ATOMIC LOCK 00**

Address: Operational Base + offset (0x0100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 01**

Address: Operational Base + offset (0x0104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 02**

Address: Operational Base + offset (0x0108)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 03**

Address: Operational Base + offset (0x010C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 04**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 05**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 06**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 07**

Address: Operational Base + offset (0x011C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 08**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 09**

Address: Operational Base + offset (0x0124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 10**

Address: Operational Base + offset (0x0128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 11**

Address: Operational Base + offset (0x012C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 12**

Address: Operational Base + offset (0x0130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 13**

Address: Operational Base + offset (0x0134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 14**

Address: Operational Base + offset (0x0138)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 15**

Address: Operational Base + offset (0x013C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 16**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 17**

Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 18**

Address: Operational Base + offset (0x0148)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 19**

Address: Operational Base + offset (0x014C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 20**

Address: Operational Base + offset (0x0150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 21**

Address: Operational Base + offset (0x0154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 22**

Address: Operational Base + offset (0x0158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 23**

Address: Operational Base + offset (0x015C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 24**

Address: Operational Base + offset (0x0160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 25**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 26**

Address: Operational Base + offset (0x0168)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 27**

Address: Operational Base + offset (0x016C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 28**

Address: Operational Base + offset (0x0170)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 29**

Address: Operational Base + offset (0x0174)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 30**

Address: Operational Base + offset (0x0178)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**MAILBOX ATOMIC LOCK 31**

Address: Operational Base + offset (0x017C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                   |
|------------|-------------|--------------------|--------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                             |
| 0          | RW          | 0x0                | atomic_lock<br>Atomic lock flag bit. |

**12.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 13 DECOM

### 13.1 Overview

DECOM can decompress compressed files in GZIP, LZ4, Deflate and Zlib formats. DECOM controller supports the following features:

- Support for decompressing GZIP files
- Support for decompressing LZ4 files, including the General Structure of LZ4 Frame format and the Legacy Frame format
- Support for decompressing data in Deflate format
- Support for decompressing data in ZLIB format
- 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 FIFOs(RX\_FIFO) for caching source compressed data
- Support one internal 24-bit wide and 64-location deep FIFOs(HF\_FIFO) for caching intermediate data during decompression
- Built-in a 32K-128bit two-port RAM for storing decompressed data
- Support complete interrupt and error interrupt output
- Support Hash32 check in LZ4 decompression process
- 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

### 13.2 Block Diagram



Fig. 13-1 DECOM Block Diagram

### 13.3 Function Description

#### 13.3.1 Module Introduction

##### 13.3.1.1 APB INTERFACE

The APB slave interface is used for registers configuration, decompression file parameter reading and interrupt status query, etc.

##### 13.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. When decompressing the LZ4 file, it is also used to read back data with a matching distance of more than 32 KB from the external storage.

### **13.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.

### **13.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.

### **13.3.1.5 UNLZ4 Module**

The UNLZ4 module performs file header parsing on the compressed file of LZ4 format, and decompresses the data into LZ77 format (match length-matching distance) data pair or character data, and stores it in HF\_FIFO.

### **13.3.1.6 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.

### **13.3.1.7 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.

### **13.3.1.8 HF\_FIFO**

The HF\_FIFO is used to buffer the LZ77 format (match length-match distance) data pair or character data decompressed by the UNLZ4 module and 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.

### **13.3.1.9 UNLZ77 Module**

UNLZ77 is used to implement LZ77 decoding and store the decompressed data in 32K RAM. When the matching distance is less than 32k byte, matching replication is performed in 32K RAM. When the matching distance is greater than 32k byte, the AXI Master interface is controlled to perform matching replication in the external storage.

### **13.3.1.10 32K-RAM**

The 32K 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.

### **13.3.1.11 HASH32 Module**

In the process of decompressing the LZ4 compressed file, the HASH32 module is used to calculate the hash32 check value of the file header, data block and decompressed data.

## **13.3.2 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 decompressing LZ4 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.

### 13.3.3 Data Flow



Fig. 13-2 DECOM Data Flow

## 13.4 Register Description

### 13.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

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

| Name          | Offset | Size | Reset Value | Description                        |
|---------------|--------|------|-------------|------------------------------------|
| DECOM_LMTSH   | 0x0054 | W    | 0xffffffff  | Limit Size of Decompressed Data.   |
| DECOM_GZFHD   | 0x0058 | W    | 0x00000000  | GZIP/ZLIB File Header Information. |
| DECOM_VERSION | 0x00f0 | W    | 0x00000926  | DECOM Version Number               |

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

### 13.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. 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. 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>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.<br>1'b0: Disable.<br>1'b1: Enable.                                                                                                                                                                               |
| 2    | RW   | 0x0         | BCEN<br>LZ4 Block Checksum Check 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.<br>1'b0: Disable.<br>1'b1: Enable. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p>HCEN<br/>LZ4 Header Checksum Check Enable.<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.</p> |
| 0          | RW          | 0x0                | <p>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.</p>                                                                       |

**DECOM\_ENR**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                               |
| 0          | WO          | 0x0                | <p>ENR<br/>Enables and disables all decompress operations.<br/>All FIFO buffers and aclk/dclk domain work registers are cleared when the device is disabled. Self Clear when decompression is complete.<br/>1'b0: Disable decompressor.<br/>1'b1: Enable decompressor to work. The ENR should be enabled after the other registers are configured.</p> |

**DECOM\_RADDR**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>RADDR<br/>Read Address.<br/>This register is used to configure the starting address of the file to be decompressed.</p> |

**DECOM\_WADDR**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>WADDR<br/>Write Address.<br/>This register is used to configure the starting address of the location where the decompressed data is written.<br/>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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0xffffffff         | UDDSL<br>Undecompressed Data Size Lower 32bits.<br>UDDS[63:0] is the total size of undecompressed file. DECOM will read the compressed file data according to the value of UDDS[63:0], but the configuration of this register is optional. If this register is not configured, the default value is 64'hffff_ffff_ffff_ffff, DECOM will always read the data until the current The decompression process ends. (Unit:byte) |

**DECOM\_UDDSH**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                               |
|------------|-------------|--------------------|--------------------------------------------------|
| 31:0       | RW          | 0xffffffff         | UDDSH<br>Undecompressed Data Size Higher 32bits. |

**DECOM\_TXTHR**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x000000100        | TXTHR<br>When the number of 32K_MEM entries is greater than or equal to this value, the DECOM will automatically transfer the data in the 32K_MEM to the external via the AXI Master interface. The value ranges is 0~32256.(Unit:byte) |

**DECOM\_SLEN**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x000000000        | SLEN<br>Inflate Store Block Size.<br>Indicate the block size when decompressing the store block of Infalte file. For debugging SLC_ERR. (Unit:byte) |

**DECOM\_STAT**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x000000000        | 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. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | COMPLETE<br>Decom Complete Flag.<br>Only decompress total complete with no error, this flag is set to 1.<br>1'b0: Not complete.<br>1'b1: Decompress is complete with no error. |

**DECOM ISR**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                             |
| 19         | WO          | 0x0                | DSOLI<br>Decompressed Data Size Over Limit_size Interrupt.<br>1'b0: interrupt is not active<br>1'b1: interrupt is active             |
| 18         | WO          | 0x0                | ZDICTEI<br>ZLIB Dictionary Error Interrupt.<br>1'b0: Interrupt is not active<br>1'b1: Interrupt is active                            |
| 17         | WO          | 0x0                | GCMEI<br>Gzip/Zlib Compression Method Check Error Interrupt.<br>1'b0: interrupt is not active<br>1'b1: interrupt is active           |
| 16         | WO          | 0x0                | GIDEI<br>Gzip ID Error Interrupt.<br>1'b0: interrupt is not active<br>1'b1: interrupt is active                                      |
| 15         | WO          | 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         | WO          | 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         | WO          | 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  |
| 12         | WO          | 0x0                | CSEI<br>Unlz4 Content Size Error Interrupt.<br>1'b0: cs_err interrupt is not active<br>1'b1: cs_err interrupt is active              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | WO          | 0x0                | DICTEI<br>Unlz4 Dictionary Error Interrupt.<br>1'b0: Interrupt is not active<br>1'b1: Interrupt is active                                                                                    |
| 10         | WO          | 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          | WO          | 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          | WO          | 0x0                | RDCEI<br>AXI Read Channel Error Interrupt.<br>Write 1 then Clear this interrupt.<br>1'b0: Inflate AXI RDC_ERR interrupt is not active.<br>1'b1: Inflate AXI RDC_ERR interrupt is active.     |
| 7          | WO          | 0x0                | WRCEI<br>AXI Write Channel Error Interrupt.<br>Write 1 then Clear this interrupt.<br>1'b0: Inflate AXI WRC_ERR interrupt is not active.<br>1'b1: Inflate AXI WRC_ERR interrupt is active.    |
| 6          | WO          | 0x0                | DISEI<br>Inflate Huffman Distance Error Interrupt.<br>Write 1 then Clear this interrupt.<br>1'b0: Inflate HFDIS_ERR interrupt is not active.<br>1'b1: Inflate HFDIS_ERR interrupt is active. |
| 5          | WO          | 0x0                | LENEI<br>Inflate Huffman Length Error Interrupt.<br>Write 1 then Clear this interrupt.<br>1'b0: Inflate HFLEN_ERR interrupt is not active.<br>1'b1: Inflate HFLEN_ERR interrupt is active.   |
| 4          | WO          | 0x0                | LITEI<br>Inflate Huffman Literal Error Interrupt.<br>Write 1 then Clear this interrupt.<br>1'b0: Inflate HFLIT_ERR interrupt is not active.<br>1'b1: Inflate HFLIT_ERR interrupt is active.  |
| 3          | WO          | 0x0                | SQMEI<br>Inflate SQ Match Error Interrupt.<br>Write 1 then Clear this interrupt.<br>1'b0: Inflate SQM_ERR interrupt is not active.<br>1'b1: Inflate SQM_ERR interrupt is active.             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | WO          | 0x0                | SLCEI<br>Inflate Store Block Len Check Error Interrupt.<br>Write 1 then Clear this interrupt.<br>1'b0: Inflate SLC_ERR interrupt is not active.<br>1'b1: Inflate SLC_ERR interrupt is active.                                                                                                                        |
| 1          | WO          | 0x0                | HDEI<br>Inflate File Header Error Interrupt.<br>Write 1 then Clear this interrupt.<br>1'b0: Inflate header error interrupt is not active.<br>1'b1: Inflate header error interrupt is active.                                                                                                                         |
| 0          | WO          | 0x0                | DSI<br>Decom Stop Interrupt.<br>This interrupt indicates that DECOM has stopped working.<br>Including decompression completion or decompression<br>encountered an error.<br>Write 1 then Clear this interrupt.<br>1'b0: decompression stop interrupt is not active.<br>1'b1: decompression stop interrupt is active. |

**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.     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------|
| 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 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.           |
| 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.     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 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 Storte Block Len 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><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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | TSIZEH<br>The Total Size of the data after decompression. |

**DECOM\_MNUM**

Address: Operational Base + offset (0x003c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | MNUM<br>Magic Number is 0x184D2204.<br>If the MN is not 0x184D2204, a MN Error will be generated. And DECOM will stop decompressing.<br>For debug. |

**DECOM\_FRAME**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.                                                                                                   |
| 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.<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>(Unit:byte)<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.<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 GZIM = 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'h0000_0926. |

## **13.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 (ie 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 14 Temperature-Sensor ADC (TS-ADC)

### 14.1 Overview

TS-ADC Controller module supports user-defined mode and automatic mode. User-defined mode refers, TSADC all the control signals entirely by software writing to register for direct control. Automatic mode refers to the module automatically poll TSADC output, and the results were checked. If you find that the temperature 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.

TS-ADC Controller supports the following features:

- Support User-Defined Mode and Automatic Mode
- In User-Defined Mode, start-of-conversion can be controlled completely by software, and also can be generated by hardware
- In Automatic Mode, the temperature of alarm(high/low temperature) interrupt can be configurable
- In Automatic Mode, the temperature of system reset can be configurable
- Support to 2 channel TS-ADC(CPU and NPU), the temperature criteria of each channel can be configurable
- In Automatic Mode, the time interval of temperature detection can be configurable
- In Automatic Mode, when detecting a high temperature, the time interval of temperature detection can be configurable
- High temperature debounce can be configurable
- -40~125°C temperature range and 5°C temperature resolution
- 12-bit SARADC up to 732 S/s sampling rate

### 14.2 Block Diagram

TS-ADC controller comprises with:

- APB Interface
- TS-ADC control logic



Fig. 14-1 TS-ADC Controller Block Diagram

### 14.3 Function Description

#### 14.3.1 AHB 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.

#### 14.3.2 TS-ADC Controller

This block is exploited to realize binary search algorithm, storing the intermediate result and

generate control signal for analog block. This block compares the analog input with the voltage generated from D/A Converter, and output the comparison result to SAR and Control Logic Block for binary search. Three level amplifiers are employed in this comparator to provide enough gain.

## 14.4 Register Description

### 14.4.1 Registers Summary

| Name                           | Offset | Size | Reset Value | Description                                  |
|--------------------------------|--------|------|-------------|----------------------------------------------|
| TSADC USER CON                 | 0x0000 | W    | 0x000000200 | User-Define Mode Control Register            |
| TSADC AUTO CON                 | 0x0004 | W    | 0x000000000 | Auto Mode Control Register                   |
| TSADC INT EN                   | 0x0008 | W    | 0x000000000 | Interrupt Enable Register                    |
| TSADC INT PD                   | 0x000C | W    | 0x000000000 | Interrupt Status Register                    |
| TSADC DATA0                    | 0x0020 | W    | 0x000000000 | A/D Conversion Data Register for Channel 0   |
| TSADC DATA1                    | 0x0024 | W    | 0x000000000 | A/D Conversion Data Register for Channel 1   |
| TSADC COMPO INT                | 0x0030 | W    | 0x000000000 | High Temperature Level Register for Source 0 |
| TSADC COMP1 INT                | 0x0034 | W    | 0x000000000 | High Temperature Level Register for Source 1 |
| TSADC COMPO SHUT               | 0x0040 | W    | 0x000000000 | Shut Temperature Level Register for Source 0 |
| TSADC COMP1 SHUT               | 0x0044 | W    | 0x000000000 | Shut Temperature Level Register for Source 1 |
| TSADC HIGHT INT DEBO<br>UNCE   | 0x0060 | W    | 0x000000003 | High Temperature Debounce Register           |
| TSADC HIGHT TSHUT D<br>EBOUNCE | 0x0064 | W    | 0x000000003 | Shut Temperature Debounce Register           |
| TSADC AUTO PERIOD              | 0x0068 | W    | 0x00010000  | Auto Access Period Register                  |
| TSADC AUTO PERIOD H<br>T       | 0x006C | W    | 0x00010000  | High Temperature Auto Access Period Register |
| TSADC COMPO LOW INT            | 0x0080 | W    | 0x000000000 | Low Temperature Level Register for Source 0  |
| TSADC COMP1 LOW INT            | 0x0084 | W    | 0x000000000 | Low Temperature Level Register for Source 1  |

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

### 14.4.2 Detail Register Description

#### TSADC USER CON

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                                                                                                                                                                |
| 15    | RW   | 0x0         | adc_status<br>1'b0: ADC stop<br>1'b1: Conversion in progress                                                                                                                                            |
| 14:6  | RW   | 0x008       | inter_pd_soc<br>Interleave between power down and start of conversion.                                                                                                                                  |
| 5     | RW   | 0x0         | start<br>When software write 1 to this bit, start-of-conversion will be assert.<br>This bit will be cleared after TSADC access finishing.<br>Only when TSADC_USER_CON[4] = 1'b1, this bit takes effect. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | start_mode<br>Start mode.<br>1'b0: TSADC controller will assert start_of_conversion after "inter_pd_soc" cycles<br>1'b1: The start_of_conversion will be controlled by TSADC_USER_CON[5] |
| 3          | RW          | 0x0                | adc_power_ctrl<br>1'b0: ADC power down<br>1'b1: ADC power up and reset                                                                                                                   |
| 2:0        | RW          | 0x0                | adc_input_src_sel<br>3'b000: Input source 0 (SARADC_AIN[0])<br>3'b001: Input source 1 (SARADC_AIN[1])<br>Others: Reserved                                                                |

**TSADC AUTO CON**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:26      | RO          | 0x00               | reserved                                                                                                                                                                              |
| 25         | RW          | 0x0                | last_tshut_2cru<br>TSHUT status.<br>This bit will set to 1 when tshut is valid, and only be cleared when application write 1 to it.<br>This bit will not be cleared by system reset.  |
| 24         | RW          | 0x0                | last_tshut_2gpio<br>TSHUT status.<br>This bit will set to 1 when tshut is valid, and only be cleared when application write 1 to it.<br>This bit will not be cleared by system reset. |
| 23:18      | RO          | 0x00               | reserved                                                                                                                                                                              |
| 17         | RW          | 0x0                | sample_dly_sel<br>1'b0: AUTO_PERIOD is used<br>1'b1: AUTO_PERIOD_HT is used                                                                                                           |
| 16         | RW          | 0x0                | auto_status<br>1'b0: Auto mode stop<br>1'b1: Auto mode in progress                                                                                                                    |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                              |
| 13         | RW          | 0x0                | src1_lt_en<br>1'b0: Do not care low temperature of source 1<br>1'b1: Enable the low temperature monitor of source 1                                                                   |
| 12         | RW          | 0x0                | src0_lt_en<br>1'b0: Do not care low temperature of source 0<br>1'b1: Enable the low temperature monitor of source 0                                                                   |
| 11:9       | RO          | 0x0                | reserved                                                                                                                                                                              |
| 8          | RW          | 0x0                | tshut_polarity<br>1'b0: Low active<br>1'b1: High active                                                                                                                               |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                              |
| 5          | RW          | 0x0                | src1_en<br>1'b0: Do not care the temperature of source 1<br>1'b1: If the temperature of source 1 is too high, TSHUT will be valid                                                     |
| 4          | RW          | 0x0                | src0_en<br>1'b0: Do not care the temperature of source 0<br>1'b1: If the temperature of source 0 is too high, TSHUT will be valid                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2        | RO          | 0x0                | reserved                                                                                                                                               |
| 1          | RW          | 0x0                | tsadc_q_sel<br>1'b0: Use tsadc_q as output (positive temperature coefficient)<br>1'b1: Use (4096-tsadc_q) as output (negative temperature coefficient) |
| 0          | RW          | 0x0                | auto_en<br>1'b0: TSADC controller works at user-define mode<br>1'b1: TSADC controller works at auto mode                                               |

**TSADC INT EN**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                  |
| 16         | RW          | 0x0                | eoc_int_en<br>End-of-conversion interrupt enable in user-define mode<br>1'b0: Disable<br>1'b1: Enable                     |
| 15:14      | RO          | 0x0                | reserved                                                                                                                  |
| 13         | RW          | 0x0                | lt_inten_src1<br>Low temperature interrupt enable for src1.<br>1'b0: Disable<br>1'b1: Enable                              |
| 12         | RW          | 0x0                | lt_inten_src0<br>Low temperature interrupt enable for src0.<br>1'b0: Disable<br>1'b1: Enable                              |
| 11:10      | RO          | 0x0                | reserved                                                                                                                  |
| 9          | RW          | 0x0                | tshut_2cru_en_src1<br>1'b0: TSHUT output to CRU disabled. TSHUT output will always keep low<br>1'b1: TSHUT output works   |
| 8          | RW          | 0x0                | tshut_2cru_en_src0<br>1'b0: TSHUT output to CRU disabled. TSHUT output will always keep low<br>1'b1: TSHUT output works   |
| 7:6        | RO          | 0x0                | reserved                                                                                                                  |
| 5          | RW          | 0x0                | tshut_2gpio_en_src1<br>1'b0: TSHUT output to GPIO disabled. TSHUT output will always keep low<br>1'b1: TSHUT output works |
| 4          | RW          | 0x0                | tshut_2gpio_en_src0<br>1'b0: TSHUT output to GPIO disabled. TSHUT output will always keep low<br>1'b1: TSHUT output works |
| 3:2        | RO          | 0x0                | reserved                                                                                                                  |
| 1          | RW          | 0x0                | ht_inten_src1<br>High temperature interrupt enable for src1.<br>1'b0: Disable<br>1'b1: Enable                             |
| 0          | RW          | 0x0                | ht_inten_src0<br>High temperature interrupt enable for src0.<br>1'b0: Disable<br>1'b1: Enable                             |

**TSADC INT PD**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                    |
| 16         | RW          | 0x0                | eoc_int_pd<br>This bit will be set to 1 when end-of-conversion.<br>Set 0 to clear the interrupt.                                                                                                                                            |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                    |
| 13         | RW          | 0x0                | lt_irq_src1<br>When TSADC output is lower than COMP_INT_LOW, this bit will be valid, which means temperature is low, and the application should in charge of this.<br>write 1 to it, this bit will be cleared.                              |
| 12         | RW          | 0x0                | lt_irq_src0<br>When TSADC output is lower than COMP_INT_LOW, this bit will be valid, which means temperature is low, and the application should in charge of this.<br>write 1 to it, this bit will be cleared.                              |
| 11:6       | RO          | 0x00               | reserved                                                                                                                                                                                                                                    |
| 5          | RW          | 0x0                | tshut_o_src1<br>TSHUT output status.<br>When TSADC output is bigger than COMP_SHUT, this bit will be valid, which means temperature is VERY high, and the application should in charge of this.<br>write 1 to it, this bit will be cleared. |
| 4          | RW          | 0x0                | tshut_o_src0<br>TSHUT output status.<br>When TSADC output is bigger than COMP_SHUT, this bit will be valid, which means temperature is VERY high, and the application should in charge of this.<br>write 1 to it, this bit will be cleared. |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                    |
| 1          | RW          | 0x0                | ht_irq_src1<br>When TSADC output is bigger than COMP_INT, this bit will be valid, which means temperature is high, and the application should in charge of this.<br>write 1 to it, this bit will be cleared.                                |
| 0          | RW          | 0x0                | ht_irq_src0<br>When TSADC output is bigger than COMP_INT, this bit will be valid, which means temperature is high, and the application should in charge of this.<br>write 1 to it, this bit will be cleared.                                |

### TSADC DATA0

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                          |
| 11:0       | RW          | 0x000              | adc_data<br>ADC data.<br>A/D value of the channel 0 last conversion (DOUT[11:0]). |

### TSADC DATA1

Address: Operational Base + offset (0x0024)

| <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              | adc_data<br>ADC data.<br>A/D value of the channel 1 last conversion (DOUT[11:0]). |

**TSADC COMPO INT**

Address: Operational Base + offset (0x0030)

| <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, means the temperature is high.<br>TSADC_INT will be valid. |

**TSADC COMP1 INT**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                               |
| 11:0       | RW          | 0x000              | tsadc_comp_src1<br>TSADC high temperature level.<br>TSADC output is bigger than tsadc_comp, means the temperature is high.<br>TSADC_INT will be valid. |

**TSADC COMPO SHUT**

Address: Operational Base + offset (0x0040)

| <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, means the temperature is too high.<br>TSHUT will be valid. |

**TSADC COMP1 SHUT**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                               |
| 11:0       | RW          | 0x000              | tsadc_comp_src1<br>TSADC high temperature level.<br>TSADC output is bigger than tsadc_comp, means the temperature is too high.<br>TSHUT will be valid. |

**TSADC HIGHT INT DEBOUNCE**

Address: Operational Base + offset (0x0060)

| <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 temperature is higher than COMP_INT for "debounce" times. |

**TSADC HIGHT TSHUT DEBOUNCE**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                           |
| 7:0        | RW          | 0x03               | debounce<br>TSADC controller will only generate interrupt or TSHUT when temperature is higher than COMP_SHUT for "debounce" times. |

**TSADC AUTO PERIOD**

Address: Operational Base + offset (0x0068)

| <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 two accessing of TSADC. |

**TSADC AUTO PERIOD HT**

Address: Operational Base + offset (0x006C)

| <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 two accessing of TSADC after the temperature is higher than COMP_SHUT or COMP_INT. |

**TSADC COMPO LOW INT**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x000000           | reserved                                                                                                                                                |
| 11:0       | RW          | 0x000              | tsadc_comp_src0<br>TSADC low temperature level.<br>TSADC output is lower than tsadc_comp, means the temperature is low.<br>TSADC_LOW_INT will be valid. |

**TSADC COMP1 LOW INT**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x000000           | reserved                                                                                                                                                |
| 11:0       | RW          | 0x000              | tsadc_comp_src1<br>TSADC low temperature level.<br>TSADC output is lower than tsadc_comp, means the temperature is low.<br>TSADC_LOW_INT will be valid. |

**14.5 Application Notes****14.5.1 Channel Select**

The system has two Temperature Sensors, channel 0 is for CPU and channel 1 is for NPU.

**14.5.2 Single-Sample Conversion**

- The start timing



Fig. 14-2 Start Flow to Enable the Sensor and ADC

- Bypass mode(**GRF\_SOC\_CON1[1]** = 1'b1)

When the ADC bypass mode is enable(**tsadc\_dig\_bypass** = 1'b1), the ADC will cost 14 clock cycles to complete the conversion. The **tsadc\_dout** will keep the valid data output unchanged until the next clock cycles when the **tsadc\_sample** is valid.



Fig. 14-3 TS-ADC Timing Diagram in Bypass Mode

- The Normal mode

- **tsadc\_clk\_sel** = 1'b0(**GRF\_SOC\_CON1[0]** = 1'b0)

The ADC will cost 15 clock cycles to complete the conversion. The **tsadc\_dout** will keep the valid data output unchanged until the next two clock cycles when the **tsadc\_sample** is valid.



Fig. 14-4 TS-ADC Timing Diagram in Normal Mode with **tsadc\_clk\_sel** = 1'b0

- **tsadc\_clk\_sel** = 1'b1(**GRF\_SOC\_CON1[0]** = 1'b1)

The ADC will cost 16 clock cycles to complete the conversion. The **tsadc\_dout** will keep the valid data output unchanged until the next three clock cycles when the **tsadc\_sample** is valid.



Fig. 14-5 TS-ADC Timing Diagram in Normal Mode with **tsadc\_clk\_sel** = 1'b1

### 14.5.3 Temperature-to-Code Mapping

Table 14-1 Temperature Code Mapping

| Temperature (°C) | ADC Output Data<br>(AUTO_CON[1] == 1'b0) |         |     |
|------------------|------------------------------------------|---------|-----|
|                  | Min                                      | Typ     | Max |
| -40              | -                                        | 2614.38 | -   |
| -20              | -                                        | 2659.65 | -   |
| 0                | -                                        | 2704.91 | -   |
| 25               | -                                        | 2761.49 | -   |
| 50               | -                                        | 2818.07 | -   |
| 75               | -                                        | 2874.65 | -   |
| 100              | -                                        | 2931.23 | -   |
| 125              | -                                        | 2987.81 | -   |

Note:

$$D_{outstd}(T) = 2.2632 * T + 2704.9$$

Code to Temperature mapping of the Temperature sensor is a piece wise linear curve. Any temperature, code falling between to 2 give temperatures can be linearly interpolated.

Code to Temperature mapping should be updated based on silicon results.

### 14.5.4 User-Define Mode

- In user-define mode, the PD\_DVDD and CHSEL\_DVDD are generate by setting register TSADC\_USER\_CON, bit[3] and bit[2:0]. In order to ensure timing between PD\_DVDD and CHSEL\_DVDD, the CHSEL\_DVDD must be set before the PD\_DVDD.
- In user-define mode, you can choose the method to control the START\_OF\_CONVERSION by setting bit[4] of TSADC\_USER\_CON. If set to 0, the start\_of\_conversion will be assert after "inter\_pd\_soc" cycles, which could be set by bit[11:6] of TSADC\_USER\_CON. And if start\_mode was set 1, the start\_of\_conversion will be controlled by bit[5] of TSADC\_USER\_CON.
- Software can get the four channel temperature from TSADC\_DATA{n} (n=0,1,2,3).

### 14.5.5 Automatic Mode

You can use the automatic mode with the following step:

- Set TSADC\_AUTO\_PERIOD to configure the interleave between every two accessing of TSADC in normal operation.
- Set TSADC\_AUTO\_PERIOD\_HT to configure the interleave between every two accessing of TSADC after the temperature is higher than COMP\_SHUT or COMP\_INT.
- Set TSADC\_COMPn\_INT(n=0,1) to configure the high temperature level, if tsadc output is smaller than the value, means the temperature is high, tsadc\_int will be asserted.
- Set TSADC\_COMPn\_SHUT(n=0,1) to configure the super high temperature level, if tsadc output is smaller than the value, means the temperature is too high, TSHUT will be asserted.
- Set TSADC\_INT\_EN to enable the high temperature interrupt for all channel; and you can also set TSHUT output to GPIO to reset the whole chip; and you can set TSHUT output to cru to reset the whole chip.
- Set TSADC\_HIGHT\_INT\_DEBOUNCE and TSADC\_HIGHT\_TSHUT\_DEBOUNCE, if the temperature is higher than COMP\_INT or COMP\_SHUT for "debounce" times, TSADC controller will generate interrupt or TSHUT.
  - Set TSADC\_AUTO\_CON to enable the TSADC controller.

## Chapter 15 SAR-ADC

### 15.1 Overview

The ADC is a 6-channel signal-ended 10-bit Successive Approximation Register (SAR) A/D Converter. It uses the supply and ground as its reference which avoids use of any external reference. It converts the analog input signal into 10-bit binary digital codes at maximum conversion rate of 1MSPS with 12MHz A/D converter clock.

### 15.2 Block Diagram



Fig. 15-1 SAR-ADC Block Diagram

#### Successive-Approximate Register and Control Logic Block

This block is exploited to realize binary search algorithm, storing the intermediate result and generate control signal for analog block.

#### Comparator Block

This block compares the analog input SARADC\_AIN[2:0] with the voltage generated from D/A Converter, and output the comparison result to SAR and Control Logic Block for binary search. Three level amplifiers are employed in this comparator to provide enough gain.

### 15.3 Function Description

In RV1109/RV1126, SAR-ADC works at single-sample operation mode.

This mode is useful to sample an analog input when there is a gap between two samples to be converted. In this mode START is asserted only on the rising edge of CLKIN where conversion is needed. At the end of every conversion EOC signal is made high and valid output data is available at the rising edge of EOC. The detailed timing diagram will be shown in the following.

### 15.4 Register Description

#### 15.4.1 Registers Summary

| Name              | Offset | Size | Reset Value | Description                              |
|-------------------|--------|------|-------------|------------------------------------------|
| SARADC DATA       | 0x0000 | W    | 0x00000000  | Data after A/D Conversion                |
| SARADC STAS       | 0x0004 | W    | 0x00000000  | Status Register of A/D Converter         |
| SARADC CTRL       | 0x0008 | W    | 0x00000000  | Control Register of A/D Converter        |
| SARADC DLY PU SOC | 0x000C | W    | 0x00000000  | Delay between Power Up and Start Command |

Notes: **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 Register Description

##### SARADC DATA

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                        |
|------------|-------------|--------------------|-----------------------------------------------------------|
| 31:10      | RO          | 0x0000000          | reserved                                                  |
| 9:0        | RW          | 0x000              | adc_data<br>A/D value of the last conversion (DOUT[9:0]). |

**SARADC STAS**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:1       | RO          | 0x000000000        | reserved                                                                          |
| 0          | RW          | 0x0                | adc_status<br>ADC status (EOC).<br>1'b0: ADC stop<br>1'b1: Conversion in progress |

**SARADC CTRL**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                      |
| 6          | RW          | 0x0                | int_status<br>Interrupt status.<br>This bit will be set to 1 when end-of-conversion.<br>Set 0 to clear the interrupt.                                                                                                                                                                                                                         |
| 5          | RW          | 0x0                | int_en<br>Interrupt enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                                  |
| 4          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                      |
| 3          | RW          | 0x0                | adc_power_ctrl<br>ADC power down control bit.<br>1'b0: ADC power down<br>1'b1: ADC power up and reset<br>Start signal will be asserted (DLY_PU_SOC + 2) sclk clock period later after power up.                                                                                                                                               |
| 2:0        | RW          | 0x0                | adc_input_src_sel<br>ADC input source selection(CH_SEL[2:0]).<br>3'b000: Input source 0 (SARADC_AIN[0])<br>3'b001: Input source 1 (SARADC_AIN[1])<br>3'b010: Input source 2 (SARADC_AIN[2])<br>3'b011: Input source 3 (SARADC_AIN[3])<br>3'b100: Input source 4 (SARADC_AIN[4])<br>3'b101: Input source 5 (SARADC_AIN[5])<br>Others: Reserved |

**SARADC DLY PU SOC**

Address: Operational Base + offset (0x000C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0000000          | reserved                                                                                                                                              |
| 5:0        | RW          | 0x00               | dly_pu_soc<br>Delay between power up and start command.<br>The start signal will be asserted (dly_pu_soc + 2) sclk clock period later after power up. |

## 15.5 Timing Diagram



Fig. 15-2 SAR-ADC Timing Diagram in Single-sample Conversion Mode

The following table shows the detail value for timing parameters in the above diagram.

Table 15-1 SAR-ADC Timing Parameters List

| Parameter                            | Symbol             | Condition | Min   | Typ              | Max   | Unit             |
|--------------------------------------|--------------------|-----------|-------|------------------|-------|------------------|
| Operating Condition                  |                    |           |       |                  |       |                  |
| Analog Supply                        | AVDD               |           | 1.62  | 1.8              | 1.98  | V                |
| Digital Supply                       | VDD                |           | 0.72  | 0.8              | 0.88  | V                |
| Junction Temperature                 | T <sub>j</sub>     |           | -40   |                  | 125   | °C               |
| Saradc Performance                   |                    |           |       |                  |       |                  |
| Resolution                           |                    |           |       | 10               |       | bit              |
| Differential Non-linearity           | DNL                |           |       | ±1               |       | LSB              |
| Integral Non-linearity               | INL                |           |       | ±1.5             |       | LSB              |
| Input Voltage Range                  | V <sub>in</sub>    |           | 0.01* | V <sub>REF</sub> | 0.99* | V <sub>REF</sub> |
| Input Capacitance                    | C <sub>in</sub>    |           |       | 6                |       | pF               |
| Sampling Rate                        | f <sub>s</sub>     |           |       |                  | 1     | MS/s             |
| Timing Characteristic                |                    |           |       |                  |       |                  |
| Clock Frequency                      | f <sub>CLK</sub>   |           |       |                  | 12    | MHz              |
| Clock Period                         | t <sub>CLK</sub>   |           | 83.33 |                  |       | ns               |
| Conversion Time                      |                    |           | 12    |                  |       | t <sub>CLK</sub> |
| Setup Time of soc signal             | T <sub>s</sub>     |           | 0     |                  |       | ns               |
| Hold Time of soc signal              | T <sub>h</sub>     |           | 3     |                  |       | ns               |
| EOC delay from rising edge of CLK    | T <sub>d_EOC</sub> |           |       |                  | 10    | ns               |
| B[9:0] delay from rising edge of CLK | T <sub>d_B</sub>   |           |       |                  | 10    | ns               |

## 15.6 Application Notes

Steps of adc conversion:

- Write SARADC\_CTRL[3] as 0 to power down ADC converter.

- Write SARADC\_CTRL[2:0] as n to select ADC channel(n).
- Write SARADC\_CTRL[5] as 1 to enable ADC interrupt.
- Write SARADC\_CTRL[3] as 1 to power up ADC converter.
- Wait for ADC interrupt or poll SARADC\_STAS register to assert whether the conversion is completed.
- Read the conversion result from SARADC\_DATA[9:0].
- Note: The A/D converter was designed to operate at maximum 1MHz.

## Chapter 16 DMA Controller (DMAC)

### 16.1 Overview

This device supports 1 Direct Memory Access (DMA) Controller. It (DMAC) supports 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 27 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 16-1 DMAC Request Mapping Table

| Req number | Source   | Polarity   |
|------------|----------|------------|
| 0          | SPI0 RX  | High level |
| 1          | SPI0 TX  | High level |
| 2          | SPI1 RX  | High level |
| 3          | SPI1 TX  | High level |
| 4          | UART0 RX | High level |
| 5          | UART0 TX | High level |
| 6          | UART1 RX | High level |
| 7          | UART1 TX | High level |
| 8          | UART2 RX | High level |
| 9          | UART2 TX | High level |
| 10         | UART3 RX | High level |
| 11         | UART3 TX | High level |
| 12         | UART4 RX | High level |
| 13         | UART4 TX | High level |
| 14         | UART5 RX | High level |
| 15         | UART5 TX | High level |
| 16         | PWM0     | High level |
| 17         | PWM1     | High level |
| 18         | PWM2     | High level |
| 19         | I2S0 RX  | High level |
| 20         | I2S0 TX  | High level |
| 21         | I2S1 RX  | High level |
| 22         | I2S1 TX  | High level |
| 23         | I2S2 RX  | High level |
| 24         | I2S2 TX  | High level |
| 25         | PDM      | High level |
| 26         | AudioPWM | High level |

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

### 16.2 Block Diagram

Following figure shows the block diagram of DMAC.



Fig. 16-1 Block Diagram of DMAC

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

## 16.3 Function Description

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

### 16.3.2 Operating states

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



Fig. 16-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.

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

| <b>Name</b>       | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                     |
|-------------------|---------------|-------------|--------------------|----------------------------------------|
| <u>DMAC_FTR3</u>  | 0x004c        | W           | 0x00000000         | Fault Type DMA Channel 3 Register      |
| <u>DMAC_FTR4</u>  | 0x0050        | W           | 0x00000000         | Fault Type DMA Channel 4 Register      |
| <u>DMAC_FTR5</u>  | 0x0054        | W           | 0x00000000         | Fault Type DMA Channel 5 Register      |
| <u>DMAC_FTR6</u>  | 0x0058        | W           | 0x00000000         | Fault Type DMA Channel 6 Register      |
| <u>DMAC_FTR7</u>  | 0x005c        | W           | 0x00000000         | Fault Type DMA Channel 7 Register      |
| <u>DMAC_CSR0</u>  | 0x0100        | W           | 0x00000000         | Channel 0 Status Register              |
| <u>DMAC_CPC0</u>  | 0x0104        | W           | 0x00000000         | Channel 0 Program Counter Register     |
| <u>DMAC_CSR1</u>  | 0x0108        | W           | 0x00000000         | Channel 1 Status Register              |
| <u>DMAC_CPC1</u>  | 0x010c        | W           | 0x00000000         | Channel 1 Program Counter Register     |
| <u>DMAC_CSR2</u>  | 0x0110        | W           | 0x00000000         | Channel 2 Status Register              |
| <u>DMAC_CPC2</u>  | 0x0114        | W           | 0x00000000         | Channel 2 Program Counter Register     |
| <u>DMAC_CSR3</u>  | 0x0118        | W           | 0x00000000         | Channel 3 Status Register              |
| <u>DMAC_CPC3</u>  | 0x011c        | W           | 0x00000000         | Channel 3 Program Counter Register     |
| <u>DMAC_CSR4</u>  | 0x0120        | W           | 0x00000000         | Channel 4 Status Register              |
| <u>DMAC_CPC4</u>  | 0x0124        | W           | 0x00000000         | Channel 4 Program Counter Register     |
| <u>DMAC_CSR5</u>  | 0x0128        | W           | 0x00000000         | Channel 5 Status Register              |
| <u>DMAC_CPC5</u>  | 0x012c        | W           | 0x00000000         | Channel 5 Program Counter Register     |
| <u>DMAC_CSR6</u>  | 0x0130        | W           | 0x00000000         | Channel 6 Status Register              |
| <u>DMAC_CPC6</u>  | 0x0134        | W           | 0x00000000         | Channel 6 Program Counter Register     |
| <u>DMAC_CSR7</u>  | 0x0138        | W           | 0x00000000         | Channel 7 Status Register              |
| <u>DMAC_CPC7</u>  | 0x013c        | W           | 0x00000000         | Channel 7 Program Counter Register     |
| <u>DMAC_SAR0</u>  | 0x0400        | W           | 0x00000000         | Channel 0 Source Address Register      |
| <u>DMAC_DAR0</u>  | 0x0404        | W           | 0x00000000         | Channel 0 Destination Address Register |
| <u>DMAC_CCR0</u>  | 0x0408        | W           | 0x00000000         | Channel 0 Channel Control Register     |
| <u>DMAC_LC0_0</u> | 0x040c        | W           | 0x00000000         | Channel 0 Loop Counter 0 Register      |

| <b>Name</b>       | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                     |
|-------------------|---------------|-------------|--------------------|----------------------------------------|
| <u>DMAC_LC1_0</u> | 0x0410        | W           | 0x00000000         | Channel 0 Loop Counter 1 Register      |
| <u>DMAC_SAR1</u>  | 0x0420        | W           | 0x00000000         | Channel 1 Source Address Register      |
| <u>DMAC_DAR1</u>  | 0x0424        | W           | 0x00000000         | Channel 1 Destination Address Register |
| <u>DMAC_CCR1</u>  | 0x0428        | W           | 0x00000000         | Channel 1 Channel Control Register     |
| <u>DMAC_LC0_1</u> | 0x042c        | W           | 0x00000000         | Channel 1 Loop Counter 0 Register      |
| <u>DMAC_LC1_1</u> | 0x0430        | W           | 0x00000000         | Channel 1 Loop Counter 1 Register      |
| <u>DMAC_SAR2</u>  | 0x0440        | W           | 0x00000000         | Channel 2 Source Address Register      |
| <u>DMAC_DAR2</u>  | 0x0444        | W           | 0x00000000         | Channel 2 Destination Address Register |
| <u>DMAC_CCR2</u>  | 0x0448        | W           | 0x00000000         | Channel 2 Channel Control Register     |
| <u>DMAC_LC0_2</u> | 0x044c        | W           | 0x00000000         | Channel 2 Loop Counter 0 Register      |
| <u>DMAC_LC1_2</u> | 0x0450        | W           | 0x00000000         | Channel 2 Loop Counter 1 Register      |
| <u>DMAC_SAR3</u>  | 0x0460        | W           | 0x00000000         | Channel 3 Source Address Register      |
| <u>DMAC_DAR3</u>  | 0x0464        | W           | 0x00000000         | Channel 3 Destination Address Register |
| <u>DMAC_CCR3</u>  | 0x0468        | W           | 0x00000000         | Channel 3 Channel Control Register     |
| <u>DMAC_LC0_3</u> | 0x046c        | W           | 0x00000000         | Channel 3 Loop Counter 0 Register      |
| <u>DMAC_LC1_3</u> | 0x0470        | W           | 0x00000000         | Channel 3 Loop Counter 1 Register      |
| <u>DMAC_SAR4</u>  | 0x0480        | W           | 0x00000000         | Channel 4 Address Register             |
| <u>DMAC_DAR4</u>  | 0x0484        | W           | 0x00000000         | Channel 4 Destination Address Register |
| <u>DMAC_CCR4</u>  | 0x0488        | W           | 0x00000000         | Channel 4 Channel Control Register     |
| <u>DMAC_LC0_4</u> | 0x048c        | W           | 0x00000000         | Channel 4 Loop Counter 0 Register      |
| <u>DMAC_LC1_4</u> | 0x0490        | W           | 0x00000000         | Channel 4 Loop Counter 1 Register      |
| <u>DMAC_SAR5</u>  | 0x04a0        | W           | 0x00000000         | Channel 5 Address Register             |

| Name           | Offset | Size | Reset Value | Description                            |
|----------------|--------|------|-------------|----------------------------------------|
| 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 | 0xd00  | W    | 0x00000000  | Debug Status Register                  |
| DMAC_DBGCMD    | 0xd04  | W    | 0x00000000  | Debug Command Register                 |
| DMAC_DBGINST0  | 0xd08  | W    | 0x00000000  | Debug Instruction-0 Register           |
| DMAC_DBGINST1  | 0xd0c  | W    | 0x00000000  | Debug Instruction-1 Register           |
| DMAC_CR0       | 0xe00  | W    | 0x001f3075  | Configuration Register 0               |
| DMAC_CR1       | 0xe04  | W    | 0x000000b5  | Configuration Register 1               |
| DMAC_CR2       | 0xe08  | W    | 0x00000000  | Configuration Register 2               |
| DMAC_CR3       | 0xe0c  | W    | 0x0000ffff  | Configuration Register 3               |
| DMAC_CR4       | 0xe10  | W    | 0x000fffff  | Configuration Register 4               |
| DMAC_CRDn      | 0xe14  | W    | 0x07ff7f73  | Configuration Register                 |
| DMAC_WD        | 0xe80  | W    | 0x00000000  | DMA Watchdog Register                  |

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

### 16.4.3 Detail Register Description

#### DMAC\_DSR

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

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

**DMAC\_INTEN**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| Bit  | Attr | Reset Value | Description                                                                                                                                    |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                              |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| Bit  | Attr | Reset Value | Description                                                                                                                  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| 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)

| Bit  | Attr | Reset Value | Description                                                                                                                                  |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                              |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                | <p>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.</p>                                                                                                                                               |
| 17         | RO          | 0x0                | <p>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.</p>                                                                                                                                             |
| 16         | RO          | 0x0                | <p>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.</p>                                                                                                                                       |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 13         | RO          | 0x0                | <p>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.</p>                                                                            |
| 12         | RO          | 0x0                | <p>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.</p>         |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 7          | RO          | 0x0                | <p>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | <p>ch_periph_err<br/>DMASTP, or DMAFLUSHP with inappropriate security permissions.</p> <p>1'b0: a DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: a DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFP to wait for a secure peripheral</li> <li>b. DMALDP or DMASTP to notify a secure peripheral</li> <li>c. DMAFLUSHP to flush a secure peripheral</li> </ul> <p>This fault is a precise abort.</p> |
| 5          | RO          | 0x0                | <p>ch_event_err<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFE to wait for a secure event</li> <li>b. DMASEV to create a secure event or secure interrupt</li> </ul> <p>This fault is a precise abort.</p>                                                                                                                          |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RO          | 0x0                | <p>operand_invalid<br/>Valid for the configuration of the DMAC.</p> <p>1'b0: Valid operand</p> <p>1'b1: Invalid operand</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RO          | 0x0                | <p>undef_instr<br/>1'b0: Defined instruction</p> <p>1'b1: Undefined instruction</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                                                         |

**DMAC FTR1**

Address: Operational Base + offset (0x0044)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | <p>lockup_err<br/>1'b0: DMA channel has adequate resources</p> <p>1'b1: DMA channel has locked-up because of insufficient resources</p> <p>This fault is an imprecise abort.</p>                                                                                                                                        |
| 30         | RO          | 0x0                | <p>dbg_instr<br/>Memory or from the debug interface.</p> <p>1'b0: Instruction that generated an abort was read from system memory</p> <p>1'b1: Instruction that generated an abort was read from the debug interface</p> <p>This fault is an imprecise abort but the bit is only valid when a precise abort occurs.</p> |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RO          | 0x0                | <p>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.</p>                                                                                                                                               |
| 17         | RO          | 0x0                | <p>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.</p>                                                                                                                                             |
| 16         | RO          | 0x0                | <p>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.</p>                                                                                                                                       |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 13         | RO          | 0x0                | <p>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.</p>                                                                            |
| 12         | RO          | 0x0                | <p>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.</p>         |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 7          | RO          | 0x0                | <p>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | <p>ch_periph_err<br/>DMASTP, or DMAFLUSHP with inappropriate security permissions.</p> <p>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFP to wait for a secure peripheral</li> <li>b. DMALDP or DMASTP to notify a secure peripheral</li> <li>c. DMAFLUSHP to flush a secure peripheral</li> </ul> <p>This fault is a precise abort.</p> |
| 5          | RO          | 0x0                | <p>ch_event_err<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFE to wait for a secure event</li> <li>b. DMASEV to create a secure event or secure interrupt</li> </ul> <p>This fault is a precise abort.</p>                                                                                                                          |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RO          | 0x0                | <p>operand_invalid<br/>Valid for the configuration of the DMAC.</p> <p>1'b0: Valid operand</p> <p>1'b1: Invalid operand</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RO          | 0x0                | <p>undef_instr<br/>1'b0: Defined instruction</p> <p>1'b1: Undefined instruction</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                                                         |

**DMAC FTR2**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | <p>lockup_err<br/>1'b0: DMA channel has adequate resources</p> <p>1'b1: DMA channel has locked-up because of insufficient resources</p> <p>This fault is an imprecise abort.</p>                                                                                                                                        |
| 30         | RO          | 0x0                | <p>dbg_instr<br/>Memory or from the debug interface.</p> <p>1'b0: Instruction that generated an abort was read from system memory</p> <p>1'b1: Instruction that generated an abort was read from the debug interface</p> <p>This fault is an imprecise abort but the bit is only valid when a precise abort occurs.</p> |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RO          | 0x0                | <p>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.</p>                                                                                                                                               |
| 17         | RO          | 0x0                | <p>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.</p>                                                                                                                                             |
| 16         | RO          | 0x0                | <p>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.</p>                                                                                                                                       |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 13         | RO          | 0x0                | <p>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.</p>                                                                            |
| 12         | RO          | 0x0                | <p>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.</p>         |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 7          | RO          | 0x0                | <p>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | <p>ch_periph_err<br/>DMASTP, or DMAFLUSHP with inappropriate security permissions.</p> <p>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFP to wait for a secure peripheral</li> <li>b. DMALDP or DMASTP to notify a secure peripheral</li> <li>c. DMAFLUSHP to flush a secure peripheral</li> </ul> <p>This fault is a precise abort.</p> |
| 5          | RO          | 0x0                | <p>ch_event_err<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFE to wait for a secure event</li> <li>b. DMASEV to create a secure event or secure interrupt</li> </ul> <p>This fault is a precise abort.</p>                                                                                                                          |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RO          | 0x0                | <p>operand_invalid<br/>Valid for the configuration of the DMAC.</p> <p>1'b0: Valid operand</p> <p>1'b1: Invalid operand</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RO          | 0x0                | <p>undef_instr<br/>1'b0: Defined instruction</p> <p>1'b1: Undefined instruction</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                                                         |

**DMAC\_FTR3**

Address: Operational Base + offset (0x004c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | <p>lockup_err<br/>1'b0: DMA channel has adequate resources</p> <p>1'b1: DMA channel has locked-up because of insufficient resources</p> <p>This fault is an imprecise abort.</p>                                                                                                                                        |
| 30         | RO          | 0x0                | <p>dbg_instr<br/>Memory or from the debug interface.</p> <p>1'b0: Instruction that generated an abort was read from system memory</p> <p>1'b1: Instruction that generated an abort was read from the debug interface</p> <p>This fault is an imprecise abort but the bit is only valid when a precise abort occurs.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 18         | RO          | 0x0                | <p>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.</p>                                                                                                                                               |
| 17         | RO          | 0x0                | <p>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.</p>                                                                                                                                             |
| 16         | RO          | 0x0                | <p>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.</p>                                                                                                                                       |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 13         | RO          | 0x0                | <p>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.</p>                                                                            |
| 12         | RO          | 0x0                | <p>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.</p>         |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 7          | RO          | 0x0                | <p>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | <p>ch_periph_err<br/>DMASTP, or DMAFLUSHP with inappropriate security permissions.</p> <p>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFP to wait for a secure peripheral</li> <li>b. DMALDP or DMASTP to notify a secure peripheral</li> <li>c. DMAFLUSHP to flush a secure peripheral</li> </ul> <p>This fault is a precise abort.</p> |
| 5          | RO          | 0x0                | <p>ch_event_err<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFE to wait for a secure event</li> <li>b. DMASEV to create a secure event or secure interrupt</li> </ul> <p>This fault is a precise abort.</p>                                                                                                                          |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RO          | 0x0                | <p>operand_invalid<br/>Valid for the configuration of the DMAC.</p> <p>1'b0: Valid operand</p> <p>1'b1: Invalid operand</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RO          | 0x0                | <p>undef_instr<br/>1'b0: Defined instruction</p> <p>1'b1: Undefined instruction</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                                                         |

**DMAC FTR4**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | <p>lockup_err<br/>1'b0: DMA channel has adequate resources</p> <p>1'b1: DMA channel has locked-up because of insufficient resources</p> <p>This fault is an imprecise abort.</p>                                                                                                                                        |
| 30         | RO          | 0x0                | <p>dbg_instr<br/>Memory or from the debug interface.</p> <p>1'b0: Instruction that generated an abort was read from system memory</p> <p>1'b1: Instruction that generated an abort was read from the debug interface</p> <p>This fault is an imprecise abort but the bit is only valid when a precise abort occurs.</p> |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RO          | 0x0                | <p>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.</p>                                                                                                                                               |
| 17         | RO          | 0x0                | <p>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.</p>                                                                                                                                             |
| 16         | RO          | 0x0                | <p>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.</p>                                                                                                                                       |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 13         | RO          | 0x0                | <p>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.</p>                                                                            |
| 12         | RO          | 0x0                | <p>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.</p>         |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 7          | RO          | 0x0                | <p>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | <p>ch_periph_err<br/>DMASTP, or DMAFLUSHP with inappropriate security permissions.</p> <p>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFP to wait for a secure peripheral</li> <li>b. DMALDP or DMASTP to notify a secure peripheral</li> <li>c. DMAFLUSHP to flush a secure peripheral</li> </ul> <p>This fault is a precise abort.</p> |
| 5          | RO          | 0x0                | <p>ch_event_err<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFE to wait for a secure event</li> <li>b. DMASEV to create a secure event or secure interrupt</li> </ul> <p>This fault is a precise abort.</p>                                                                                                                          |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RO          | 0x0                | <p>operand_invalid<br/>Valid for the configuration of the DMAC.</p> <p>1'b0: Valid operand</p> <p>1'b1: Invalid operand</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RO          | 0x0                | <p>undef_instr<br/>1'b0: Defined instruction</p> <p>1'b1: Undefined instruction</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                                                         |

**DMAC FTR5**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | <p>lockup_err<br/>1'b0: DMA channel has adequate resources</p> <p>1'b1: DMA channel has locked-up because of insufficient resources</p> <p>This fault is an imprecise abort.</p>                                                                                                                                        |
| 30         | RO          | 0x0                | <p>dbg_instr<br/>Memory or from the debug interface.</p> <p>1'b0: Instruction that generated an abort was read from system memory</p> <p>1'b1: Instruction that generated an abort was read from the debug interface</p> <p>This fault is an imprecise abort but the bit is only valid when a precise abort occurs.</p> |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RO          | 0x0                | <p>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.</p>                                                                                                                                               |
| 17         | RO          | 0x0                | <p>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.</p>                                                                                                                                             |
| 16         | RO          | 0x0                | <p>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.</p>                                                                                                                                       |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 13         | RO          | 0x0                | <p>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.</p>                                                                            |
| 12         | RO          | 0x0                | <p>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.</p>         |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 7          | RO          | 0x0                | <p>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | <p>ch_periph_err<br/>DMASTP, or DMAFLUSHP with inappropriate security permissions.</p> <p>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFP to wait for a secure peripheral</li> <li>b. DMALDP or DMASTP to notify a secure peripheral</li> <li>c. DMAFLUSHP to flush a secure peripheral</li> </ul> <p>This fault is a precise abort.</p> |
| 5          | RO          | 0x0                | <p>ch_event_err<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFE to wait for a secure event</li> <li>b. DMASEV to create a secure event or secure interrupt</li> </ul> <p>This fault is a precise abort.</p>                                                                                                                          |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RO          | 0x0                | <p>operand_invalid<br/>Valid for the configuration of the DMAC.</p> <p>1'b0: Valid operand</p> <p>1'b1: Invalid operand</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RO          | 0x0                | <p>undef_instr<br/>1'b0: Defined instruction</p> <p>1'b1: Undefined instruction</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                                                         |

**DMAC FTR6**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | <p>lockup_err<br/>1'b0: DMA channel has adequate resources</p> <p>1'b1: DMA channel has locked-up because of insufficient resources</p> <p>This fault is an imprecise abort.</p>                                                                                                                                        |
| 30         | RO          | 0x0                | <p>dbg_instr<br/>Memory or from the debug interface.</p> <p>1'b0: Instruction that generated an abort was read from system memory</p> <p>1'b1: Instruction that generated an abort was read from the debug interface</p> <p>This fault is an imprecise abort but the bit is only valid when a precise abort occurs.</p> |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RO          | 0x0                | <p>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.</p>                                                                                                                                               |
| 17         | RO          | 0x0                | <p>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.</p>                                                                                                                                             |
| 16         | RO          | 0x0                | <p>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.</p>                                                                                                                                       |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 13         | RO          | 0x0                | <p>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.</p>                                                                            |
| 12         | RO          | 0x0                | <p>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.</p>         |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 7          | RO          | 0x0                | <p>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | <p>ch_periph_err<br/>DMASTP, or DMAFLUSHP with inappropriate security permissions.</p> <p>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFP to wait for a secure peripheral</li> <li>b. DMALDP or DMASTP to notify a secure peripheral</li> <li>c. DMAFLUSHP to flush a secure peripheral</li> </ul> <p>This fault is a precise abort.</p> |
| 5          | RO          | 0x0                | <p>ch_event_err<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFE to wait for a secure event</li> <li>b. DMASEV to create a secure event or secure interrupt</li> </ul> <p>This fault is a precise abort.</p>                                                                                                                          |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RO          | 0x0                | <p>operand_invalid<br/>Valid for the configuration of the DMAC.</p> <p>1'b0: Valid operand</p> <p>1'b1: Invalid operand</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RO          | 0x0                | <p>undef_instr<br/>1'b0: Defined instruction</p> <p>1'b1: Undefined instruction</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                                                         |

**DMAC FTR7**

Address: Operational Base + offset (0x005c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | <p>lockup_err<br/>1'b0: DMA channel has adequate resources</p> <p>1'b1: DMA channel has locked-up because of insufficient resources</p> <p>This fault is an imprecise abort.</p>                                                                                                                                        |
| 30         | RO          | 0x0                | <p>dbg_instr<br/>Memory or from the debug interface.</p> <p>1'b0: Instruction that generated an abort was read from system memory</p> <p>1'b1: Instruction that generated an abort was read from the debug interface</p> <p>This fault is an imprecise abort but the bit is only valid when a precise abort occurs.</p> |
| 29:19      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RO          | 0x0                | <p>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.</p>                                                                                                                                               |
| 17         | RO          | 0x0                | <p>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.</p>                                                                                                                                             |
| 16         | RO          | 0x0                | <p>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.</p>                                                                                                                                       |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 13         | RO          | 0x0                | <p>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.</p>                                                                            |
| 12         | RO          | 0x0                | <p>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.</p>         |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                       |
| 7          | RO          | 0x0                | <p>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.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x0                | <p>ch_periph_err<br/>DMASTP, or DMAFLUSHP with inappropriate security permissions.</p> <p>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFP to wait for a secure peripheral</li> <li>b. DMALDP or DMASTP to notify a secure peripheral</li> <li>c. DMAFLUSHP to flush a secure peripheral</li> </ul> <p>This fault is a precise abort.</p> |
| 5          | RO          | 0x0                | <p>ch_event_err<br/>1'b0: A DMA channel thread in the Non-secure state is not violating the security permissions</p> <p>1'b1: A DMA channel thread in the Non-secure state attempted to execute either:</p> <ul style="list-style-type: none"> <li>a. DMAWFE to wait for a secure event</li> <li>b. DMASEV to create a secure event or secure interrupt</li> </ul> <p>This fault is a precise abort.</p>                                                                                                                          |
| 4:2        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1          | RO          | 0x0                | <p>operand_invalid<br/>Valid for the configuration of the DMAC.</p> <p>1'b0: Valid operand</p> <p>1'b1: Invalid operand</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                 |
| 0          | RO          | 0x0                | <p>undef_instr<br/>1'b0: Defined instruction</p> <p>1'b1: Undefined instruction</p> <p>This fault is a precise abort.</p>                                                                                                                                                                                                                                                                                                                                                                                                         |

**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                | <p>cns<br/>1'b0: DMA channel operates in the Secure state</p> <p>1'b1: DMA channel operates in the Non-secure state</p>                 |
| 20:16      | RO          | 0x0                | reserved                                                                                                                                |
| 15         | RO          | 0x0                | <p>dmawfp_periph<br/>1'b0: DMAWFP executed with the periph operand not set</p> <p>1'b1: DMAWFP executed with the periph operand set</p> |
| 14         | RO          | 0x0                | <p>dmawfp_b_ns<br/>1'b0: DMAWFP executed with the single operand set</p> <p>1'b1: DMAWFP executed with the burst operand set</p>        |
| 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                                                                                                                    |

| <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 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                                                                                                                    |

| <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 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                                                                                                                    |

| <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 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                                                                                                                    |

| <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 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                                                                                                                    |

| <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 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                                                                                                                    |

| <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 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                                                                                                                    |

| <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 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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:25      | RO          | 0x0                | <p>dst_cache_ctrl</p> <p>Bit [27]</p> <p>1'b0: AWCACHE[3] is LOW<br/>1'b1: AWCACHE[3] is HIGH</p> <p>Bit [26]</p> <p>1'b0: AWCACHE[1] is LOW<br/>1'b1: AWCACHE[1] is HIGH</p> <p>Bit [25]</p> <p>1'b0: AWCACHE[0] is LOW<br/>1'b1: AWCACHE[0] is HIGH</p>                                                                                                                                  |
| 24:22      | RO          | 0x0                | <p>dst_prot_ctrl</p> <p>Bit [24]</p> <p>1'b0: AWPROT[2] is LOW<br/>1'b1: AWPROT[2] is HIGH</p> <p>Bit [23]</p> <p>1'b0: AWPROT[1] is LOW<br/>1'b1: AWPROT[1] is HIGH</p> <p>Bit [22]</p> <p>1'b0: AWPROT[0] is LOW<br/>1'b1: AWPROT[0] is HIGH</p>                                                                                                                                         |
| 21:18      | RO          | 0x0                | <p>dst_burst_len</p> <p>the destination data:</p> <p>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</p> <p>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</p> <p>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</p> <p>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br/>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.</p>                                                                                                                                                                                                                                  |

| <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\_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                                                                                                                                                                                                                |
| 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>                                                                                                                                                       |

| <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\_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               | <p>loop_counter_iterations<br/>Loop counter 0 iterations</p> |

**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               | <p>loop_counter_iterations<br/>Loop counter 1 iterations</p> |

**DMAC SAR2**

Address: Operational Base + offset (0x0440)

| <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 2</p> |

**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. |

| <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</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\_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               | <p>loop_counter_iterations<br/>Loop counter 0 iterations</p> |

**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               | <p>loop_counter_iterations<br/>Loop counter 1 iterations</p> |

**DMAC SAR3**

Address: Operational Base + offset (0x0460)

| <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 3</p> |

**DMAC DAR3**

Address: Operational Base + offset (0x0464)

| <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 3</p> |

**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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:25      | RO          | 0x0                | <p>dst_cache_ctrl</p> <p>Bit [27]</p> <p>1'b0: AWCACHE[3] is LOW<br/>1'b1: AWCACHE[3] is HIGH</p> <p>Bit [26]</p> <p>1'b0: AWCACHE[1] is LOW<br/>1'b1: AWCACHE[1] is HIGH</p> <p>Bit [25]</p> <p>1'b0: AWCACHE[0] is LOW<br/>1'b1: AWCACHE[0] is HIGH</p>                                                                                                                                  |
| 24:22      | RO          | 0x0                | <p>dst_prot_ctrl</p> <p>Bit [24]</p> <p>1'b0: AWPROT[2] is LOW<br/>1'b1: AWPROT[2] is HIGH</p> <p>Bit [23]</p> <p>1'b0: AWPROT[1] is LOW<br/>1'b1: AWPROT[1] is HIGH</p> <p>Bit [22]</p> <p>1'b0: AWPROT[0] is LOW<br/>1'b1: AWPROT[0] is HIGH</p>                                                                                                                                         |
| 21:18      | RO          | 0x0                | <p>dst_burst_len</p> <p>the destination data:</p> <p>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</p> <p>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</p> <p>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</p> <p>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br/>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.</p>                                                                                                                                                                                                                                  |

| <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\_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>                                                                                                                                                       |

| <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 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 SARS**

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 DARS**

Address: Operational Base + offset (0x04a4)

| <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 5 |

**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                | 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</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 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               | <p>loop_counter_iterations<br/>           Loop counter 0 iterations</p> |

**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               | <p>loop_counter_iterations<br/>           Loop counter 1 iterations</p> |

**DMAC SAR6**

Address: Operational Base + offset (0x04c0)

| <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 6</p> |

**DMAC DAR6**

Address: Operational Base + offset (0x04c4)

| <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 6</p> |

**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                | <p>dst_cache_ctrl</p> <p>Bit [27]</p> <p>1'b0: AWCACHE[3] is LOW<br/>1'b1: AWCACHE[3] is HIGH</p> <p>Bit [26]</p> <p>1'b0: AWCACHE[1] is LOW<br/>1'b1: AWCACHE[1] is HIGH</p> <p>Bit [25]</p> <p>1'b0: AWCACHE[0] is LOW<br/>1'b1: AWCACHE[0] is HIGH</p>                                                                                                                                  |
| 24:22      | RO          | 0x0                | <p>dst_prot_ctrl</p> <p>Bit [24]</p> <p>1'b0: AWPROT[2] is LOW<br/>1'b1: AWPROT[2] is HIGH</p> <p>Bit [23]</p> <p>1'b0: AWPROT[1] is LOW<br/>1'b1: AWPROT[1] is HIGH</p> <p>Bit [22]</p> <p>1'b0: AWPROT[0] is LOW<br/>1'b1: AWPROT[0] is HIGH</p>                                                                                                                                         |
| 21:18      | RO          | 0x0                | <p>dst_burst_len</p> <p>the destination data:</p> <p>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</p> <p>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</p> <p>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</p> <p>1'b0: Fixed-address burst. The DMAC signals AWBURST[0] LOW.<br/>1'b1: Incrementing-address burst. The DMAC signals AWBURST[0] HIGH.</p>                                                                                                                                                                                                                                  |

| <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\_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        |

| <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>                                                                                                                                                       |

| <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 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               | <p>loop_counter_iterations<br/>Loop counter 0 iterations</p> |

**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               | <p>loop_counter_iterations<br/>Loop counter 1 iterations</p> |

**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                | <p>dbgstatus<br/>1'b0: Idle<br/>1'b1: Busy</p> |

**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]<br>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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------|
| 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'b0000000000: 1 line<br>10'b0000000001: 2 lines<br>...<br>10'b1111111111: 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                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------|
| 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                                                                             |
| 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 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 |

**16.5 Timing Diagram**

Following picture shows the relationship between dma\_req and dma\_ack.



Fig. 16-3 DMAC Request and Acknowledge Timing

**16.6 Interface Description**

DMAC has the following tie-off signals. It can be configured by SGRF register. (Please refer to the SGRF chapter to find them)

Table 16-2 DMAC Boot Interface

| <b>Interface</b>    | <b>Reset Value</b> | <b>Control Source</b>                        |
|---------------------|--------------------|----------------------------------------------|
| boot_manager_ns     | 0x1                | SGRF_DMAC_CON3[0]                            |
| boot_irq_ns         | 0xFFFF             | SGRF_DMAC_CON0[15:0]                         |
| boot_periph_ns      | 0xFFFFFFFF         | {SGRF_DMAC_CON2[15:0], SGRF_DMAC_CON1[15:0]} |
| grf_drtype_spi0_rx  | 0x1                | SGRF_DMAC_CON4[1:0]                          |
| grf_drtype_spi0_tx  | 0x1                | SGRF_DMAC_CON4[3:2]                          |
| grf_drtype_spi1_rx  | 0x1                | SGRF_DMAC_CON4[5:4]                          |
| grf_drtype_spi1_tx  | 0x1                | SGRF_DMAC_CON4[7:6]                          |
| grf_drtype_uart0_rx | 0x1                | SGRF_DMAC_CON4[9:8]                          |
| grf_drtype_uart0_tx | 0x1                | SGRF_DMAC_CON4[11:10]                        |
| grf_drtype_uart1_rx | 0x1                | SGRF_DMAC_CON4[13:12]                        |
| grf_drtype_uart1_tx | 0x1                | SGRF_DMAC_CON4[15:14]                        |
| grf_drtype_uart2_rx | 0x1                | SGRF_DMAC_CON5[1:0]                          |
| grf_drtype_uart2_tx | 0x1                | SGRF_DMAC_CON5[3:2]                          |
| grf_drtype_uart3_rx | 0x1                | SGRF_DMAC_CON5[5:4]                          |
| grf_drtype_uart3_tx | 0x1                | SGRF_DMAC_CON5[7:6]                          |
| grf_drtype_uart4_rx | 0x1                | SGRF_DMAC_CON5[9:8]                          |
| grf_drtype_uart4_tx | 0x1                | SGRF_DMAC_CON5[11:10]                        |
| grf_drtype_uart5_rx | 0x1                | SGRF_DMAC_CON5[13:12]                        |
| grf_drtype_uart5_tx | 0x1                | SGRF_DMAC_CON5[15:14]                        |
| grf_drtype_pwm0     | 0x1                | SGRF_DMAC_CON6[1:0]                          |
| grf_drtype_pwm1     | 0x1                | SGRF_DMAC_CON6[3:2]                          |
| grf_drtype_pwm2     | 0x1                | SGRF_DMAC_CON6[5:4]                          |
| grf_drtype_i2s0_rx  | 0x1                | SGRF_DMAC_CON6[7:6]                          |
| grf_drtype_i2s0_tx  | 0x1                | SGRF_DMAC_CON6[9:8]                          |
| grf_drtype_i2s1_rx  | 0x1                | SGRF_DMAC_CON6[11:10]                        |
| grf_drtype_i2s1_tx  | 0x1                | SGRF_DMAC_CON6[13:12]                        |
| grf_drtype_i2s2_rx  | 0x1                | SGRF_DMAC_CON6[15:14]                        |
| grf_drtype_i2s2_tx  | 0x1                | SGRF_DMAC_CON7[1:0]                          |
| grf_drtype_pdm      | 0x1                | SGRF_DMAC_CON7[3:2]                          |
| grf_drtype_audiopwm | 0x1                | SGRF_DMAC_CON7[5:4]                          |

**boot\_manager\_ns**

When the DMAC exits from reset, this signal controls the security state of the DMA manager thread:

0 = assigns DMA manager to the Secure state

1 = assigns DMA manager to the Non-secure state.

**boot\_irq\_ns**

Controls the security state of an event-interrupt resource, when the DMAC exits from reset:

boot\_irq\_ns[x] is LOW

The DMAC assigns event<x> or irq[x] to the Secure state.

boot\_irq\_ns[x] is HIGH

The DMAC assigns event<x> or irq[x] to the Non-secure state.

**boot\_periph\_ns**

Controls the security state of a peripheral request interface, when the DMAC exits from reset:

boot\_periph\_ns[x] is LOW

The DMAC assigns peripheral request interface x to the Secure state.

boot\_periph\_ns[x] is HIGH

The DMAC assigns peripheral request interface x to the Non-secure state.

**grf\_drtype\_<x>**

The DMAC sets the state of the request\_type flag:

grf\_drtype\_<x>[1:0]=b00: request\_type<x> = Single.

grf\_drtype\_<x>[1:0]=b01: request\_type<x> = Burst.

## 16.7 Application Notes

### 16.7.1 Using the APB Slave Interfaces

You must ensure that you use the appropriate APB interface, depending on the security state in which the boot\_manager\_ns initializes the DMAC to operate. For example, if the DMAC is in the secure state, you must issue the instruction using the secure APB interface, otherwise the DMAC ignores the instruction. You can use the secure APB interface, or the non-secure APB interface, to start or restart a DMA channel when the DMAC is in the Non-secure state. The necessary steps to start a DMA channel thread using the debug instruction registers as following:

1. Create a program for the DMA channel.
2. Store the program in a region of system memory.
3. Poll the 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.

### 16.7.2 Security Usage

#### DMA manager thread is in the secure state

If the DNS bit is 0, the DMA manager thread operates in the secure state and it only performs secure instruction fetches. When a DMA manager thread in the secure state processes:

**DMAGO**

It uses the status of the ns bit, to set the security state of the DMA channel thread by writing to the CNS bit for that channel.

**DMAWFE**

It halts execution of the thread until the event occurs. When the event occurs, the DMAC continues execution of the thread, irrespective of the security state of the corresponding INS bit.

**DMASEV**

It sets the corresponding bit in the INT\_EVENT\_RIS Register, irrespective of the security state of the corresponding INS bit.

#### DMA manager thread is in the Non-secure state

If the DNS bit is 1, the DMA manager thread operates in the Non-secure state, and it only performs non-secure instruction fetches. When a DMA manager thread in the Non-secure state processes:

**DMAGO**

The DMAC uses the status of the ns bit, to control if it starts a DMA channel thread. If:

ns = 0

The DMAC does not start a DMA channel thread and instead it:

1. Executes a NOP.
2. Sets the 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.

### **16.7.3 Programming Restrictions**

#### **Fixed unaligned bursts**

The DMAC does not support fixed unaligned bursts. If you program the following conditions, the DMAC treats this as a programming error:

Unaligned read

- src\_inc field is 0 in the 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.

### **16.7.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 16-3 Source Size in DMAC\_CCRn

| Source size in<br>DMAC_CCRn | Allowed offset between DMAC_SARn and<br>DMAC_DARn |
|-----------------------------|---------------------------------------------------|
| SS8                         | any offset allowed.                               |
| SS16                        | 0,2,4,6,8,10,12,14                                |
| SS32                        | 0,4,8,12                                          |
| SS64                        | 0,8                                               |

#### **16.7.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

#### **16.7.6 Instruction Sets**

Table 16-4 DMAC Instruction Sets

| Mnemonic | Instruction  | Thread Usage |
|----------|--------------|--------------|
| 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

### 16.7.7 Assembler Directives

In this document, only DMMADNH instruction is took as an example to show the way the instruction assembled. For the other instructions, please refer to pl330\_trm.pdf.

#### DMAADNH

Add Negative Halfword adds an immediate negative 16-bit value to the 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 16-5 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 17 I2S\_TDM

### 17.1 Overview

The I2S/PCM/TDM controller is designed for interfacing between the AHB bus and the I2S bus.

The I2S bus (Inter-IC sound bus) is a serial link for digital audio data transfer between devices in the system and is invented by Philips Semiconductor. Now it is widely used by many semiconductor manufacturers.

I2S bus is widely used in the devices such as ADC, DAC, DSP, CPU, etc. With the I2S interface, we can connect audio devices and the embedded SoC platform together and provide an audio interface solution for the system.

#### 17.1.1 Features

There is one I2S/PCM/TDM controller and two I2S/PCM controllers embed in the system. These three controllers are named as I2S0, I2S1 and I2S2. The I2S0 supports I2S, PCM and TDM mode while the I2S1 or I2S2 supports I2S and PCM mode stereo audio output and input. Unless stated separately, all of the following features apply to I2S0, I2S1 and I2S2.

- Support eight internal 32-bit wide and 32-location deep FIFOs, four for transmitting and the others for receiving audio data for I2S0
- Support two internal 32-bit wide and 32-location deep FIFOs, one for transmitting and the other for receiving audio data for each I2S1 and I2S2
- 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 a total of 10 channels transmitting and receiving in I2S mode at the same time for I2S0
- Support 2-channel audio transmitting and receiving in PCM mode for I2S0
- Support 2-channel audio receiving in I2S mode and 2 channel in PCM mode for I2S1
- Support 2-channel audio transmitting in I2S mode and 2-channel in PCM mode for I2S2
- Support up to 192kHz sample rate
- Support I2S normal, left and right justified mode serial audio data transfer
- Support PCM early, late1, late2, late3 mode serial audio data transfer
- Support TDM normal, 1/2 cycle left shift , 1 cycle left shift, 2 cycle left shift, right shift mode serial audio data transfer for I2S0
- Support MSB or LSB first serial audio data transfer
- Support 16 to 31 bit audio data left or right justified in 32-bit wide FIFO
- Support two 16-bit audio data store together in one 32-bit wide location
- Support 2 independent LRCK signals, one for receiving and the other for transmitting audio data. Single LRCK can be used for transmitting and receiving data if the sample rate are the same
- Support configurable SCLK and LRCK polarity
- Support a range of 16 to 32 programmable slot bit width in TDM mode for I2S0
- Support a range of 32 to 512 programmable frame width in TDM mode for I2S0
- Support programmable FSYNC width in TDM mode for I2S0

## 17.2 Controller Block Diagram



Fig.17-1 I2S/PCM/TDM Controller (8-channel) Block Diagram



Fig.17-2 I2S/PCM Controller (2-channel) Block Diagram

### System Interface

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

### Clock Generator

The Clock Generator implements clock generation function. By the divider of the module, the clock generator generates SCLK and LRCK to transmitter and receiver.

### Transmitters

The Transmitters implement transmission operation. The transmitters can act as either a master or a slave, with I2S, PCM or TDM mode surround serial audio interface.

### Receiver

The Receiver implements receive operation. The receiver can act as either a master or a slave, with I2S, PCM or TDM mode stereo serial audio interface.

### Transmit FIFO

The Transmit FIFO is the buffer to store transmitted audio data. The size of one FIFO is 32bits x 32.

### Receive FIFO

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

### 17.3 Function description

In the I2S/PCM/TDM or I2S/PCM controller, there are four types: transmitter-master & receiver-master; transmitter-master & receiver-slave; transmitter-slave & receiver-master; transmitter-slave & receiver-slave.

In broadcasting application, the I2S/PCM/TDM or I2S/PCM controller is used as a transmitter and external or internal audio CODEC is used as a receiver. In recording application, the I2S/PCM/TDM or I2S/PCM controller is used as a receiver and external or internal audio CODEC is used as a transmitter. Either the I2S/PCM/TDM or I2S/PCM controller or the audio CODEC can act as a master or a slave, but if one is master, the other must be slave.



Fig.17-3 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 17-4 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.

### **17.3.1 T2S Normal Mode**

This is the waveform of I2S normal mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes low to indicate left channel and high to right channel. For SD (i2s\_sdo, i2s\_sdi) signal, it starts sending the first bit (MSB or LSB) one SCLK clock cycle after LRCK changes. The range of SD signal width is from 16 to 32bits.



Fig.17-5 I2S Normal Mode Timing Format

### **17.3.2 I2S Left Justified Mode**

This is the waveform of I2S left justified mode. For LRCK (`i2s_lrck_rx` / `i2s_lrck_tx`) signal, it goes high to indicate left channel and low to right channel. For SD (`i2s_sdo`, `i2s_sdi`) signal, it starts sending the first bit (MSB or LSB) at the same time when LRCK changes. The range

of SD signal width is from 16 to 32bits.



Fig.17-6 I2S Left Justified Mode Timing Format

### 17.3.3 I2S Right Justified Mode

This is the waveform of I2S right justified mode. For LRCK (i2s\_lrck\_rx/ i2s\_lrck\_tx) signal, it goes high to indicate left channel and low to right channel. For SD (i2s\_sdo, i2s\_sdi) signal, it transfers MSB or LSB first; but what is different from I2S normal or left justified mode, the last bit of the transferred data is aligned to the transition edge of the LRCK signal while one bit is transferred at one SCLK cycle. The range of SD signal width is from 16 to 32bits.



Fig.17-7 I2S Right Justified Mode Timing Format

### 17.3.4 PCM Early Mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo, i2s\_sdi) signal, it sends the first bit (MSB or LSB) at the same time when LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig.17-8 PCM Early Mode Timing Format

### 17.3.5 PCM Late1 Mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo, i2s\_sdi) signal, it sends the first bit (MSB or LSB) one SCLK clock cycle after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig.17-9 PCM Late1 Mode Timing Format

### 17.3.6 PCM Late2 Mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo, i2s\_sdi) signal, it sends the first bit (MSB or LSB)two SCLK clock cycles after LRCK goes high. The range of SD

signal width is from 16 to 32bits.



Fig.17-10 PCM Late2 Mode Timing Format

### 17.3.7 PCM Late3 Mode

This is the waveform of PCM early mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo, i2s\_sdi) signal, it sends the first bit (MSB or LSB) three SCLK clock cycles after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig.17-11 PCM Late3 Mode Timing Format

### 17.3.8 TDM Normal Mode (PCM Format)

This is the waveform of TDM normal mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo, i2s\_sdi) signal, it sends the first bit (MSB or LSB) on the second falling edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig.17-12 TDM Normal Mode Timing Format (PCM Format)

### 17.3.9 TDM Left Shift Mode0 (PCM Format)

This is the waveform of PCM early mode. For LRCK (i2s\_lrck\_rx/i2s\_lrck\_tx) signal, it goes high to indicate the start of a group of audio channels. For SD (i2s\_sdo, i2s\_sdi) signal, it sends the first bit (MSB or LSB) on the second rising edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig.17-13 TDM Left Shift Mode 0 Timing Format (PCM Format)

### 17.3.10 TDM Left Shift Mode1 (PCM Format)

This is the waveform of PCM early mode. For LRCK (**i2s\_lrck\_rx/i2s\_lrck\_tx**) signal, it goes high to indicate the start of a group of audio channels. For SD (**i2s\_sdo, i2s\_sdi**) signal, it sends the first bit (MSB or LSB) on the first falling edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig.17-14 TDM Left Shift Mode 1 Timing Format (PCM Format)

### 17.3.11 TDM Left Shift Mode2 (PCM Format)

This is the waveform of PCM early mode. For LRCK (**i2s\_lrck\_rx/i2s\_lrck\_tx**) signal, it goes high to indicate the start of a group of audio channels. For SD (**i2s\_sdo, i2s\_sdi**) signal, it sends the first bit (MSB or LSB) on the first rising edge of SCLK after LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig.17-15 TDM Left Shift Mode 2 Timing Format (PCM Format)

### 17.3.12 TDM Left Shift Mode3 (PCM Format)

This is the waveform of PCM early mode. For LRCK (**i2s1\_lrck\_rx/i2s1\_lrck\_tx**) signal, it goes high to indicate the start of a group of audio channels. For SD (**i2s1\_sdo, i2s1\_sdi**) signal, it sends the first bit (MSB or LSB) at the same time when LRCK goes high. The range of SD signal width is from 16 to 32bits.



Fig.17-16 TDM Left Shift Mode 3 Timing Format (PCM Format)

### 17.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.17-17 TDM Normal Mode Timing Format (I2S Format)

### 17.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:



tdm\_txctrl[17]/tdm\_rxctrl[17]=0:



Fig.17-18 TDM Left Justified Mode Timing Format (I2S Format)

### 17.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.17-19 TDM Right Justified Mode Timing Format (I2S Format)

## 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 for I2S0

| 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    | 0x00070000  | 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 TXCTRL | 0x0030 | W    | 0x00003EFF  | TDM Mode Transmit Operation Control Register |
| I2S TDM 8CH TDM RXCTRL | 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    | 0x20150001  | Version Register                             |

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

### 17.4.3 Detail Registers Description for I2S0

#### I2S TDM 8CH TXCR

Address: Operational Base + offset (0x0000)

| Bit | Attr | Reset Value | Description |
|-----|------|-------------|-------------|
| 31  | RO   | 0x0         | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:29      | RW          | 0x3                | <p>TX_PATH_SEL3<br/>TX Path Select 3</p> <p>2'b00: Sdo3 output data from path0<br/>2'b01: Sdo3 output data from path1<br/>2'b10: Sdo3 output data from path2<br/>2'b11: Sdo3 output data from path3</p> <p>Note: When TDM mode, only path0 enable.</p> |
| 28:27      | RW          | 0x2                | <p>TX_PATH_SEL2<br/>TX Path Select 2</p> <p>2'b00: Sdo2 output data from path0<br/>2'b01: Sdo2 output data from path1<br/>2'b10: Sdo2 output data from path2<br/>2'b11: Sdo2 output data from path3</p> <p>Note: When TDM mode, only path0 enable.</p> |
| 26:25      | RW          | 0x1                | <p>TX_PATH_SEL1<br/>TX Path Select 1</p> <p>2'b00: Sdo1 output data from path0<br/>2'b01: Sdo1 output data from path1<br/>2'b10: Sdo1 output data from path2<br/>2'b11: Sdo1 output data from path3</p> <p>Note: When TDM mode, only path0 enable.</p> |
| 24:23      | RW          | 0x0                | <p>TX_PATH_SEL0<br/>TX Path Select 0</p> <p>2'b00: Sdo0 output data from path0<br/>2'b01: Sdo0 output data from path1<br/>2'b10: Sdo0 output data from path2<br/>2'b11: Sdo0 output data from path3</p> <p>Note: When TDM mode, only path0 enable.</p> |
| 22:17      | RW          | 0x00               | <p>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.</p> |
| 16:15      | RW          | 0x0                | <p>TCSR<br/>Transmit Channel Select Register</p> <p>2'b00: Two channel<br/>2'b01: Four channel<br/>2'b10: Six channel<br/>2'b11: Eight channel</p>                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | RW          | 0x0                | 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.                                                                             |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                 |
| 12         | RW          | 0x0                | SJM<br>Store Justified Mode<br>Can be written only when XFER[0] bit is 0.<br>16bit~31bit DATA stored in 32 bits width FIFO.<br>If VDW select 16bit data, this bit is valid only when HWT select 0.<br>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.<br>1'b0: Right justified<br>1'b1: Left justified |
| 11         | RW          | 0x0                | FBM<br>First Bit Mode<br>Can be written only when XFER[0] bit is 0.<br>1'b0: MSB<br>1'b1: LSB                                                                                                                                                                                                                                                                                            |
| 10:9       | RW          | 0x0                | 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                                                                                                                                                                                                                     |
| 8:7        | RW          | 0x0                | 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.                                                                                                                                                                                  |
| 6:5        | RW          | 0x0                | 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)                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x0f               | <p>VDW<br/>Valid Data Width<br/>Can be written only when XFER[0] bit is 0.<br/>5'b00000~5'b01110: Reserved<br/>5'b01111: 16bit<br/>5'b10000: 17bit<br/>5'b10001: 18bit<br/>5'b10010: 19bit<br/>.....<br/>5'b11100: 29bit<br/>5'b11101: 30bit<br/>5'b11110: 31bit<br/>5'b11111: 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                | <p>RX_PATH_SEL3<br/>Rx Path Select 3<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.</p> |
| 22:21      | RW          | 0x2                | <p>RX_PATH_SEL2<br/>Rx Path Select 2<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.</p> |
| 20:19      | RW          | 0x1                | <p>RX_PATH_SEL1<br/>Rx Path Select 1<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.</p> |
| 18:17      | RW          | 0x0                | <p>RX_PATH_SEL0<br/>Rx Path Select 0<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</p>                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:15      | RW          | 0x0                | <p>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</p>                                                                                                                                                                                                                                                         |
| 14         | RW          | 0x0                | <p>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.</p>                                                                                   |
| 13         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                               |
| 12         | RW          | 0x0                | <p>SJM<br/>Store Justified Mode<br/>Can be written only when XFER[1] bit is 0.<br/>16bit~31bit DATA stored in 32 bits width FIFO.<br/>If VDW select 16bit data, this bit is valid only when HWT select 0.<br/>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.<br/>1'b0: Right justified<br/>1'b1: Left justified</p> |
| 11         | RW          | 0x0                | <p>FBM<br/>First Bit Mode<br/>Can be written only when XFER[1] 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[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</p>                                                                                                                                                                                                                      |
| 8:7        | RW          | 0x0                | <p>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</p>                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:5        | RW          | 0x0                | <p>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)</p>                                                                                   |
| 4:0        | RW          | 0x0f               | <p>VDW<br/>Valid Data Width<br/>Can be written only when XFER[1] bit is 0.<br/>5'b00000~5'b01110: Reserved<br/>5'b01111: 16bit<br/>5'b10000: 17bit<br/>5'b10001: 18bit<br/>5'b10010: 19bit<br/>.....<br/>5'b11100: 29bit<br/>5'b11101: 30bit<br/>5'b11110: 31bit<br/>5'b11111: 32bit</p> |

**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                | <p>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.</p> |
| 27         | RW          | 0x0                | <p>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)</p>                                                                                                          |
| 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>                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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      | RW          | 0x07               | <p>MDIV<br/>Reserved.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15:8       | RW          | 0x00               | <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          | 0x00               | <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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------|
| 23:18      | RO          | 0x00               | TFL3<br>Transmit FIFO3 Level<br>Contains the number of valid data entries in the transmit FIFO3. |
| 17:12      | RO          | 0x00               | TFL2<br>Transmit FIFO2 Level<br>Contains the number of valid data entries in the transmit FIFO2. |
| 11:6       | RO          | 0x00               | TFL1<br>Transmit FIFO1 Level<br>Contains the number of valid data entries in the transmit FIFO1. |
| 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                | RXFIE<br>RX Full Interrupt Enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                     |
| 15:9       | RO          | 0x00               | reserved                                                                                                                                                               |
| 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 INTSR**

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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 16         | RO          | 0x0                | RXFI<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:2       | RO          | 0x00000000         | reserved                                                                          |
| 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       | WO          | 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       | RO          | 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      | RO          | 0x00               | RFL3<br>Receive FIFO3 Level<br>Contains the number of valid data entries in the receive FIFO3. |
| 17:12      | RO          | 0x00               | RFL2<br>Receive FIFO2 Level<br>Contains the number of valid data entries in the receive FIFO2. |
| 11:6       | RO          | 0x00               | RFL1<br>Receive FIFO1 Level<br>Contains the number of valid data entries in the receive FIFO1. |
| 5:0        | RO          | 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                                                                                                                                                                                                                                                                                                                                                  |
| 20:18      | RW          | 0x0                | 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. |
| 17         | RW          | 0x0                | 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.                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:14      | RW          | 0x0                | <p>TDM_TX_SHIFT_CTRL<br/>TDM Transfer Shift Ctrl<br/>Can be written only when XFER[0] is 0.</p> <p>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</p> <p>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</p> <p>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</p> <p>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</p> <p>3'b100:<br/>PCM format 4: 2 cycle shift left, drive data aligned to the posedge of TX LRCK.<br/>I2S format: Not support</p> <p>3'b101~3'b111: Not support</p> <p>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.</p> <p>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</p> <p>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<br/>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>RX_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<br/>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>                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:14      | RW          | 0x0                | <p>TDM_RX_SHIFT_CTRL<br/>TDM Receive Shift Ctrl<br/>Can be written only when XFER[1] is 0.</p> <p>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</p> <p>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</p> <p>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</p> <p>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</p> <p>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</p> <p>3'b101~3'b111: Not support</p> <p>Note: Function when RX TFS[1:0] is 2 or 3.</p> |
| 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.</p> <p>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</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>                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 Divider<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          | 0x20150001         | I2S_VERSION<br>I2S Version |

**17.4.4 Registers Summary for I2S1/I2S2**

| <b>Name</b>    | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                   |
|----------------|---------------|-------------|--------------------|--------------------------------------|
| I2S_2CH_TXCR   | 0x0000        | W           | 0x0000000F         | Transmit Operation Control Register. |
| I2S_2CH_RXCR   | 0x0004        | W           | 0x0000000F         | Receive Operation Control Register   |
| I2S_2CH_CKR    | 0x0008        | W           | 0x00071F1F         | Clock Generation Register            |
| I2S_2CH_FIFOLR | 0x000C        | W           | 0x00000000         | FIFO Level Register                  |
| I2S_2CH_DMACR  | 0x0010        | W           | 0x001F0000         | DMA Control Register                 |
| I2S_2CH_INTCR  | 0x0014        | W           | 0x01F00000         | Interrupt Control Register           |
| I2S_2CH_INTSR  | 0x0018        | W           | 0x00000000         | Interrupt Status Register            |
| I2S_2CH_XFER   | 0x001C        | W           | 0x00000000         | Transfer Start Register              |

| Name         | Offset | Size | Reset Value | Description                      |
|--------------|--------|------|-------------|----------------------------------|
| I2S 2CH CLR  | 0x0020 | W    | 0x00000000  | SCLK Domain Logic Clear Register |
| I2S 2CH TXDR | 0x0024 | W    | 0x00000000  | Transmit FIFO Data Register      |
| I2S 2CH RXDR | 0x0028 | W    | 0x00000000  | Receive FIFO Data Register       |

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

### 17.4.5 Detail Registers Description for I2S1/I2S2

#### I2S 2CH TXCR

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23 | RO   | 0x000       | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 22:17 | RW   | 0x00        | RCNT<br>Right Justified Counter<br>Can be written only when XFER[0] bit is 0.<br>Only valid in I2S right justified format and slave TX mode is selected.<br>Start to transmit data RCNT sclk cycles after left channel valid.                                                                                                                                                       |
| 16:15 | RW   | 0x0         | CSR<br>Channel Select Register<br>2'b00: 2 channel<br>2'b01~2'b11: Reserved                                                                                                                                                                                                                                                                                                         |
| 14    | RW   | 0x0         | 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.                                                                        |
| 13    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 12    | RW   | 0x0         | SJM<br>Store Justified Mode<br>Can be written only when XFER[0] bit is 0.<br>16bit~31bit DATA stored in 32 bits width FIFO.<br>If VDW select 16bit data, this bit is valid only when HWT select 0.Because if HWT is 1, every FIFO unit contain two 16bit data and 32 bit space is full, it is impossible to choose justified mode.<br>1'b0: Right justified<br>1'b1: Left justified |
| 11    | RW   | 0x0         | FBM<br>First Bit Mode<br>Can be written only when XFER[0] bit is 0.<br>1'b0: MSB<br>1'b1: LSB                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:9       | RW          | 0x0                | 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                                                                                                  |
| 8:7        | RW          | 0x0                | PBM<br>PCM Bus Mode<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                                                                                        |
| 6          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                              |
| 5          | RW          | 0x0                | TFS<br>Transfer Format Select<br>Can be written only when XFER[0] bit is 0.<br>1'b0: I2S format<br>1'b1: PCM format                                                                                                                                                   |
| 4:0        | RW          | 0x0f               | VDW<br>Valid Data Width<br>Can be written only when XFER[0] bit is 0.<br>5'b00000~5'b01110: reserved<br>5'b01111: 16bit<br>5'b10000: 17bit<br>5'b10001: 18bit<br>5'b10010: 19bit<br>.....<br>5'b11100: 29bit<br>5'b11101: 30bit<br>5'b11110: 31bit<br>5'b11111: 32bit |

**I2S 2CH RXCR**

Address: Operational Base + offset (0x0004)

| <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                | 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>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 contain two 16bit data and 32 bit space is full, it is impossible to choose justified mode.<br>1'b0: Right justified<br>1'b1: Left justified |
| 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          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 5          | RW          | 0x0                | TFS<br>Transfer Format Select<br>Can be written only when XFER[1] bit is 0.<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/>Can be written only when XFER[1] bit is 0.<br/>5'b00000~5'b01110: reserved<br/>5'b01111: 16bit<br/>5'b10000: 17bit<br/>5'b10001: 18bit<br/>5'b10010: 19bit<br/>.....<br/>5'b11100: 29bit<br/>5'b11101: 30bit<br/>5'b11110: 31bit<br/>5'b11111: 32bit</p> |

**I2S 2CH 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                | <p>TRCM<br/>TX/RX LRCK as common<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.<br/>Note: When set to 2'b01 or 2'b10 , if user wants to use both transmitting and receiving in master mode, user should configure as following:<br/>a. The value of TSD and RSD should be same.<br/>b. User should start TX transfer and RX transfer at the same time.</p> |
| 27         | RW          | 0x0                | <p>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)</p>                                                                                                                                                                                                                                                                                                                                                                           |
| 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>                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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      | RW          | 0x07               | <p>MDIV<br/>Mclk Divider<br/>Can be written only when XFER[1] or XFER[0] bit is 0.<br/>mclk divider = (mclk/sclk)-1.<br/>For example, if mclk divider is 5, then the frequency of sclk is mclk/6</p>                                                                                                                                                                                                                                                                                             |
| 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 divider&gt;&gt;1 + 1)*2*frequency of rx_lrck</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 divider&gt;&gt;1 + 1)*2*frequency of tx_lrck</p>                                                                                                                                                                                                                                                                        |

**I2S 2CH FIFO LR**

Address: Operational Base + offset (0x000C)

| <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:24      | RO          | 0x00               | RFL<br>Receive FIFO Level<br>Contains the number of valid data entries in the receive FIFO.    |
| 23:6       | RO          | 0x000000           | reserved                                                                                       |
| 5:0        | RW          | 0x00               | TFL<br>Transmit FIFO0 Level<br>Contains the number of valid data entries in the transmit FIFO. |

**I2S\_2CH\_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 TXFIFO is equal to or below this field value. |

**I2S\_2CH\_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                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                | RXFIE<br>RX Full Interrupt Enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                  |
| 15:9       | RO          | 0x00               | reserved                                                                                                                                                            |
| 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          | WO          | 0x0                | TXUIC<br>TX Under-run Interrupt Clear<br>Write 1 to clear TX under-run 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\_2CH\_INTSR**

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                | RXFI<br>RX Full Interrupt<br>1'b0: Inactive<br>1'b1: Active    |
| 15:2       | RO          | 0x0000             | reserved                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 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 2CH XFER**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                          |
| 1          | RW          | 0x0                | RXS<br>RX Transfer 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 2CH 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 2CH TXDR**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | TXDR<br>Transmit FIFO Data Register<br>When it is written to, data are moved into the transmit FIFO. |

**I2S 2CH RXDR**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXDR<br>Receive FIFO Data Register<br>When the register is read, data in the receive FIFO is accessed. |

## 17.5 Interface Description

Three I2S controllers embed in the chip are I2S0, I2S1 and I2S2. The I2S0 is connected to two groups of IO interfaces.

The following table shows the I2S0 group 0 interface description.

Table 17-1 I2S0 Group 0 Interface Description

| <b>Module Pin</b>            | <b>Direction</b> | <b>Pad Name</b>                                                          | <b>IOMUX Setting</b>             |
|------------------------------|------------------|--------------------------------------------------------------------------|----------------------------------|
| i2s0_mclk_tx or i2s0_mclk_rx | I/O              | I2S0_MCLK_M0/GPIO3_D2_d                                                  | GRF_GPIO3D_IOMUX_L[10:8]=3'b001  |
| i2s0_sclk_tx                 | I/O              | I2S0_SCLK_TX_M0/ACODEC_DAC_CLK/GPIO3_D0_d                                | GRF_GPIO3D_IOMUX_L[2:0]=3'b001   |
| i2s0_sclk_rx                 | I/O              | I2S0_SCLK_RX_M0/PDM_CLK1_M0/ACODEC_ADC_CLK/GPIO3_D1_d                    | GRF_GPIO3D_IOMUX_L[6:4]=3'b001   |
| i2s0_lrck_tx                 | I/O              | I2S0_LRCK_TX_M0/ACODEC_DAC_SYNC/AUDPWM_L_M1/AUDDSM_LN/GPIO3_D3_d         | GRF_GPIO3D_IOMUX_L[14:12]=3'b001 |
| i2s0_lrck_rx                 | I/O              | I2S0_LRCK_RX_M0/PDM_CLK0_M0/ACODEC_ADC_SYNC/GPIO3_D4_d                   | GRF_GPIO3D_IOMUX_H[2:0]=3'b001   |
| i2s0_sdi0                    | I                | I2S0_SDIO_M0/PDM_SDIO_M0/ACODEC_DAC_DATA/GPIO3_D6_d                      | GRF_GPIO3D_IOMUX_H[10:8]=3'b001  |
| i2s0_sdo0                    | O                | I2S0_SDO0_M0/ACODEC_DAC_DATAR/AUDPWM_R_M1/AUDDSM_LP/GPIO3_D5_d           | GRF_GPIO3D_IOMUX_H[6:4]=3'b001   |
| i2s0_sdi1/i2s0_sdo3          | I/O              | I2S0_SDO3_SD1_M0/PDM_SD1_M0/AUDPWM_R_M0/I2C4_SDA_M1/AUDDSM_RP/GPIO4_A1_d | GRF_GPIO4A_IOMUX_L[6:4]=3'b001   |
| i2s0_sdi2/i2s0_sdo2          | I/O              | I2S0_SDO2_SD2_M0/PDM_SD2_M0/AUDPWM_L_M0/I2C4_SCL_M1/AUDDSM_RN/GPIO4_A0_d | GRF_GPIO4A_IOMUX_L[2:0]=3'b001   |
| i2s0_sdi3/i2s0_sdo1          | I/O              | I2S0_SDO1_SD3_M0/PDM_SD3_M0/ACODEC_ADC_DATA/GPIO3_D7_d                   | GRF_GPIO3D_IOMUX_H[14:12]=3'b001 |

The following table shows the I2S0 group 1 interface description.

Table 17-2 I2S0 Group 1 Interface Description

| <b>Module Pin</b>            | <b>Direction</b> | <b>Pad Name</b>                                                              | <b>IOMUX Setting</b>           |
|------------------------------|------------------|------------------------------------------------------------------------------|--------------------------------|
| i2s0_mclk_tx or i2s0_mclk_rx | I/O              | CIF_D4_M0/RGMII_RXD3_M0/I2S0_MCLK_M1/UART5_RTSN_M0/I2C5_SCL_M1/GPIO3_B0_d    | GRF_GPIO3B_IOMUX_L[2:0]=3'b011 |
| i2s0_sclk_tx                 | I/O              | CIF_D0_M0/I2S0_SCLK_TX_M1/UART4_TX_M0/I2C3_SCL_M0/PWM8_M0/GPIO3_A4_d         | GRF_GPIO3A_IOMUX_H[2:0]=3'b011 |
| i2s0_sclk_rx                 | I/O              | CIF_D5_M0/RGMII_TXD2_M0/I2S0_SCLK_RX_M1/UART5_CTSN_M0/I2C5_SDA_M1/GPIO3_B1_d | GRF_GPIO3B_IOMUX_L[6:4]=3'b011 |

| <b>Module Pin</b>       | <b>Direction</b> | <b>Pad Name</b>                                                                     | <b>IOMUX Setting</b>             |
|-------------------------|------------------|-------------------------------------------------------------------------------------|----------------------------------|
| i2s0_lrck_tx            | I/O              | CIF_D1_M0/RGMII_CRS_M0/I2S0_LRCK_TX_M1/UART4_RX_M0/I2C3_SDA_M0/PWM9_M0/GPIO3_A5_d   | GRF_GPIO3A_IOMUX_H[6:4]=3'b011   |
| i2s0_lrck_rx            | I/O              | CIF_D6_M0/RGMII_TXD3_M0/I2S0_LRCK_RX_M1/UART4_RTSN_M0/GPIO3_B2_d                    | GRF_GPIO3B_IOMUX_L[10:8]=3'b011  |
| i2s0_sdi0               | I                | CIF_D3_M0/RGMII_RXD2_M0/I2S0_SDI0_M1/UART5_RX_M0/CAN_TXD_M1/PWM1_1_IR_M0/GPIO3_A7_d | GRF_GPIO3A_IOMUX_H[14:12]=3'b011 |
| i2s0_sdo0               | O                | CIF_D2_M0/RGMII_COL_M0/I2S0_SDO0_M1/UART5_TX_M0/CAN_RXD_M1/PWM10_M0/GPIO3_A6_d      | GRF_GPIO3A_IOMUX_H[10:8]=3'b011  |
| i2s0_sdi1/<br>i2s0_sdo3 | I/O              | CIF_D9_M0/RGMII_TXEN_M0/I2S0_SDO3_SDI1_M1/SPI1_CS0n_M0/GPIO3_B5_d                   | GRF_GPIO3B_IOMUX_H[6:4]=3'b011   |
| i2s0_sdi2/<br>i2s0_sdo2 | I/O              | CIF_D8_M0/RGMII_TXD1_M0/I2S0_SDO2_SDI2_M1/SPI1_CS1n_M0/GPIO3_B4_d                   | GRF_GPIO3B_IOMUX_H[2:0]=3'b011   |
| i2s0_sdi3/<br>i2s0_sdo1 | I/O              | CIF_D7_M0/RGMII_TXD0_M0/I2S0_SDO1_SDI3_M1/UART4_CTSN_M0/GPIO3_B3_d                  | GRF_GPIO3B_IOMUX_L[14:12]=3'b011 |

The I2S0 also communicates with the Digital Audio Codec inside the chip by configuring GRF\_SOC\_CON2[12]. If GRF\_SOC\_CON2[12] is configured to 1'b1, then I2S0 will communicate with Digital Audio Codec, otherwise the I2S0 will interact with other I2S devices through I2S0 group 0 or group 1 interface. By configuring GRF\_IOFUNC\_SEL0[9] to 1'b0, i2s0\_mclk\_tx will be connected to the PAD. If GRF\_IOFUNC\_SEL0[9] is configured to 1'b1, i2s0\_mclk\_rx will be connected to the PAD.

The I2S1 is connected to three groups of IO interfaces. The following table shows the I2S1 group 0 interface description.

Table 17-3 I2S1 Group 0 Interface Description

| <b>Module Pin</b>               | <b>Direction</b> | <b>Pad Name</b>                              | <b>IOMUX Setting</b>            |
|---------------------------------|------------------|----------------------------------------------|---------------------------------|
| i2s1_mclk                       | I/O              | FLASH_CS0n/FSPI_CS0n/I2S1_MCLK_M0/GPIO0_D4_u | GRF_GPIO0D_IOMUX_H[2:0]=3'b100  |
| i2s1_sclk                       | I/O              | FLASH_RDYn/FSPI_D1/I2S1_SCLK_M0/GPIO1_A1_u   | GRF_GPIO1A_IOMUX_L[6:4]=3'b100  |
| i2s1_lrck_tx or<br>i2s1_lrck_rx | I/O              | FLASH_ALE/FSPI_D0/I2S1_LRCK_M0/GPIO1_A0_d    | GRF_GPIO1A_IOMUX_L[2:0]=3'b100  |
| i2s1_sdi                        | I                | FLASH_RDn/FSPI_D3/I2S1_SDI_M0/GPIO1_A2_u     | GRF_GPIO1A_IOMUX_L[10:8]=3'b100 |
| i2s1_sdo                        | O                | FSPI_D2/I2S1_SDO_M0/GPIO0_D6_d               | GRF_GPIO0D_IOMUX_H[10:8]=3'b100 |

Table 17-4 I2S1 Group 1 Interface Description

| <b>Module Pin</b>               | <b>Direction</b> | <b>Pad Name</b>                                   | <b>IOMUX Setting</b>             |
|---------------------------------|------------------|---------------------------------------------------|----------------------------------|
| i2s1_mclk                       | I/O              | SPI0_CS1n_M1/I2S1_MCLK_M1/UART4_TX_M2/GPIO1_D5_d  | GRF_GPIO1D_IOMUX_H[6:4]=3'b010   |
| i2s1_sclk                       | I/O              | SPI0_MOSI_M1/I2S1_SCLK_M1/I2C3_SCL_M2/GPIO1_D6_d  | GRF_GPIO1D_IOMUX_H[10:8]=3'b010  |
| i2s1_lrck_tx or<br>i2s1_lrck_rx | I/O              | SPI0_MISO_M1/I2S1_LRCK_M1/I2C3_SD_A_M2/GPIO1_D7_d | GRF_GPIO1D_IOMUX_H[14:12]=3'b010 |
| i2s1_sdi                        | I                | SPI0_CS0n_M1/I2S1_SDI_M1/UART5_TX_M2/GPIO2_A0_d   | GRF_GPIO2A_IOMUX_L[2:0]=3'b010   |

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>                                | <b>IOMUX Setting</b>           |
|-------------------|------------------|------------------------------------------------|--------------------------------|
| i2s1_sdo          | O                | SPI0_CLK_M1/I2S1_SDO_M1/UART5_RX_M2/GPIO2_A1_d | GRF_GPIO2A_IOMUX_L[6:4]=3'b010 |

Table 17-5 I2S1 Group 2 Interface Description

| <b>Module Pin</b>            | <b>Direction</b> | <b>Pad Name</b>                                              | <b>IOMUX Setting</b>             |
|------------------------------|------------------|--------------------------------------------------------------|----------------------------------|
| i2s1_mclk                    | I/O              | LCDC_D19/RGMII_RXD2_M1/CIF_D15_M1/I2S1_MCLK_M2/GPIO2_C7_d    | GRF_GPIO2C_IOMUX_H[14:12]=3'b110 |
| i2s1_sclk                    | I/O              | LCDC_D21/RGMII_TXD2_M1/CIF_CLKOUT_M1/I2S1_SCLK_M2/GPIO2_D1_d | GRF_GPIO2D_IOMUX_L[6:4]=3'b110   |
| i2s1_lrck_tx or i2s1_lrck_rx | I/O              | LCDC_D22/RGMII_TXCLK_M1/CIF_CLKIN_M1/I2S1_LRCK_M2/GPIO2_D2_d | GRF_GPIO2D_IOMUX_L[10:8]=3'b110  |
| i2s1_sdi                     | I                | LCDC_D23/RGMII_RXCLK_M1/CIF_HSYNC_M1/I2S1_SDI_M2/GPIO2_D3_d  | GRF_GPIO2D_IOMUX_L[14:12]=3'b110 |
| i2s1_sdo                     | O                | LCDC_D20/RGMII_RXD3_M1/CIF_VSYNC_M1/I2S1_SDO_M2/GPIO2_D0_d   | GRF_GPIO2D_IOMUX_L[2:0]=3'b110   |

By configuring GRF\_IOFUNC\_SEL0[10] to 1'b0, i2s1\_lrck\_rx will be connected to the PAD. If GRF\_IOFUNC\_SEL0[10] is configured to 1'b1, i2s1\_lrck\_tx will be connected to the PAD.

The I2S2 is connected to two groups of IO interfaces. The following table shows the I2S1 group 0 interface description.

Table 17-6 I2S2 Group 0 Interface Description

| <b>Module Pin</b>            | <b>Direction</b> | <b>Pad Name</b>                                                         | <b>IOMUX Setting</b>             |
|------------------------------|------------------|-------------------------------------------------------------------------|----------------------------------|
| i2s2_mclk                    | I/O              | I2S2_MCLK_M0/SDMMC1_DET/SPI1_CS1n_M1/I2C5_SCL_M2/UART1_TX_M1/GPIO1_D0_d | GRF_GPIO1D_IOMUX_L[2:0]=3'b001   |
| i2s2_sclk                    | I/O              | I2S2_SCLK_M0/SPI1_CLK_M1/PRELIGHT_TRIG_OUT/UART1_RTSn_M1/GPIO1_C6_d     | GRF_GPIO1C_IOMUX_H[10:8]=3'b001  |
| i2s2_lrck_tx or i2s2_lrck_rx | I/O              | I2S2_LRCK_M0/SPI1_CS0n_M1/UART1_CTSn_M1/GPIO1_C7_d                      | GRF_GPIO1C_IOMUX_H[14:12]=3'b001 |
| i2s2_sdi                     | I                | I2S2_SDI_M0/SPI1_MISO_M1/FLASH_TRI_G_IN/GPIO1_C5_d                      | GRF_GPIO1C_IOMUX_H[6:4]=3'b001   |
| i2s2_sdo                     | O                | I2S2_SDO_M0/SPI1_MOSI_M1/FLASH_TRIG_OUT/GPIO1_C4_d                      | GRF_GPIO1C_IOMUX_H[2:0]=3'b001   |

Table 17-7 I2S2 Group 1 Interface Description

| <b>Module Pin</b>            | <b>Direction</b> | <b>Pad Name</b>                                                                          | <b>IOMUX Setting</b>             |
|------------------------------|------------------|------------------------------------------------------------------------------------------|----------------------------------|
| i2s2_mclk                    | I/O              | LCDC_D7/I2S2_MCLK_M1/CIF_D3_M1/UART5_CTSn_M1/SPI0_CS1n_M2/PWM0_M1/I2C5_SDA_M0/GPIO2_B3_d | GRF_GPIO2B_IOMUX_L[14:12]=3'b010 |
| i2s2_sclk                    | I/O              | LCDC_D5/I2S2_SCLK_M1/UART5_RX_M1/PWM2_M1/SPI0_MISO_M2/GPIO2_B1_d                         | GRF_GPIO2B_IOMUX_L[6:4]=3'b010   |
| i2s2_lrck_tx or i2s2_lrck_rx | I/O              | LCDC_D6/I2S2_LRCK_M1/UART5_RTSn_M1/PWM1_M1/SPI0_CLK_M2/GPIO2_B2_d                        | GRF_GPIO2B_IOMUX_L[10:8]=3'b010  |
| i2s2_sdi                     | I                | LCDC_D4/I2S2_SDI_M1/UART5_TX_M1/PWM3_IR_M1/SPI0_MOSI_M2/GPIO2_B0_d                       | GRF_GPIO2B_IOMUX_L[2:0]=3'b010   |
| i2s2_sdo                     | O                | LCDC_D3/I2S2_SDO_M1/UART4_RX_M1/PWM4_M1/SPI0_CS0n_M2/GPIO2_A7_d                          | GRF_GPIO2A_IOMUX_H[14:12]=3'b010 |

By configuring GRF\_IOFUNC\_SEL0[11] to 1'b0, i2s2\_lrck\_rx will be connected to the PAD. If GRF\_IOFUNC\_SEL0[11] is configured to 1'b1, i2s2\_lrck\_tx will be connected to the PAD.

## 17.6 Application Notes

### 17.6.1 Software Application Notes



Fig.17-20 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.

## **Chapter 18 Digital Audio Codec**

### **18.1 Overview**

Digital Audio Codec is a 24-bit digital audio encoder/decoder which supports multiple sample rates. It is mainly composed of digital ADC and digital DAC. The function of digital ADC is to convert pulse density modulation format data into PCM format audio data through a series of filters and volume control. Decoding result of digital ADC is sent out through I2S/PCM interface. The aim of digital DAC is to process the data received from I2S/PCM interface through filters, volume control and modulation. Finally the modulated result is sent to Analog Codec.

The Digital Audio Codec supports the following features.

- Support 8-bit APB bus slave interface
- Support 3-channel digital ADC
- Support 2-channel digital DAC
- Support I2S/PCM interface
- Support I2S/PCM master and slave mode
- Support 4-channel audio transmitting in I2S mode
- Support 2-channel audio receiving in I2S mode
- Support 2-channel audio transmitting or 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~24 bit sample resolution for both digital ADC and digital DAC
- Support programmable left and right channel exchangeable in I2S mode and PCM mode for both digital ADC and digital DAC
- Support three modes of mixing for every digital DAC channel
- Both digital ADC and digital DAC support three groups of sample rates. Group 0 are 8kHz/16kHz/32kHz/64kHz/128kHz, group 1 are 11.025kHz/22.05kHz/44.1kHz/88.2kHz/176.4kHz and group 2 are 12kHz/24kHz/48kHz/96kHz/192kHz
- Support asynchronous mode and synchronous mode
- In asynchronous mode, there are no constraints on the sample rate of digital ADC and digital DAC. They are completely independent
- In synchronous mode, support digital ADC or digital DAC operating individually. The sample rate of digital ADC and digital DAC can be within any groups and any kind within one group
- In synchronous mode, support digital ADC and digital DAC operating at the same time within same sample rate group. Sample rates of digital ADC and digital DAC are within the same group
- In synchronous mode, support digital ADC and digital DAC operating at the same time within different sample rate group. Sample rate of digital ADC is within group 0 and digital DAC is within group 2 or digital ADC is within group 2 and digital DAC is within group 0, group 1 not supported
- The pass-band of digital ADC filters is  $0.45625 * fs$
- Support digital ADC pass-band ripple within +/-0.1dB
- The stop-band of digital ADC filters is  $0.5 * fs$
- Support digital ADC stop-band attenuation at least 60dB
- Support volume control for both digital ADC and digital DAC
- Support Automatic Level Control(ALC)and noise gate for digital ADC
- Support programmable negative and positive volume gain for both digital ADC and digital DAC
- Support communication with Analog Codec through I2C bus

## 18.2 Block Diagram



Fig.18-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 ADC/DAC operation clock and I2S operation clock.

### **Digital ADC**

There are 3 digital ADC channels in total inside Digital Audio Codec. The 2-channel digital ADC is composed of left channel and right channel while the 1-channel digital ADC contains only one channel. The digital ADC receives three channels data from ADC\_SER module. It includes CIC filters, compensation filters, low-pass decimation filters, high-pass filters and other audio signal processing related modules. The output of digital ADC is sent to the I2S module.

### **ADC\_SER**

This module receives serial data from analog ADC. It extracts three channels from input serial data and distributes them to the corresponding digital ADC channel.

### **Digital DAC**

There are 2 digital DAC channels inside the Audio Codec. The digital DAC receives audio data from I2S RX. It includes one CIC filter, one high-pass filter, several low-pass decimation filters, modulator and other audio signal processing related modules. The output of digital DAC is sent to DAC\_SER module and serialized before transmitting to analog DAC.

### **DAC\_SER**

This module receives parallel data from digital DAC. It then serializes the parallel data and sends it to analog DAC.

### **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 operate in TX or RX mode. When in TX mode, it receives audio data from digital ADC and sends it out through I2S TX interface. When in RX mode, it receives audio data from I2S RX interface and sends it to digital DAC.

### **ACDC\_I2C**

The ACDC\_I2C module is used to communicate with analog ADC/DAC. It is responsible for sending 4-bit PGA gain codes for each channel to analog ADC/DAC every interval of time.

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

### **18.3.1 Filters of Digital ADC**

Digital Audio Codec receives 3 channels data such as DATA0, DATA1 and DATA2 from Analog Codec. DATA0 is connected to the left channel of 2-channel digital ADC, DATA1 is connected to the right channel of 2-channel digital ADC and DATA2 is connected to the 1-channel digital ADC.

In order to achieve PCM format audio data from DATA0, DATA1 and DATA2, a total of 8 filters for 2-channel digital ADC and 8 filters for 1-channel digital ADC are embedded. It includes a CIC decimation filter, a compensation filter, 4 half-band filters, a low-pass filter and a high-pass filter in 2-channel digital ADC or 1-channel digital ADC.

The CIC decimation filter achieves maximum 16-times decimation when in normal mode. It also can be programmed to 8-times in low power mode 1 or 4-times decimation in low power mode 2. When operates in low power mode 1 or 2, the operating clock of digital ADC can be reduced to half or quarter of the normal mode. The problem is that signal indicators will become worse and some sample rates not support in low power mode 1 or 2. So make sure that the CIC decimation filter works in 16-times decimation unless you don't care about signal indicators.

Compensation filter is connected in series following CIC filter. Its function is to reduce the ripple of CIC filter output. It can be software enabled or disabled.

The 4 half-band filters and a low-pass filter each perform 2-times decimation. That means a maximum of 32-times decimation can be achieved. Not all of these 5 decimation filters are working all the time. How many of them are needed to work depends on the sample rate. For example, in order to output a 192K sample rate signal, only one filter works, the rest of filters are idle.

The high-pass filter is used to filter DC components in audio data stream. Result of high-pass filter is sent to the volume control.

The equivalent parameters of digital ADC filters are as follows.

Table 18-1 Equivalent Parameters of Digital ADC Filters

| Parameter             | Test condition | Min   | Typ | Max       | Unit |
|-----------------------|----------------|-------|-----|-----------|------|
| Pass-band             | +/- 0.1dB      | 20    | N/A | 0.45625fs | Hz   |
| Pass-band ripple      | N/A            | N/A   | N/A | +/- 0.1   | dB   |
| Stop-band             | N/A            | 0.5fs | N/A | N/A       | Hz   |
| Stop-band attenuation | f>0.5fs        | 60    | N/A | N/A       | dB   |

### **18.3.2 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. How to pour 2-channel audio data into 2-channel digital DAC can be achieved by programming mixing mode.

Audio processing of digital DAC is similar to that of digital ADC, which is almost the inverse process of digital ADC. The 2-channel digital DAC includes a high-pass filter and 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, 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 third-order Sigma-Delta modulator.

### **18.3.3 Volume Control**

PCM format data output from 3-channel digital ADC high-pass filters are fed into volume control module. The volume control module inside digital ADC contains several sub-modules such as noise gate, peak detect, frequency cross zero detect, ALC 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. The volume of each channel can be

controlled separately. Each channel has an 8-bit register for volume control. For negative gain, 0xff corresponds to digital mute while 0x00 corresponds to 0dB. For positive gain, 0xff corresponds to maximum gain while 0x00 corresponds to 0dB.

As for digital DAC, output of high-pass filter is fed into volume control module. Similar to digital ADC, 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 also 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.

### 18.3.4 I2C Interface

The role of I2C inside the Digital Audio Codec is to send 4-bit PGA gain codes for each digital ADC channel to Analog Codec every interval of time. The interval of time is software programmable and the unit is the sample rate of digital ADC. There are 12 bits PGA gain codes in total for 3-channel digital ADC, requiring the I2C inside Digital Audio Codec to initiate a request to transmit two bytes when interval of time reaches. The I2C inside Digital Audio Codec can be enabled or disabled by software. Its output bus will multiplex with RKI2C2 controller.

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

### 18.4.2 Registers Summary

| Name                      | Offset | Size | Reset Value | Description                                     |
|---------------------------|--------|------|-------------|-------------------------------------------------|
| ACDCCDIG_SYSCTRL0         | 0x0000 | W    | 0x00000000  | System Control Register                         |
| ACDCCDIG_ADCVUCTL         | 0x0040 | W    | 0x00000001  | ADC Volume Control Register                     |
| ACDCCDIG_ADCVUCTIME       | 0x0044 | W    | 0x00000000  | ADC Volume Control Time Limit Register          |
| ACDCCDIG_ADCDIGEN         | 0x0048 | W    | 0x00000000  | ADC Digital Enable Register                     |
| ACDCCDIG_ADCCLKCTRL       | 0x004c | W    | 0x00000000  | ADC Clock Control Register                      |
| ACDCCDIG_ADCINT_DIV       | 0x0054 | W    | 0x00000007  | ADC Integer Clock Divider Register              |
| ACDCCDIG_ADCSCLKTXINT_DIV | 0x006c | W    | 0x0000001f  | I2S SCLK TX Integer Divider Register            |
| ACDCCDIG_ADCCFG1          | 0x0084 | W    | 0x00000004  | ADC Configure Register 1                        |
| ACDCCDIG_ADCVOLL0         | 0x0088 | W    | 0x00000000  | Volume of ADC Left Channel 0 Register           |
| ACDCCDIG_ADCVOLL1         | 0x008c | W    | 0x00000000  | Volume of ADC Left Channel 2 Register           |
| ACDCCDIG_ADCVOLR0         | 0x0098 | W    | 0x00000000  | Volume of ADC right Channel 1 Register          |
| ACDCCDIG_ADCVOGP          | 0x00a8 | W    | 0x00000000  | ADC Volume Gain Polarity Register               |
| ACDCCDIG_ADCRVOLL0        | 0x00ac | W    | 0x000000ff  | Internal Volume of ADC Left Channel 0 Register  |
| ACDCCDIG_ADCRVOLL1        | 0x00b0 | W    | 0x000000ff  | Internal Volume of ADC Left Channel 2 Register  |
| ACDCCDIG_ADCRVOLR0        | 0x00bc | W    | 0x000000ff  | Internal Volume of ADC right Channel 1 Register |
| ACDCCDIG_ADCALC0          | 0x00cc | W    | 0x00000000  | Automatic Level Control Register 0              |
| ACDCCDIG_ADCALC1          | 0x00d0 | W    | 0x00000000  | Automatic Level Control Register 1              |

| <b>Name</b>                     | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                              |
|---------------------------------|---------------|-------------|--------------------|-------------------------------------------------|
| <u>ACDCDIG ADCALC2</u>          | 0x00d4        | W           | 0x00000000         | Automatic Level Control Register 2              |
| <u>ACDCDIG ADCNG</u>            | 0x00d8        | W           | 0x00000000         | ADC Noise Gate Control Register                 |
| <u>ACDCDIG ADCNGST</u>          | 0x00dc        | W           | 0x00000000         | ADC Noise Gate Status Register                  |
| <u>ACDCDIG ADCHPFEN</u>         | 0x00e0        | W           | 0x00000000         | ADC High-pass Filter Enable Register            |
| <u>ACDCDIG ADCHPFCF</u>         | 0x00e4        | W           | 0x00000000         | ADC High-pass Control Register                  |
| <u>ACDCDIG ADCPGL0</u>          | 0x00ec        | W           | 0x00000000         | PGA Gain of Left Channel 0                      |
| <u>ACDCDIG ADCPGL1</u>          | 0x00f0        | W           | 0x00000000         | PGA Gain of Left Channel 2                      |
| <u>ACDCDIG ADCPGR0</u>          | 0x00fc        | W           | 0x00000000         | PGA Gain of right Channel 1                     |
| <u>ACDCDIG ADCLILMT1</u>        | 0x010c        | W           | 0x00000000         | PGA Gain Limiter Register 1                     |
| <u>ACDCDIG ADCLILMT2</u>        | 0x0110        | W           | 0x00000000         | PGA Gain Limiter Register 2                     |
| <u>ACDCDIG ADCDMICNG1</u>       | 0x0114        | W           | 0x00000000         | Limiter Noise Gate Register 1                   |
| <u>ACDCDIG ADCDMICNG2</u>       | 0x0118        | W           | 0x00000000         | Limiter Noise Gate Register 2                   |
| <u>ACDCDIG DACVUCTL</u>         | 0x0140        | W           | 0x00000001         | DAC Volume Control Register                     |
| <u>ACDCDIG DACVUCTIME</u>       | 0x0144        | W           | 0x00000000         | DAC Volume Control Time Limit Register          |
| <u>ACDCDIG DACDIGEN</u>         | 0x0148        | W           | 0x00000000         | DAC Digital Enable Register                     |
| <u>ACDCDIG DACCLKCTRL</u>       | 0x014c        | W           | 0x00000000         | DAC Clock Control Register                      |
| <u>ACDCDIG DACINT DIV</u>       | 0x0154        | W           | 0x00000007         | DAC Integer Clock Divider Register              |
| <u>ACDCDIG DACSCLKRXINT DIV</u> | 0x0160        | W           | 0x0000001f         | I2S SCLK RX Integer Divider Register            |
| <u>ACDCDIG DACPWM DIV</u>       | 0x0164        | W           | 0x00000003         | PWM Mode Integer Divider Register               |
| <u>ACDCDIG DACPWM CTRL</u>      | 0x0168        | W           | 0x00000000         | PWM Mode Control Register                       |
| <u>ACDCDIG DACCFG1</u>          | 0x0184        | W           | 0x00000004         | DAC Configure Register 1                        |
| <u>ACDCDIG DACMUTE</u>          | 0x0188        | W           | 0x00000000         | DAC Mute Control Register                       |
| <u>ACDCDIG DACMUTEST</u>        | 0x018c        | W           | 0x00000001         | DAC Mute Status Register                        |
| <u>ACDCDIG DACVOLLO</u>         | 0x0190        | W           | 0x00000000         | Volume of DAC Left Channel 0 Register           |
| <u>ACDCDIG DACVOLR0</u>         | 0x01a0        | W           | 0x00000000         | Volume of DAC right Channel 1 Register          |
| <u>ACDCDIG DACVOGP</u>          | 0x01b0        | W           | 0x00000000         | ADC Volume Gain Polarity Register               |
| <u>ACDCDIG DACRVOLLO</u>        | 0x01b4        | W           | 0x000000ff         | Internal Volume of DAC Left Channel 0 Register  |
| <u>ACDCDIG DACRVOLR0</u>        | 0x01c4        | W           | 0x000000ff         | Internal Volume of DAC right Channel 1 Register |
| <u>ACDCDIG DA CLMT0</u>         | 0x01d4        | W           | 0x00000000         | DAC Limiter Register 0                          |
| <u>ACDCDIG DA CLMT1</u>         | 0x01d8        | W           | 0x00000000         | DAC Limiter Register 1                          |
| <u>ACDCDIG DA CLMT2</u>         | 0x01dc        | W           | 0x00000000         | DAC Limiter Register 2                          |
| <u>ACDCDIG DACMIXCTRLL</u>      | 0x01e0        | W           | 0x00000000         | DAC Mixing Control Register Of Left Channels    |
| <u>ACDCDIG DACMIXCTRLR</u>      | 0x01e4        | W           | 0x00000000         | DAC Mixing Control Register Of right Channels   |
| <u>ACDCDIG DACHPF</u>           | 0x01e8        | W           | 0x00000000         | DAC High-pass Filter Control Register           |
| <u>ACDCDIG I2C FLT CON0</u>     | 0x0280        | W           | 0x00000000         | I2C Filter Control Register 0                   |
| <u>ACDCDIG I2C FLT CON1</u>     | 0x0284        | W           | 0x0000000f         | I2C Filter Control Register 1                   |
| <u>ACDCDIG I2C CON0</u>         | 0x0288        | W           | 0x00000000         | I2C Control Register 0                          |
| <u>ACDCDIG I2C CON1</u>         | 0x028c        | W           | 0x00000003         | I2C Control Register 1                          |

| Name                  | Offset | Size | Reset Value | Description                              |
|-----------------------|--------|------|-------------|------------------------------------------|
| ACDCDIG I2C CLKDIVL0  | 0x0290 | W    | 0x00000006  | I2C Scl Low Level Divider Register 0     |
| ACDCDIG I2C CLKDIVL1  | 0x0294 | W    | 0x00000000  | I2C Scl Low Level Divider Register 1     |
| ACDCDIG I2C CLKDIVH0  | 0x0298 | W    | 0x00000006  | I2C Scl High Level Divider Register 0    |
| ACDCDIG I2C CLKDIVH1  | 0x029c | W    | 0x00000000  | I2C Scl High Level Divider Register 1    |
| ACDCDIG I2C MAXCNT    | 0x02a0 | W    | 0x00000080  | I2C Master Transmit Count Register.      |
| ACDCDIG I2C SCLOE DB0 | 0x02a4 | W    | 0x00000020  | Slave Hold Debounce Configure Register 0 |
| ACDCDIG I2C SCLOE DB1 | 0x02a8 | W    | 0x00000000  | Slave Hold Debounce Configure Register 1 |
| ACDCDIG I2C SCLOE DB2 | 0x02ac | W    | 0x00000000  | Slave Hold Debounce Configure Register 2 |
| ACDCDIG I2C SCLOE DB3 | 0x02b0 | W    | 0x00000000  | Slave Hold Debounce Configure Register 3 |
| ACDCDIG I2C TMOUTL    | 0x02b4 | W    | 0x0000001f  | I2C Transmit Request Time Out Register 0 |
| ACDCDIG I2C TMOUTH    | 0x02b8 | W    | 0x00000000  | I2C Transmit Request Time Out Register 1 |
| ACDCDIG I2C DEV ADDR  | 0x02bc | W    | 0x00000048  | I2C Slave Device Address Register        |
| ACDCDIG I2C REG ADDR  | 0x02c0 | W    | 0x00000028  | Register Address of I2C Slave            |
| ACDCDIG I2C STATUS    | 0x02c4 | W    | 0x00000000  | I2C Status Register                      |
| ACDCDIG I2S TXCR0     | 0x0300 | W    | 0x0000000f  | Transmit Operation Control Register 0    |
| ACDCDIG I2S TXCR1     | 0x0304 | W    | 0x00000000  | Transmit Operation Control Register 1    |
| ACDCDIG I2S TXCR2     | 0x0308 | W    | 0x00000000  | Transmit Operation Control Register 2    |
| 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: **B**- Byte (8 bits) access, **HW**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

### 18.4.3 Detail Registers Description

#### ACDCDIG SYSCTRL0

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                           |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6 | RO   | 0x00000000  | reserved                                                                                                                                                                                                              |
| 5    | RW   | 0x0         | sync_mode<br>1'b0: Asynchronous mode. Input operation clocks of Digital ADC and Digital ADC are asynchronous to each other.<br>1'b1: Synchronous mode. Digital ADC and Digital ADC internally share one common clock. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | clk_com_sel<br>Selects the operation clock of Digital ADC or Digital DAC as common clock when Digital ADC and Digital DAC work in synchronous mode. keep the default value when Digital ADC and Digital DAC work in asynchronous mode.<br>1'b0: Selects operation clock of Digital ADC<br>1'b1: Selects operation clock of Digital DAC                                                                                                                                                                   |
| 3          | RW          | 0x0                | glbcke<br>Global enable for synchronization signal of both Digital ADC and DAC. It works well when Digital ADC and DAC operate in synchronous mode where the Digital ADC and DAC share the same d2a_adc_clk and d2a_adc_sync to communicate with Analog ADC/DAC. If Digital ADC and DAC operate in asynchronous mode meaning that they are independent, glbcke is ineffective.<br>1'b0: Disable<br>1'b1: Enable                                                                                          |
| 2          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1          | RW          | 0x0                | sync_sel<br>Selects the synchronization signal generated by Digital ADC or by Digital DAC that is connected to d2a_adc_sync to communicate with Analogy ADC/DAC. Make sure that sync_sel is set to 1'b0 when in synchronous mode. If in asynchronous mode, sync_sel should be set according to the following illustration.<br>1'b0: Synchronization signal generated by Digital ADC is connected to d2a_adc_sync.<br>1'b1: Synchronization signal generated by Digital DAC is connected to d2a_adc_sync. |

**ACDCDIG ADCVUCTL**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                     |
| 2          | RW          | 0x0                | adc_byps<br>Digital ADC volume control bypass.<br>1'b0: ADC volume control enable<br>1'b1: ADC volume control bypass                                                                                                                                         |
| 1          | RW          | 0x0                | adcfade<br>Digital ADC volume adjust mode.<br>1'b0: update to new volume immediately<br>1'b1: update volume as adczdt field describes                                                                                                                        |
| 0          | RW          | 0x1                | adczdt<br>Digital ADC volume cross zero detect enable. It works when adc_byps is 1'b0 and adcfade 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 ADCVUCTIME**

Address: Operational Base + offset (0x0044)

| <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               | adcvuct<br>Volume control time limit, valid only in fade cross zero mode.<br>Time limit = advuct*(1/sample rate)<br>Unit: sample rate |

**ACDCDIG ADCDIGEN**

Address: Operational Base + offset (0x0048)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x00000000         | reserved                                                                                                                                                                                                  |
| 4          | RW          | 0x0                | adcglben<br>Global enable of all Digital ADC channels. Only when adcglben and the enable signal corresponding to each Digital ADC channel is valid before starting work.<br>1'b0: Disable<br>1'b1: Enable |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                  |
| 1          | RW          | 0x0                | adcen_l2<br>Digital ADC left channel 2 enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                           |
| 0          | RW          | 0x0                | adcen_l0r1<br>Digital ADC left channel 0 and right channel 1 enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                     |

**ACDCDIG ADCCLKCTRL**

Address: Operational Base + offset (0x004c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                        |
| 7:6        | RW          | 0x0                | cic_ds_ratio<br>CIC filter decimation ratio.<br>2'b00: 16 times decimation<br>2'b01: 8 times decimation<br>other: 4 times decimation                                                                                                                                                                                                            |
| 5          | RW          | 0x0                | adc_cke<br>Digital ADC operation clock enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                 |
| 4          | RW          | 0x0                | i2stx_cke<br>Clock enable of internal I2S TX channel.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                          |
| 3          | RW          | 0x0                | cke_bclktx<br>Clock enable of sclk_out_tx.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                     |
| 2          | RW          | 0x0                | filter_gate_en<br>Filter gate enable.<br>There are some filters in Digital ADC, they work depends on the sample rate. If any filters not work, the filter and its corresponding memory clock will be gated if filter_gate_en is 1'b1, otherwise the clock will be still active.<br>1'b0: Don't gate filters' clock<br>1'b1: Gate filters' clock |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | adc_sync_ena<br>Enable of the synchronization signal generated by Digital ADC.<br>Note that only when both glbcke and adc_sync_ena are equal to 1'b1, the synchronization signal of Digital ADC can be generated.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                              |
| 0          | RW          | 0x0                | adc_sync_status<br>There is a counter to generate synchronization signal of Digital ADC. In order to ensure the integrity of synchronization signal, it is necessary to read back adc_sync_status to judge whether the counter stops working when adc_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 ADC is complete. |

**ACDCDIG ADCINT DIV**

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          | 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 ADCSCLKTXINT DIV**

Address: Operational Base + offset (0x006c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                      |
| 7:0        | RW          | 0x1f               | scktxdiv<br>Integer clock divider to generate sclk_out_tx when I2S TX works in master mode. It is ignored when in slave mode. |

**ACDCDIG ADCCFG1**

Address: Operational Base + offset (0x0084)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                 |
| 4:2        | RW          | 0x1                | adcsrt<br>Sample rates of Digital ADC.<br>3'b000: 12kHz/11.024kHz/8kHz<br>3'b001: 24kHz/22.05kHz/16kHz<br>3'b010: 32kHz<br>3'b011: 48kHz/44.1kHz<br>3'b100: 96kHz/88.2kHz/64kHz<br>3'b101~3'b111: 192kHz/176.4kHz/128kHz |
| 1          | RW          | 0x0                | sig_scale_mode<br>Signal scale mode select.<br>1'b0: CIC output the normal latitude.<br>1'b1: Scale the CIC output to half of the normal latitude and scale 2 times after high-pass filter.                              |
| 0          | RW          | 0x0                | fir_com_bps<br>FIR compensate filter bypass control.<br>1'b0: Not bypass<br>1'b1: Bypass                                                                                                                                 |

**ACDCDIG ADCVOLLO**

Address: Operational Base + offset (0x0088)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                        |
| 7:0        | RW          | 0x00               | adclv0<br>Volume of Digital ADC 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\_ADCVOLL1**

Address: Operational Base + offset (0x008c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                        |
| 7:0        | RW          | 0x00               | adclv1<br>Volume of Digital ADC left channel 2.<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\_ADCVOLR0**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                         |
| 7:0        | RW          | 0x00               | adcrv0<br>Volume of Digital ADC 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\_ADCVOGP**

Address: Operational Base + offset (0x00a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x000000000        | reserved                                                                                                              |
| 2          | RW          | 0x0                | volgpl2<br>Gain polarity for the volume of Digital ADC left channel 2.<br>1'b0: Negative gain<br>1'b1: Positive gain  |
| 1          | RW          | 0x0                | volgpr1<br>Gain polarity for the volume of Digital ADC right channel 1.<br>1'b0: Negative gain<br>1'b1: Positive gain |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | volgpl0<br>Gain polarity for the volume of Digital ADC left channel 0.<br>1'b0: Negative gain<br>1'b1: Positive gain |

**ACDCDIG ADCRVOLLO**

Address: Operational Base + offset (0x00ac)

| <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 ADC left channel 0. |

**ACDCDIG ADCRVOLL1**

Address: Operational Base + offset (0x00b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                           |
| 7:0        | RW          | 0xff               | rvoll1<br>Internal real-time volume of Digital ADC left channel 2. |

**ACDCDIG ADCRVOLR0**

Address: Operational Base + offset (0x00bc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                            |
| 7:0        | RO          | 0xff               | rvolr0<br>Internal real-time volume of Digital ADC right channel 1. |

**ACDCDIG ADCALC0**

Address: Operational Base + offset (0x00cc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                  |
| 2          | RW          | 0x0                | alcl2<br>Automatic level control enable for Digital ADC left channel 2.<br>1'b0: Disable<br>1'b1: Enable  |
| 1          | RW          | 0x0                | alcr1<br>Automatic level control enable for Digital ADC right channel 1.<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RW          | 0x0                | alcl0<br>Automatic level control enable for Digital ADC left channel 0.<br>1'b0: Disable<br>1'b1: Enable  |

**ACDCDIG ADCALC1**

Address: Operational Base + offset (0x00d0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                         |
| 7:4        | RW          | 0x0                | alcarate<br>ALC attack rate=sample rate/( 8*power(2,alcarate)).  |
| 3:0        | RW          | 0x0                | alcrrate<br>ALC release rate=sample rate/( 8*power(2,alcrrate)). |

**ACDCDIG ADCALC2**

Address: Operational Base + offset (0x00d4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                              |
| 6:4        | RW          | 0x0                | alcmax<br>The highest threshold of ALC.<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                | alcmin<br>The lowest threshold of ALC.<br>3'b000~3'b100: 0db~-12db, 3db/step<br>3'b101~3'b111: -18db~-30db, 6db/step  |

**ACDCDIG ADCNG**

Address: Operational Base + offset (0x00d8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                                                                                                                                              |
| 7          | RW          | 0x0                | ngchl<br>Noise gate channel.<br>1'b0: Individual channel(or)<br>1'b1: Both channel(and)                                                                               |
| 6          | RW          | 0x0                | ngen<br>Noise gate enable.<br>1'b0: Noise gate disable<br>1'b1: Noise gate enable                                                                                     |
| 5          | RW          | 0x0                | ngboost<br>Noise gate boost.<br>1'b0: Normal noise gate<br>1'b1: Boost noise gate                                                                                     |
| 4:2        | RW          | 0x0                | nggate<br>Noise gate threshold.<br>If ngboost is 1'b0:<br>3'b000~3'b111: -63db~-84db, 3db/step<br>If ngboost is 1'b1:<br>3'b000~3'b111: -33db~-54db, 3db/step         |
| 1:0        | RW          | 0x0                | ngdly<br>Noise gate delay. The delay time before the noise gate attacks.<br>2'b00: 2048 samples<br>2'b01: 4096 samples<br>2'b10: 8192 samples<br>2'b11: 16384 samples |

**ACDCDIG ADCNGST**

Address: Operational Base + offset (0x00dc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                        |
| 1          | RO          | 0x0                | ngstl2<br>Noise gates valid status of left channel 2.<br>1'b0: Not in NG status<br>1'b1: Now in NG status                       |
| 0          | RO          | 0x0                | ngstl0r1<br>Noise gates valid status of left channel 0 and right channel 1.<br>1'b0: Not in NG status<br>1'b1: Now in NG status |

**ACDCDIG ADCHPFEN**

Address: Operational Base + offset (0x00e0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                              |
| 2          | RW          | 0x0                | hpfen_l2<br>High-pass filter enable for left channel 2.<br>1'b0: High-pass filter is disabled.<br>1'b1: High-pass filter is enabled.  |
| 1          | RW          | 0x0                | hpfen_r1<br>High-pass filter enable for right channel 1.<br>1'b0: High-pass filter is disabled.<br>1'b1: High-pass filter is enabled. |
| 0          | RW          | 0x0                | hpfen_l0<br>High-pass filter enable for left channel 0.<br>1'b0: High-pass filter is disabled.<br>1'b1: High-pass filter is enabled.  |

**ACDCDIG ADCHPFCF**

Address: Operational Base + offset (0x00e4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                           |
| 1:0        | RW          | 0x0                | hpfcf<br>High-pass filter control.<br>2'b00: 3.79Hz<br>2'b01: 60Hz<br>2'b10: 243Hz<br>2'b11: 493Hz |

**ACDCDIG ADCPGL0**

Address: Operational Base + offset (0x00ec)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                          |
| 3:0        | RW          | 0x0                | pga_l0<br>PGA gain of left channel 0 for analogy ADC.<br>Minimal gain: -18dB, maximum gain: 27dB, step: 3dB. The minimal gain corresponds to 4'b0000 and the maximum gain corresponds to 4'b1111. |

**ACDCDIG ADCPGL1**

Address: Operational Base + offset (0x00f0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                          |
| 3:0        | RW          | 0x0                | pga_l1<br>PGA gain of left channel 2 for analogy ADC.<br>Minimal gain: -18dB, maximum gain: 27dB, step: 3dB. The minimal gain corresponds to 4'b0000 and the maximum gain corresponds to 4'b1111. |

**ACDCDIG ADCPGR0**

Address: Operational Base + offset (0x00fc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                                                                                                                                           |
| 3:0        | RW          | 0x0                | pga_r0<br>PGA gain of right channel 1 for analogy ADC.<br>Minimal gain: -18dB, maximum gain: 27dB, step: 3dB. The minimal gain corresponds to 4'b0000 and the maximum gain corresponds to 4'b1111. |

**ACDCDIG ADCLILMT1**

Address: Operational Base + offset (0x010c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                     |
| 7          | RW          | 0x0                | lmt_en<br>PGA gain LIMITER enable.<br>1'b0: Disable<br>1'b1: Enable                                                          |
| 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 ADCLILMT2**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | 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 ADCDMICNG1**

Address: Operational Base + offset (0x0114)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                         |
| 7          | RW          | 0x0                | ngchl_li<br>Noise gate channel.<br>1'b0: Individual channel(or)<br>1'b1: Both channel(and)                                                                       |
| 6          | RW          | 0x0                | ngen_li<br>Noise gate enable.<br>1'b0: Noise gate disable<br>1'b1: Noise gate enable                                                                             |
| 5          | RW          | 0x0                | ngboost_li<br>Noise gate boost.<br>1'b0: Normal noise gate<br>1'b1: Boost noise gate                                                                             |
| 4:2        | RW          | 0x0                | nggate_li<br>Noise gate threshold.<br>If ngboost is 1'b0:<br>3'b000~3'b111: -63db~-84db, 3db/step<br>If ngboost is 1'b1:<br>3'b000~3'b111: -33db~-54db, 3db/step |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0        | RW          | 0x0                | <p>ngdly_li<br/>Noise gate delay. The delay time before the noise gate attacks.<br/>2'b00: 2048 samples<br/>2'b01: 4096 samples<br/>2'b10: 8192 samples<br/>2'b11: 16384 samples</p> |

**ACDCDIG\_ADCDMICNG2**

Address: Operational Base + offset (0x0118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                                     |
| 1          | RO          | 0x0                | <p>ngvalid_li_l2<br/>Noise gates valid status of Limiter for left channel 2.<br/>1'b0: Not in NG status<br/>1'b1: Now in NG status</p>                       |
| 0          | RO          | 0x0                | <p>ngvalid_li_l0r1<br/>Noise gates valid status of Limiter for left channel 0 and right channel 1.<br/>1'b0: Not in NG status<br/>1'b1: Now in NG status</p> |

**ACDCDIG\_DACVUCTL**

Address: Operational Base + offset (0x0140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                               |
| 2          | RW          | 0x0                | <p>dac_byps<br/>Digital DAC volume control bypass.<br/>1'b0: Digital DAC volume control enable<br/>1'b1: Digital DAC volume control bypass</p>                                                                                                                         |
| 1          | RW          | 0x0                | <p>dacfade<br/>Digital DAC volume adjust mode.<br/>1'b0: Update to new volume immediately.<br/>1'b1: Update volume as daczdt field describes.</p>                                                                                                                      |
| 0          | RW          | 0x1                | <p>daczdt<br/>Digital DAC volume cross zero detect enable. It works when adc_byps is 1'b0 and adcfade 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.</p> |

**ACDCDIG\_DACVUCTIME**

Address: Operational Base + offset (0x0144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                         |
| 7:0        | RW          | 0x00               | <p>dacvuct<br/>Volume control time limit, valid only in fade cross zero mode.<br/>Time limit = dacvuct*(1/sample rate)<br/>Unit: sample rate</p> |

**ACDCDIG\_DACDIGEN**

Address: Operational Base + offset (0x0148)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RW          | 0x0                | adcglben<br>Global enable of all Digital DAC channels. Only when adcglben 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          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5          | RW          | 0x0                | dac_cke<br>Digital DAC operation clock enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                                                                                                                                 |
| 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_bclkrx<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 generated by Digital DAC. Note that only when both glbcke and dac_sync_ena are equal to 1'b1, the synchronization signal of Digital DAC can be generated.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                 |
| 1          | RW          | 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          | RW          | 0x0                | dac_mod_attenu_en<br>When enabled, the input of the Digital DAC modulator is attenuated by 6dB, and the output of the Digital DAC modulator is increased by 6dB.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                               |

**ACDCDIG DACINT DIV**

Address: Operational Base + offset (0x0154)

| <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          | 0x07               | int_div_con<br>Interger 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>Interger clock divider to generate sclk_out_rx when I2S RX works in master mode. It is ignored when in slave mode. |

**ACDCDIG DACPWM DIV**

Address: Operational Base + offset (0x0164)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                             |
| 7:0        | RW          | 0x03               | audio_pwm_div<br>PWM mode division of Digital DAC's operation clock. |

**ACDCDIG DACPWM 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                | pwm_mode_cke<br>Clock enable of 1-bit PWM modulator<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                  |
| 5:4        | RW          | 0x0                | pwm_mode<br>Audio PWM mode or Audio DAC mode selection<br>2'b00: Audio DAC mode<br>2'b01: Audio PWM mode 0. The input of 1-bit PWM modulator is from the last filter of Audio DAC.<br>2'b01: Audio PWM mode 1. The input of 1-bit PWM modulator is directly from output of I2S RX inside the ACDCDIG. |
| 3          | RW          | 0x0                | pwm_en<br>1-bit PWM modulator enable<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                                 |
| 2:0        | RW          | 0x0                | dith_sel<br>Dith mode selection of 1-bit PWM 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.<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 |

**ACDCDIG DACMUTE**

Address: Operational Base + offset (0x0188)

| Bit  | Attr | Reset Value | Description                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2 | RO   | 0x00000000  | reserved                                                                                                                                                          |
| 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)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                        |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | RO   | 0x00000000  | reserved                                                                                                                                                                                                                                           |
| 4    | RO   | 0x0         | unmutest_I0r1<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_I0r1<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)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x00000000  | 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 DACVOLRO**

Address: Operational Base + offset (0x01a0)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                    |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x00000000  | reserved                                                                                                                                                                       |
| 7:0  | RW   | 0x00        | dacr0<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          | 0x0000000          | reserved                                                           |
| 7:0        | RO          | 0xff               | rvollo<br>Internal real-time volume of Digital DAC left channel 0. |

**ACDCDIG DACRVOLR0**

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 DACLMT0**

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                                                                     |
| 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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                               |
| 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                | hpfcf<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 I2C FLT CON0**

Address: Operational Base + offset (0x0280)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                                                       |
| 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. |

**ACDCDIG\_I2C\_FLT\_CON1**

Address: Operational Base + offset (0x0284)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                           |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO   | 0x00000000  | reserved                                                                                                                                                                              |
| 6    | 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) |
| 5    | 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.                                                                         |
| 4    | RW   | 0x0         | flt_en<br>SCL edge glitch filter enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                             |
| 3:0  | RW   | 0xf         | slv_hold_scl_th<br>Slave hold scl threshold = slv_hold_scl_db * Tclk_i2c.                                                                                                             |

**ACDCDIG\_I2C\_CON0**

Address: Operational Base + offset (0x0288)

| Bit  | Attr | Reset Value | Description                                                                                     |
|------|------|-------------|-------------------------------------------------------------------------------------------------|
| 31:7 | RO   | 0x00000000  | reserved                                                                                        |
| 6    | RW   | 0x0         | act2nak<br>Operation when NAK handshake is received.<br>1'b0: Ignored<br>1'b1: Stop transaction |
| 5:3  | RO   | 0x0         | reserved                                                                                        |
| 2:1  | RW   | 0x0         | i2c_mode<br>I2C mode select.<br>2'b00: Transmit only<br>2'b01~2'b11: Reserved                   |
| 0    | RW   | 0x0         | i2c_en<br>I2C enable.<br>1'b0: Not enable<br>1'b1: Enable                                       |

**ACDCDIG\_I2C\_CON1**

Address: Operational Base + offset (0x028c)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x00000000  | reserved                                                                                                                                                                                   |
| 7:6  | RW   | 0x0         | stop_setup<br>Stop setup configure.<br>TSU: sto = (stop_setup + 1) * T(SCL_HIGH) + Tclk_i2c                                                                                                |
| 5:4  | RW   | 0x0         | start_setup<br>Start setup configure.<br>TSU: sta = (start_setup + 1) * T(SCL_HIGH) + Tclk_i2c<br>THD: sta = (start_setup + 2) * T(SCL_HIGH) - Tclk_i2c                                    |
| 3:0  | RW   | 0x3         | data_upd_st<br>SDA update point configure.<br>Used to configure 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 |

**ACDCDIG\_I2C\_CLKDIVLO**

Address: Operational Base + offset (0x0290)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                       |
| 7:0        | RW          | 0x06               | clkdivl0<br>Low 8 bits of scl low level clock divider. The value of 16 bits scl low level clock divider updates only when clkdivl1 is programmed. So ensure to program clkdivl0 firstly, followed by clkdivl1. |

**ACDCDIG I2C CLKDIVL1**

Address: Operational Base + offset (0x0294)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                |
| 7:0        | RW          | 0x00               | clkdivl1<br>High 8 bits of scl low level clock divider. The value of 16 bits scl low level clock divider updates only when clkdivl1 is programmed. So ensure to program clkdivl0 firstly, followed by clkdivl1.<br>$T(SCL\_LOW) = Tclk\_i2c * (CLKDIVL + 1) * 8$ , where the CLKDIVL is equal to clkdivl0+clkdivl1*256. |

**ACDCDIG I2C CLKDIVH0**

Address: Operational Base + offset (0x0298)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                         |
| 7:0        | RW          | 0x06               | clkdivh0<br>Low 8 bits of scl high level clock divider. The value of 16 bits scl high level clock divider updates only when clkdivh1 is programmed. So ensure to program clkdivh0 firstly, followed by clkdivh1. |

**ACDCDIG I2C CLKDIVH1**

Address: Operational Base + offset (0x029c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                  |
| 7:0        | RW          | 0x00               | clkdivh1<br>High 8 bits of scl high level clock divider. The value of 16 bits scl high level clock divider updates only when clkdivh1 is programmed. So ensure to program clkdivh0 firstly, followed by clkdivh1.<br>$T(SCL\_LOW) = Tclk\_i2c * (CLKDIVH + 1) * 8$ , where the CLKDIVH is equal to clkdivh0+clkdivh1*256. |

**ACDCDIG I2C MAXCNT**

Address: Operational Base + offset (0x02a0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                            |
| 7          | RO          | 0x1                | idle<br>1'b0: I2C module is busy.<br>1'b1: I2C module is idle.                      |
| 6          | RO          | 0x0                | reserved                                                                            |
| 5:0        | RW          | 0x00               | mtxcnt<br>Master transmit number. Specify the total bytes to be transmitted (0~32). |

**ACDCDIG I2C SCLOE DB0**

Address: Operational Base + offset (0x02a4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                            |
| 7:0        | RW          | 0x20               | scloedb0<br>Bit7~bit0 of slave hold scl debounce register.<br>Cycles for debounce (unit: Tclk_i2c). |

**ACDCDIG I2C SCLOE DB1**

Address: Operational Base + offset (0x02a8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                             |
| 7:0        | RW          | 0x00               | scloedb1<br>Bit15~bit8 of slave hold scl debounce register.<br>Cycles for debounce (unit: Tclk_i2c). |

**ACDCDIG I2C SCLOE DB2**

Address: Operational Base + offset (0x02ac)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                              |
| 7:0        | RW          | 0x00               | scloedb2<br>Bit23~bit16 of slave hold scl debounce register.<br>Cycles for debounce (unit: Tclk_i2c). |

**ACDCDIG I2C SCLOE DB3**

Address: Operational Base + offset (0x02b0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                              |
| 7:0        | RW          | 0x00               | scloedb3<br>Bit31~bit24 of slave hold scl debounce register.<br>Cycles for debounce (unit: Tclk_i2c). |

**ACDCDIG I2C TMOUTL**

Address: Operational Base + offset (0x02b4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                             |
| 7:0        | RW          | 0x1f               | tmoutl<br>Low 8 bits of 16 bits I2C transmit request time out register. The value of 16 bits I2C transmit request time out register updates only when tmouth is programmed. So ensure to program tmoutl firstly, followed by tmouth. |

**ACDCDIG I2C TMOUTH**

Address: Operational Base + offset (0x02b8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                              |
| 7:0        | RW          | 0x00               | tmouth<br>High 8 bits of 16 bits I2C transmit request time out register. The value of 16 bits I2C transmit request time out register updates only when tmouth is programmed. So ensure to program tmoutl firstly, followed by tmouth. |

**ACDCDIG I2C DEV ADDR**

Address: Operational Base + offset (0x02bc)

| <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          | 0x48               | dev_addr<br>I2C slave device address. |

**ACDCDIG I2C REG ADDR**

Address: Operational Base + offset (0x02c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                    |
|------------|-------------|--------------------|-------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                              |
| 7:0        | RW          | 0x28               | regaddr<br>I2C slave register address to be accessed. |

**ACDCDIG I2C STATUS**

Address: Operational Base + offset (0x02c4)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                        |
| 7          | RO          | 0x0                | slavehdsclst<br>Slave hold scl status bit.<br>1'b0: Slave not hold scl.<br>1'b1: Slave hold scl, write 1'b1 to clear.                           |
| 6          | RO          | 0x0                | nakrcvst<br>NAK handshake received status bit.<br>1'b0: No NAK handshake received.<br>1'b1: NAK handshake received, write 1'b1 to clear.        |
| 5          | RO          | 0x0                | stopst<br>Stop operation finished status bit.<br>1'b0: No finished.<br>1'b1: Stop operation finished, write 1'b1 to clear.                      |
| 4          | RO          | 0x0                | startst<br>Start operation finished status bit.<br>1'b0: Not finished.<br>1'b1: Start operation finished, write 1'b1 to clear.                  |
| 3          | RO          | 0x0                | reserved                                                                                                                                        |
| 2          | RO          | 0x0                | mbtfst<br>I2C_MTXCNT data transfer finished status bit.<br>1'b0: Not finished.<br>1'b1: I2C_MTXCNT data transfer finished, write 1'b1 to clear. |
| 1          | RO          | 0x0                | reserved                                                                                                                                        |
| 0          | RO          | 0x0                | btfst<br>Byte tx finished status bit.<br>1'b0: Byte tx not finish.<br>1'b1: Byte tx finished, write 1'b1 to clear.                              |

**ACDCDIG I2S TXCR0**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                         |
| 7:6        | RW          | 0x0                | pbm<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>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               | vdw<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 |

**ACDCDIG I2S TXCR1**

Address: Operational Base + offset (0x0304)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                           |
| 7:6        | RW          | 0x0                | tcsr<br>2'b00: Two channel<br>2'b01: Four channel<br>Others: Reserved                                              |
| 5          | RO          | 0x0                | reserved                                                                                                           |
| 4          | RW          | 0x0                | cex<br>Exchange left channel and right channel in the every transmit line.<br>1'b0: Not exchange<br>1'b1: Exchange |
| 3          | RO          | 0x0                | reserved                                                                                                           |
| 2          | RW          | 0x0                | fbm<br>1'b0: MSB<br>1'b1: LSB                                                                                      |
| 1:0        | RW          | 0x0                | ibm<br>2'b00: I2S normal<br>2'b01: I2S Left justified<br>2'b10: I2S Right justified<br>2'b11: Reserved             |

**ACDCDIG I2S TXCR2**

Address: Operational Base + offset (0x0308)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x0000000          | reserved                                                                                                                                             |
| 5:0        | RW          | 0x00               | rcnt<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. |

**ACDCDIG I2S RXCRO**

Address: Operational Base + offset (0x030c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                         |
| 7:6        | RW          | 0x0                | pbm<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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | tfs<br>1'b0: I2S format<br>1'b1: PCM format                                                                                                                                                         |
| 4:0        | RW          | 0x0f               | vdw<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 |

**ACDCDIG I2S RXCR1**

Address: Operational Base + offset (0x0310)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                          |
| 7:6        | RW          | 0x0                | rcsr<br>2'b00: Two channel<br>Others: Reserved                                                                    |
| 5          | RO          | 0x0                | reserved                                                                                                          |
| 4          | RW          | 0x0                | cex<br>Exchange left channel and right channel in the every receive line.<br>1'b0: Not exchange<br>1'b1: Exchange |
| 3          | RO          | 0x0                | reserved                                                                                                          |
| 2          | RW          | 0x0                | fwm<br>1'b0: MSB<br>1'b1: LSB                                                                                     |
| 1:0        | RW          | 0x0                | ibm<br>2'b00: I2S normal<br>2'b01: I2S Left justified<br>2'b10: I2S Right justified<br>2'b11: Reserved            |

**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                                                                                         |
| 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        | RW          | 0x0                | tsd<br>I2S tx sclk divider for tx_lrck generator.<br>2'b00: 64<br>2'b01: 128<br>2'b10~2'b11: 256 |

**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>1'b0: Master mode(sclk output)<br>1'b1: Slave mode(sclk input)                                                                                                                                                                                                                                                                                                                        |
| 2          | RW          | 0x0                | ckp<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          | RW          | 0x0                | tlp<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) |

**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          | RW          | 0x0                | txs<br>1'b0: Stop TX transfer<br>1'b1: Start TX transfer |

**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                                                                |
| 1          | RW          | 0x0                | rxc<br>This is a self-cleared bit. Write 1 to clear all receive logic.  |
| 0          | RW          | 0x0                | txc<br>This is a self-cleared bit. Write 1 to clear all transmit logic. |

**ACDCDIG VERSION**

Address: Operational Base + offset (0x0380)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:8       | RO          | 0x00000000         | reserved                   |
| 7:0        | RW          | 0x02               | ver<br>Version of ACDCDIG. |

## 18.5 Interface Description

Digital Audio Codec supports audio DAC mode and audio PWM mode. The following table shows the Digital Audio Codec interface description for audio DAC mode.

Table 18-2 Digital Audio Codec Interface Description for Audio DAC Mode

| Module Pin     | Direction | Pad Name                                                                 | IOMUX Setting                        |
|----------------|-----------|--------------------------------------------------------------------------|--------------------------------------|
| D2A_ADC_CLK    | O         | I2S0_SCLK_RX_M0/PDM_CLK1_M0/A<br>CODEC_ADC_CLK/GPIO3_D1_d                | GRF_GPIO3D_IOMUX_L[6:4]<br>=3'b011   |
| D2A_ADC_SYNC   | O         | I2S0_LRCK_RX_M0/PDM_CLK0_M0/A<br>CODEC_ADC_SYNC/GPIO3_D4_d               | GRF_GPIO3D_IOMUX_H[2:0]<br>=3'b011   |
| A2D_ADC_DATA   | I         | I2S0_SDO1_SD13_M0/PDM_SD13_M<br>0/ACODEC_ADC_DATA/GPIO3_D7_d             | GRF_GPIO3D_IOMUX_H[14:<br>12]=3'b011 |
| D2A_DAC_CLK    | O         | I2S0_SCLK_TX_M0/ACODEC_DAC_C<br>LK/GPIO3_D0_d                            | GRF_GPIO3D_IOMUX_L[2:0]<br>=3'b011   |
| D2A_DAC_SYNC   | O         | I2S0_LRCK_TX_M0/ACODEC_DAC_S<br>YNC/AUDPWM_L_M1/AUDDSM_LN/G<br>PIO3_D3_d | GRF_GPIO3D_IOMUX_L[14:1<br>2]=3'b011 |
| D2A_DAC_DATA_L | O         | I2S0_SDIO_M0/PDM_SDIO_M0/ACOD<br>EC_DAC_DATA/L/GPIO3_D6_d                | GRF_GPIO3D_IOMUX_H[10:<br>8]=3'b011  |
| D2A_DAC_DATA_R | O         | I2S0_SDO0_M0/ACODEC_DAC_DATA<br>R/AUDPWM_R_M1/AUDDSM_LP/GPI<br>O3_D5_d   | GRF_GPIO3D_IOMUX_H[6:4]<br>=3'b011   |

When operating in audio PWM mode, Digital Audio Codec outputs two pairs of differential signals encoded in PWM format. The following table shows the Digital Audio Codec interface description for audio PWM mode.

Table 18-3 Digital Audio Codec Interface Description for Audio PWM Mode

| Module Pin    | Direction | Pad Name                                                                           | IOMUX Setting                        |
|---------------|-----------|------------------------------------------------------------------------------------|--------------------------------------|
| AUDIO_PWM_L_P | O         | I2S0_SDO0_M0/ACODEC_DAC_DATA<br>R/AUDPWM_R_M1/AUDDSM_LP/GPI<br>O3_D5_d             | GRF_GPIO3D_IOMUX_H[6:4]<br>=3'b101   |
| AUDIO_PWM_L_N | O         | I2S0_LRCK_TX_M0/ACODEC_DAC_S<br>YNC/AUDPWM_L_M1/AUDDSM_LN/G<br>PIO3_D3_d           | GRF_GPIO3D_IOMUX_L[14:1<br>2]=3'b101 |
| AUDIO_PWM_R_P | O         | I2S0_SDO3_SD11_M0/PDM_SD11_M<br>0/AUDPWM_R_M0/I2C4_SDA_M1/AU<br>DDSM_RP/GPIO4_A1_d | GRF_GPIO4A_IOMUX_L[6:4]<br>=3'b101   |
| AUDIO_PWM_R_N | O         | I2S0_SDO2_SD12_M0/PDM_SD12_M<br>0/AUDPWM_L_M0/I2C4_SCL_M1/AU<br>DDSM_RN/GPIO4_A0_d | GRF_GPIO4A_IOMUX_L[2:0]<br>=3'b101   |

## 18.6 Application Notes

### 18.6.1 Frequency Configuration

ACDC\_ADC\_CLK and ACDC\_DAC\_CLK are input clocks of Digital Audio Codec. Operation clock of digital ADC and I2S master TX mode are generated from ACDC\_ADC\_CLK, while operation clock of digital DAC and I2S master RX mode are generated from ACDC\_DAC\_CLK. ACDC\_ADC\_CLK and ACDC\_DAC\_CLK are asynchronous to each other. ACDC\_ADC\_CLK must be homologous to the MCLK\_TX of I2S which is connected to Digital Audio Codec when the I2S TX module inside Digital Audio Codec acts as a slave. It is similar that ACDC\_DAC\_CLK must be homologous to the MCLK\_RX of I2S which is connected to Digital Audio Codec when the I2S RX module inside Digital Audio Codec acts as a slave. Clocks named D2A\_ADC\_CLK and D2A\_DAC\_CLK acting as interface clock generated from

ACDC\_ADC\_CLK and ACDC\_DAC\_CLK respectively are sent out to Analog Codec. In order to transfer audio data between digital Codec and Analog Codec, in addition to the audio data lines of digital ADC and DAC, two periodic synchronous signal named D2A\_ADC\_SYNC and D2A\_DAC\_SYNC are needed to indicate the start of every sample data.

The Digital ADC supports three application scenarios that are normal mode, low power mode 1 and low power mode 2. Different application mode requires different frequency of ACDC\_ADC\_CLK. If ACDCDIG\_ADCCLKCTRL.cic\_ds\_ratio is programmed to 16, 8 and 4, the Digital ADC operates in normal mode, low power mode 1 and low power mode 2 respectively.

The relationship of ACDC\_ADC\_CLK, D2A\_ADC\_CLK, D2A\_ADC\_SYNC and sample rates is as follows where the D2A\_ADC\_CLK is 8 times of D2A\_ADC\_SYNC.

Table 18-4 Relationship of ACDC\_ADC\_CLK, D2A\_ADC\_CLK, D2A\_ADC\_SYNC and Sample Rates in Normal Mode

| ACDC_ADC_CLK | D2A_ADC_CLK | D2A_ADC_SYNC | Sample rates supported           |
|--------------|-------------|--------------|----------------------------------|
| 49.152MHz    | 49.152MHz   | 6.144MHz     | 12/24/48/96/192kHz               |
| 45.154MHz    | 45.154MHz   | 5.644MHz     | 11.024/22.05/44.1/88.2/176.4 kHz |
| 32.768MHz    | 32.768MHz   | 4.096MHz     | 8/16/32/64/128kHz                |

Table 18-5 Relationship of ACDC\_ADC\_CLK, D2A\_ADC\_CLK, D2A\_ADC\_SYNC and Sample Rates in Low Power Mode 1

| ACDC_ADC_CLK | D2A_ADC_CLK | D2A_ADC_SYNC | Sample rates supported    |
|--------------|-------------|--------------|---------------------------|
| 24.576MHz    | 24.576MHz   | 3.072MHz     | 12/24/48/96kHz            |
| 22.577MHz    | 22.577MHz   | 2.822MHz     | 11.024/22.05/44.1/88.2kHz |
| 16.384MHz    | 16.384MHz   | 2.048MHz     | 8/16/32/64kHz             |

Table 18-6 Relationship of ACDC\_ADC\_CLK, D2A\_ADC\_CLK, D2A\_ADC\_SYNC and Sample Rates in Low Power Mode 2

| ACDC_CLK  | D2A_ADC_CLK | D2A_ADC_SYNC | Sample rates supported |
|-----------|-------------|--------------|------------------------|
| 12.288MHz | 1.536MHz    | 1.536MHz     | 12/24/48kHz            |
| 11.288MHz | 1.411MHz    | 1.411MHz     | 11.024/22.05/44.1kHz   |
| 8.192MHz  | 1.024MHz    | 1.024MHz     | 8/16kHz                |

For Digital DAC, the relationship of ACDC\_DAC\_CLK, D2A\_DAC\_CLK, D2A\_DAC\_SYNC and sample rates is as follows where the D2A\_DAC\_CLK is 8 times of D2A\_DAC\_SYNC.

Table 18-7 Relationship of ACDC\_DAC\_CLK, D2A\_DAC\_CLK, D2A\_DAC\_SYNC and Sample Rates

| ACDC_DAC_CLK | D2A_DAC_CLK | D2A_DAC_SYNC | Sample rates supported           |
|--------------|-------------|--------------|----------------------------------|
| 49.152MHz    | 49.152MHz   | 6.144MHz     | 12/24/48/96/192kHz               |
| 45.154MHz    | 45.154MHz   | 5.644MHz     | 11.024/22.05/44.1/88.2/176.4 kHz |
| 32.768MHz    | 32.768MHz   | 4.096MHz     | 8/16/32/64/128kHz                |

## 18.6.2 Operation Mode

The Digital Audio Codec supports two operation modes, asynchronous mode and synchronous mode by programming ACDCDIG\_SYSCTRL0.sync\_mode.

The asynchronous mode refers to that ACDC\_ADC\_CLK and ACDC\_DAC\_CLK are asynchronous to each other. The interface of Digital ADC consists of D2A\_ADC\_CLK, D2A\_ADC\_SYNC and A2D\_ADC\_DATA, independently to the interface of Digital DAC which consists of D2A\_DAC\_CLK, D2A\_DAC\_SYNC, D2A\_DAC\_DATA\_L and D2A\_DAC\_DATA\_R.

There are no relationship between interface of Digital ADC and Digital DAC.

The synchronous mode refers to that ACDC\_ADC\_CLK and ACDC\_DAC\_CLK are fed into a mux to generate a common operation clock(named as ACDC\_COM\_CLK) for both Digital ADC and DAC. The operation clock of Digital ADC and DAC are from the same source. In this situation, the Digital Audio Codec use

D2A\_ADC\_CLK, D2A\_ADC\_SYNC, A2D\_ADC\_DATA, D2A\_DAC\_DATA\_L and D2A\_DAC\_DATA\_R to communicate with Analogy Audio Codec. D2A\_ADC\_CLK and D2A\_ADC\_SYNC are shared by Digital ADC and DAC.

When operates in synchronous mode, some restrictions should be taken into account. There are 3 applications(application mode 0, application mode 1 and application mode 2) that should be considered separately.

For application mode 0 and application mode 1, there are no restrictions on ACDC\_COM\_CLK. Just configure the frequency of ACDC\_COM\_CLK according to sample rate and make sure that the frequency of D2A\_ADC\_CLK is at least 8 times of D2A\_ADC\_SYNC.

In this situation, the divider ACDCDIG\_ADCINT\_DIV and ACDCDIG\_DACINT\_DIV must be equal to 0x07.

For application mode 2, there are some differences. For example, sample rate of digital ADC is 12kHz while sample rate of DAC is 128kHz. Configure ACDC COM CLK to the higher frequency such as 49.152MHz. The divider ACDCDIG\_ADCINT\_DIV must be set to 0x07 while ACDCDIG\_DACINT\_DIV must be set to 0x0b. On the contrary, if sample rate of digital ADC is 128kHz while sample rate of DAC is 12kHz. Configure ACDC COM CLK to the higher frequency such as 49.152MHz. The divider ACDCDIG\_ADCINT\_DIV must be set to 8'h0b while ACDCDIG\_DACINT\_DIV must be set to 0x07.

### **18.6.3 Software Application Notes**

Steps to configure Digital ADC and DAC to start transfer at the same time are as follows.

1. Program CRU in the SOC system to achieve the frequency of ACDC ADC CLK and ACDC DAC CLK.
2. Program ACDCDIG\_SYSCTRL0 to set sync\_mode and clk\_com\_sel.
3. Program ACDCDIG\_ADCINT\_DIV to 0x07 or 0x0b according to application modes.
4. Program ACDCDIG\_ADCCLKCTRL to 0x3e. It is preferred to set cic\_ds\_ratio=2'b00 to make Digital Audio Codec work in normal mode.
5. Program ACDCDIG\_ADCSCLKTXINT\_DIV.
6. Program ACDCDIG\_I2S\_CKR0 and ACDCDIG\_I2S\_CKR1 to set I2S TX related registers.
7. Program ACDCDIG\_DACINT\_DIV to 0x07 or 0x0b according to application modes.
8. Program ACDCDIG\_DACCLKCTRL to 0x3c.
9. Program ACDCDIG\_DACSCLKRXINT\_DIV.
10. Program ACDCDIG\_I2S\_CKR0 to set I2S RX related registers.
11. Program ACDCDIG\_SYSCTRL0. clk\_com\_sel to select ACDC COM CLK source if works in synchronous mode. Program ACDCDIG\_SYSCTRL0.sync\_sel to select D2A ADC SYNC source. Don't enable glbcke at this time.
12. Program I2C related registers to set properly device address, timeout value and so on. Then program ACDCDIG\_I2C\_CON0 to enable I2C at last.
13. Program ACDCDIG\_I2S\_CLR to clear I2S TX and RX logic.
14. Program ACDCDIG\_I2S\_TXCR0, ACDCDIG\_I2S\_TXCR1, ACDCDIG\_I2S\_RXCR0 and ACDCDIG\_I2S\_RXCR1.
15. Program I2S controller that is connected to Digital Audio Codec. Don't start I2S TX and RX at this time.
16. Program digital ADC related registers such as ACDCDIG\_ADCHPFEN, ACDCDIG\_ADCVUCTL, ACDCDIG\_ADCCFG1 to achieve basic configuration.
17. Program DAC related registers such as ACDCDIG\_DACHPF, ACDCDIG\_DACVUCTL and ACDCDIG\_DACCFCFG1 to achieve basic configuration.
18. Program ACDCDIG\_I2S\_XFER to start I2S TX and RX.
19. Program I2S controller outside Digital Audio Codec to start I2S TX and RX.
20. Program ACDCDIG\_SYSCTRL0.glbcke to 1'b1 to enable output of D2A ADC SYNC if works in synchronous mode. Skip this step if ACDCDIG\_SYSCTRL0.sync\_mode is 1'b0.
21. Program ACDCDIG\_ADCDIGEN and ACDCDIG\_DACDIGEN to enable digital ADC channels and DAC channels. From now on, the Digital Audio Codec begins to work.

Steps to configure Digital Audio Codec to end transfer are as follows.

1. Program ACDCDIG\_ADCDIGEN and ACDCDIG\_DACDIGEN to disable digital ADC channels and DAC channels.
2. Program ACDCDIG\_ADCCLKCTRL.adc\_sync\_ena and 1'b0 and ACDCDIG\_DACCLKCTRL.dac\_sync\_ena to 1'b0 to disable the D2A ADC SYNC and D2A ADC SYNC respectively. Wait ACDCDIG\_ADCCLKCTRL.adc\_sync\_status and ACDCDIG\_DACCLKCTRL.dac\_sync\_status until both of them read back to be 1'b0.
3. Program ACDCDIG\_SYSCTRL0.glbcke to 1'b0 if works in synchronous mode.

## Chapter 19 Audio PWM

### 19.1 Overview

The Audio PWM provides an easy and cheap solution for audio playback in low quality. It acts as a digital-to-analog converter (DAC), which converts the digital audio PCM data to the analog PWM signals.

The Audio PWM supports the following features:

- Support one 32bit AHB slave interface for the configuration and data access.
- Support one 32x32bits TX FIFO
- The FIFO can be written by Cortex-A7, MCU and DMAC
- Support 16bits~32bits source data width
- Support 8bits~11bits output sampling data width
- Support two maskable output channels, left and right, and they can be swapped
- Support the interpolation rate up to 15
- Support linear interpolation, and the interpolation rate must be 1/3/7/15 in this mode
- Support one interrupt output for FIFO almost full, overrun and empty

### 19.2 Block Diagram

The following figure shows the block diagram of Audio PWM.



Fig. 19-1 Block Diagram of Audio PWM

### 19.3 Function Description

When the source data width is 16 bits, all the 32 bits of the FIFO data is valid in normal cases. The lower 16 bits are used for the channel 0 and the upper 16 bits are used for the channel 1. And when the source data width is greater than 16 bits, the word-wide data is used alternately for the channel 0 and the channel 1.

The Audio PWM samples two halfwords/words of the FIFO data for the two output channels, and the interpolation calculation also needs the next two halfwords/words. Therefore, the four sampling data values which stored in the four data buffers are needed at the beginning of the transfer. And it is required that the next two sampling data values are prefetched from the FIFO later. For this reason, when the transfer is finish by the long stop operation and the FIFO is empty, there are still two or four unprocessed words left in the buffers.

The Pulse Width Modulation (PWM) is a form of signal modulation where data is represented by the ratio of the high level time to the period, which is known as the duty cycle. In this chip, the PWM period is defined as  $(2^N - 1)$  clock cycles, where N is the output sampling data width of the Audio PWM, which determines the duty cycle resolution and the required frequency of the system main clock. The duty cycle of 0% represents the minimum signed digit while the maximum signed digit is represented by the duty cycle of 100%.

The following table shows the duty cycle resolution of the Audio PWM.

Table 19-1 Duty Cycle Resolution of the Audio PWM

| Output Width | Duty Cycle Resolution | Duty Cycle Range | Represented Signed Digit |
|--------------|-----------------------|------------------|--------------------------|
| 8            | 256                   | 0/255 ~ 255/255  | -128 ~ 127               |

| <b>Output Width</b> | <b>Duty Cycle Resolution</b> | <b>Duty Cycle Range</b> | <b>Represented Signed Digit</b> |
|---------------------|------------------------------|-------------------------|---------------------------------|
| 9                   | 512                          | 0/511 ~ 511/511         | -256 ~ 255                      |
| 10                  | 1024                         | 0/1023 ~ 1023/1023      | -512 ~ 511                      |
| 11                  | 2048                         | 0/2047 ~ 2047/2047      | -1024 ~ 1023                    |

## 19.4 Register Description

This section describes the control/status registers of the design. Software should read and write these registers using 32-bits accesses.

### 19.4.1 Registers Summary

| <b>Name</b>             | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                       |
|-------------------------|---------------|-------------|--------------------|------------------------------------------|
| AUDIOPWM VERSION        | 0x0000        | W           | 0x01000000         | Version Number Register                  |
| AUDIOPWM XFER           | 0x0004        | W           | 0x00000000         | Transfer Control Register                |
| AUDIOPWM SRC CFG        | 0x0008        | W           | 0x00000000         | Source Data Configuration Register       |
| AUDIOPWM PWM CFG        | 0x0010        | W           | 0x00000000         | PWM Configuration Register               |
| AUDIOPWM PWM ST         | 0x0014        | W           | 0x00000000         | PWM Status Register                      |
| AUDIOPWM PWM BUF 0<br>1 | 0x0018        | W           | 0x00000000         | PWM Processed Data Buffer 0 & 1 Register |
| AUDIOPWM PWM BUF 2<br>3 | 0x001C        | W           | 0x00000000         | PWM Processed Data Buffer 2 & 3 Register |
| AUDIOPWM FIFO CFG       | 0x0020        | W           | 0x00000000         | FIFO Configuration Register              |
| AUDIOPWM FIFO LVL       | 0x0024        | W           | 0x00000000         | FIFO Level Register                      |
| AUDIOPWM FIFO INT EN    | 0x0028        | W           | 0x00000000         | FIFO Interrupt Enable Register           |
| AUDIOPWM FIFO INT ST    | 0x002C        | W           | 0x00000000         | FIFO Interrupt Status Register           |
| AUDIOPWM FIFO ENTRY     | 0x0080        | W           | 0x00000000         | FIFO Data Entry Register                 |

Notes:  
**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

#### AUDIOPWM VERSION

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                  |
|------------|-------------|--------------------|-------------------------------------|
| 31:0       | RO          | 0x01000000         | version<br>Version number: 1.0.0.0. |

#### AUDIOPWM XFER

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                       |
| 17:16      | WO          | 0x0                | 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:2       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                       |
| 1          | R/W SC      | 0x0                | lstop<br>Long stop transfer control.<br>1'b0: Nothing<br>1'b1: Long stop operation<br>If a 1 is written into this bit field, the transfer will stop and this bit will be auto cleared to 0 when read out all FIFO data. At this time, there are still 2 or 4 unsent words left in the buffers. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------|
| 0          | R/W<br>SC   | 0x0                | start<br>Transfer start or stop.<br>1'b0: Transfer stop<br>1'b1: Transfer start |

**AUDIOPWM\_SRC\_CFG**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                              |
| 22:16      | WO          | 0x00               | 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:7       | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                              |
| 6          | RW          | 0x0                | half_en<br>Half mode enable.<br>1'b0: All the 32 bits of data is valid (The lower 16 bits for channel 0 and the upper 16 bits for channel 1)<br>1'b1: Only the lower 16 bits of data is valid and the upper 16 bits of data is invalid<br>This bit field is significant only when 16 bits source data width is selected.                                              |
| 5          | RW          | 0x0                | align<br>Source data alignment.<br>1'b0: Right aligned<br>1'b1: Left aligned<br>This bit field is significant when 16 bits source data width is not selected.                                                                                                                                                                                                         |
| 4:0        | RW          | 0x00               | width<br>Source data width.<br>5'd0~5'd14: Reserved<br>5'd15: 16 bits<br>5'd16: 17 bits<br>5'd17: 18 bits<br>5'd18: 19 bits<br>5'd19: 20 bits<br>5'd20: 21 bits<br>5'd21: 22 bits<br>5'd22: 23 bits<br>5'd23: 24 bits<br>5'd24: 25 bits<br>5'd25: 26 bits<br>5'd26: 27 bits<br>5'd27: 28 bits<br>5'd28: 29 bits<br>5'd29: 30 bits<br>5'd30: 31 bits<br>5'd31: 32 bits |

**AUDIOPWM\_PWM\_CFG**

Address: Operational Base + offset (0x0010)

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:16 | WO   | 0x000       | 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:10 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9:8   | RW   | 0x0         | sample_width<br>Output sampling data width.<br>2'b00: 8 bits<br>2'b01: 9 bits<br>2'b10: 10 bits<br>2'b11: 11 bits                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7     | RW   | 0x0         | right_dis<br>Right channel output disable.<br>1'b0: Enable<br>1'b1: Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6     | RW   | 0x0         | left_dis<br>Left channel output disable.<br>1'b0: Enable<br>1'b1: Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5     | RW   | 0x0         | out_swap<br>Output swap.<br>1'b0: Audio PWM channel 0 for left channel and Audio PWM channel 1 for right channel (Default output IO map)<br>1'b1: Audio PWM channel 1 for left channel and Audio PWM channel 0 for right channel (Swap output IO map)                                                                                                                                                                                                                                                                                        |
| 4     | RW   | 0x0         | linear_interp_en<br>Linear interpolation mode enable.<br>1'b0: Disable<br>1'b1: Enable<br>Note that linear interpolation only support interpolation rate = 1/3/7/15.                                                                                                                                                                                                                                                                                                                                                                         |
| 3:0   | RW   | 0x0         | interp_rate<br>Interpolation rate.<br>4'd0: Interpolate 0 point<br>4'd1: Interpolate 1 point<br>4'd2: Interpolate 2 points<br>4'd3: Interpolate 3 points<br>4'd4: Interpolate 4 points<br>4'd5: Interpolate 5 points<br>4'd6: Interpolate 6 points<br>4'd7: Interpolate 7 points<br>4'd8: Interpolate 8 points<br>4'd9: Interpolate 9 points<br>4'd10: Interpolate 10 points<br>4'd11: Interpolate 11 points<br>4'd12: Interpolate 12 points<br>4'd13: Interpolate 13 points<br>4'd14: Interpolate 14 points<br>4'd15: Interpolate 15 points |

**AUDIOPWM PWM ST**

Address: Operational Base + offset (0x0014)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:2 | RO   | 0x00000000  | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | pwm_busy<br>Audio PWM status.<br>1'b0: Audio PWM is idle<br>1'b1: Audio PWM is busy |
| 0          | RO          | 0x0                | fifo_busy<br>TX FIFO status.<br>1'b0: FIFO is idle<br>1'b1: FIFO is busy            |

**AUDIOPWM PWM BUF 01**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                            |
|------------|-------------|--------------------|-----------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                      |
| 26:16      | RO          | 0x000              | pwm_buf_1<br>Current data value of channel 1. |
| 15:11      | RO          | 0x00               | reserved                                      |
| 10:0       | RO          | 0x000              | pwm_buf_0<br>Current data value of channel 0. |

**AUDIOPWM PWM BUF 23**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                         |
|------------|-------------|--------------------|--------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                   |
| 26:16      | RO          | 0x000              | pwm_buf_3<br>Next data value of channel 1. |
| 15:11      | RO          | 0x00               | reserved                                   |
| 10:0       | RO          | 0x000              | pwm_buf_2<br>Next data value of channel 0. |

**AUDIOPWM FIFO CFG**

Address: Operational Base + offset (0x0020)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                             |
| 27:16      | WO          | 0x000              | 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:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                             |
| 12:8       | RW          | 0x00               | almost_full_watermark<br>TX FIFO almost full watermark.<br>When the number of valid FIFO data entries is less than or equal to the value in this bit field, the almost full interrupt is triggered.                                                                                  |
| 7          | RW          | 0x0                | dma_en<br>DMA TX request enable.<br>1'b0: Disable<br>1'b1: Enable                                                                                                                                                                                                                    |
| 6:5        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                             |
| 4:0        | RW          | 0x00               | dma_watermark<br>DMA watermark.<br>This bit field controls the level at which a DMA request is made by the transmit logic. The watermark level = watermark + 1; that is, dma_tx_req is generated when the number of valid FIFO data entries is greater than the value in this field. |

**AUDIOPWM FIFO\_LVL**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                   |
| 5:0        | RO          | 0x00               | fifo_space2full<br>TX FIFO space2full level.<br>Indicates the number of valid data entries in the TX FIFO. |

**AUDIOPWM FIFO\_INT\_EN**

Address: Operational Base + offset (0x0028)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                              |
| 2          | RW          | 0x0                | empty_int_en<br>TX FIFO empty interrupt enable.<br>1'b0: Disable<br>1'b1: Enable      |
| 1          | RW          | 0x0                | overrun_int_en<br>TX FIFO overrun interrupt enable.<br>1'b0: Disable<br>1'b1: Enable  |
| 0          | RW          | 0x0                | full_int_en<br>TX FIFO almost full interrupt enable.<br>1'b0: Disable<br>1'b1: Enable |

**AUDIOPWM FIFO\_INT\_ST**

Address: Operational Base + offset (0x002C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------|
| 31:3       | RO          | 0x00000000         | reserved                                                                                        |
| 2          | RW          | 0x0                | empty_int_st<br>TX FIFO empty interrupt status.<br>1'b0: Nothing<br>1'b1: FIFO empty            |
| 1          | RW          | 0x0                | overrun_int_st<br>TX FIFO overrun interrupt status.<br>1'b0: Nothing<br>1'b1: FIFO overrun      |
| 0          | RO          | 0x0                | full_int_st<br>TX FIFO almost full interrupt status.<br>1'b0: Nothing<br>1'b1: FIFO almost full |

**AUDIOPWM FIFO\_ENTRY**

Address: Operational Base + offset (0x0080)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------|
| 31:0       | WO          | 0x00000000         | fifo_data_entry<br>External DMAC or application writes data to this address. |

**19.5 Interface Description**

Table 19-2 Audio PWM Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>                                                              | <b>IOMUX Setting</b>           |
|-------------------|------------------|------------------------------------------------------------------------------|--------------------------------|
| AUDPWM_L          | O                | I2S0_SDO2_SDI2_M0/PDM_SDI2_M0/AUD_PWM_L_M0/I2C4_SCL_M1/AUDDSM_RN/GP_IO4_A0_d | GRF_GPIO4A_IOMUX_L[2:0]=3'b011 |

| <b>Module Pin</b> | <b>Direction</b> | <b>Pad Name</b>                                                                  | <b>IOMUX Setting</b>             |
|-------------------|------------------|----------------------------------------------------------------------------------|----------------------------------|
|                   |                  | I2S0_LRCK_TX_M0/ACODEC_DAC_SYNC/A<br>UDPWM_L_M1/AUDDSM_LN/GPIO3_D3_d             | GRF_GPIO3D_IOMUX_L[14:12]=3'b100 |
| AUDPWM_R          | O                | I2S0_SDO3_SD1_M0/PDM_SD1_M0/AUD<br>PWM_R_M0/I2C4_SDA_M1/AUDDSM_RP/G<br>PIO4_A1_d | GRF_GPIO4A_IOMUX_L[6:4]=3'b011   |
|                   |                  | I2S0_SDO0_M0/ACODEC_DAC_DATAR/AU<br>DPWM_R_M1/AUDDSM_LP/GPIO3_D5_d               | GRF_GPIO3D_IOMUX_H[6:4]=3'b100   |

Notes: Unused Module Pin is tied to zero! I=input, O=output, I/O=input/output, bidirectional

## 19.6 Application Notes

- When the AUDIO\_PWM\_FIFO\_CFG.dma\_en is set to 1 and the number of the valid FIFO data entries is greater than AUDIO\_PWM\_FIFO\_CFG.dma\_watermark, the Audio PWM will generate a DMA request to the external DMAC. And then the required word-aligned data will be written to the FIFO if the DMAC has been correctly configured.
- Start the data transfer and output the processed PWM signals to the IO by configuring AUDIO\_PWM\_XFER.start to 1. If this bit is set to 0, the processing will terminate immediately.
- Generally, you can also stop the processing when all the FIFO data has been read out by configuring AUDIO\_PWM\_XFER.lstop to 1. In this way, the long stop bit will be auto cleared to 0 when the FIFO is empty. You should wait for the FIFO and the control logic of the Audio PWM to be idle by polling AUDIO\_PWM\_PWM\_ST.
- If the FIFO is empty but the processing is still running, the output level will always be low.
- You can enable the FIFO interrupt by configuring AUDIO\_PWM\_FIFO\_INT\_EN and query the interrupt status from AUDIO\_PWM\_FIFO\_INT\_ST. Writing 1 to the interrupt status bit of overrun or empty will clear it to 0, but the bit of almost full cannot be cleared by this means. Note that the FIFO overrun interrupt cannot occur in application.
- When the linear interpolation mode is enabled, you must interpolate 1/3/7/15 points by configuring AUDIO\_PWM\_PWM\_CFG.interp\_rate.
- Although the left and right channels are masked, the whole processing logic of the Audio PWM is still running.
- The required clock frequency = the audio sample rate \* the duty cycle resolution \* (the interpolation rate + 1). For example, when the audio sample rate is 16KHz, the output width is 11bits, and interpolate 1 point, the frequency of sclk\_aud pwm =  $16K * (2^{11}) * (1+1) = 65.536MHz$ . You should configuring the CRU to generate the accurate divided clock.

# Chapter 20 Pulse Density Modulation Interface Controller

## 20.1 Overview

The PDM interface controller and decoder support mono PDM format. It integrates a clock generator driving the PDM microphone and embeds filters which decimate the incoming bit stream to obtain most common audio rates.

PDM supports the following features:

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

## 20.2 Block Diagram



Fig.20-1 PDM Block Diagram

### System Interface

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

### Clock Generator

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

## Receiver

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

## Receive FIFO

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

## 20.3 Function Description

### 20.3.1 AHB Interface

There is an AHB slave interface in PDM. It is responsible for accessing registers.

### 20.3.2 PDM Interface

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

Following shows two cases of usage of the PDM, but all configurations are possible with stereo and mono digital microphones.



Fig.20-2 PDM with Eight Mono MIC



Fig.20-3 PDM with Four Stereo MIC

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



Fig.20-4 PDM interface diagram with external MIC

### 20.3.3 Digital Filter

The external PDM MIC generates a PDM stream of bits and transfers it in one period or one half-period of the clock provided by the PDM. The aim of the PDM is to process data from the PDM interface, decimate and filter the data, and store the processed data in the FIFO.

The four paths are identical. Each path is composed of a left and a right channel. The PDM interface delivers eight parallel data of 1bit. Each bit goes to a filter. The aim of the filter is to limit the noise and export PCM format audio data.

### 20.3.4 Frequency Configuration

MCLK is the source clock signal. PDM\_CLK is the output clocks generated in the PDM and is fed to the external microphones. They are also the internal clock of the external microphones. User must take care about the frequency of PDM\_CLK when selecting the source clock (MCLK).



Fig.20-5 PDM Clock Structure

Table 20-1 Relation between PDM\_CLK and Sample Rate

| PDM_CLK   | Sample Rate                                     |
|-----------|-------------------------------------------------|
| 3.072MHz  | 12kHz, 24kHz, 48kHz, 96kHz, 192kHz              |
| 2.8224MHz | 11.025kHz, 22.05kHz, 44.1kHz, 88.2kHz, 176.4kHz |
| 2.048MHz  | 8kHz, 16kHz, 32kHz, 64kHz, 128kHz               |

## 20.4 Register Description

### 20.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

### 20.4.2 Registers Summary

| Name                | Offset | Size | Reset Value | Description                           |
|---------------------|--------|------|-------------|---------------------------------------|
| PDM_SYSCONFIG       | 0x0000 | W    | 0x00000000  | PDM System Configure Register         |
| PDM_CTRL0           | 0x0004 | W    | 0x78000377  | PDM Control Register 0                |
| PDM_CTRL1           | 0x0008 | W    | 0x0bb8ea60  | PDM Control Register 1                |
| PDM_CLK_CTRL        | 0x000c | W    | 0x0000e401  | PDM Clock Control Register            |
| PDM_HPF_CTRL        | 0x0010 | W    | 0x00000000  | PDM High-pass Filter Control Register |
| PDM_FIFO_CTRL       | 0x0014 | W    | 0x00000000  | PDM FIFO Control Register             |
| PDM_DMA_CTRL        | 0x0018 | W    | 0x0000001f  | PDM DMA Control Register              |
| PDM_INT_EN          | 0x001c | W    | 0x00000000  | PDM Interrupt Enable Register         |
| PDM_INT_CLR         | 0x0020 | W    | 0x00000000  | PDM Interrupt Clear Register          |
| PDM_INT_ST          | 0x0024 | W    | 0x00000000  | PDM Interrupt Status Register         |
| PDM_RXFIFO_DATA_REG | 0x0030 | W    | 0x00000000  | PDM Receive FIFO Data Register        |
| PDM_DATA0R_REG      | 0x0034 | W    | 0x00000000  | PDM Path0 Right Channel Data Register |
| PDM_DATA0L_REG      | 0x0038 | W    | 0x00000000  | PDM Path0 Left Channel Data Register  |
| PDM_DATA1R_REG      | 0x003c | W    | 0x00000000  | PDM Path1 Right Channel Data Register |
| PDM_DATA1L_REG      | 0x0040 | W    | 0x00000000  | PDM Path1 Left Channel Data Register  |
| PDM_DATA2R_REG      | 0x0044 | W    | 0x00000000  | PDM Path2 Right Channel Data Register |
| PDM_DATA2L_REG      | 0x0048 | W    | 0x00000000  | PDM Path2 Left Channel Data Register  |
| PDM_DATA3R_REG      | 0x004c | W    | 0x00000000  | PDM Path3 Right Channel Data Register |

| Name           | Offset | Size | Reset Value | Description                                  |
|----------------|--------|------|-------------|----------------------------------------------|
| PDM DATA3L_REG | 0x0050 | W    | 0x00000000  | PDM Path3 Left Channel Data Register         |
| PDM DATA VALID | 0x0054 | W    | 0x00000000  | PDM Path Data Valid Register                 |
| PDM VERSION    | 0x0058 | W    | 0x59313031  | PDM Version Register                         |
| PDM INCR_RXDR  | 0x0400 | W    | 0x00000000  | Increment Address Receive FIFO Data Register |

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

## 20.4.3 Detail Registers Description

### PDM\_SYSCONFIG

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                          |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | RO   | 0x00000000  | reserved                                                                                                                                                                             |
| 2    | RW   | 0x0         | rx_start<br>RX transfer start bit<br>1'b0: Stop RX transfer<br>1'b1: Start RX transfer                                                                                               |
| 1    | RO   | 0x0         | reserved                                                                                                                                                                             |
| 0    | RW   | 0x0         | rx_clr<br>PDM RX logic clear<br>This is a self-cleared bit. High active.<br>Write 1'b1: Clear RX logic<br>Write 1'b0: No action<br>Read 1'b1: Clear ongoing<br>Read 1'b0: Clear done |

### PDM\_CTRL0

Address: Operational Base + offset (0x0004)

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | RW   | 0x0         | sjm_sel<br>Store justified mode<br>Can be written only when SYSCONFIG[2] is 0.<br>16bit~31bit DATA stored in 32 bits width FIFO.<br>If VDW select 16bit data, this bit is valid only when HWT select<br>1. Because if HWT is 0, every FIFO unit contains two 16bit data<br>and 32 bit space is full, it is impossible to choose justified mode.<br>1'b0: Right justified<br>1'b1: Left justified |
| 30  | RW   | 0x1         | path3_en<br>Path 3 enable<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                                                                                                                                                                       |
| 29  | RW   | 0x1         | path2_en<br>Path 2 enable<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                                                                                                                                                                       |
| 28  | RW   | 0x1         | path1_en<br>Path 1 enable<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                                                                                                                                                                       |
| 27  | RW   | 0x1         | path0_en<br>Path 0 enable<br>1'b1: Enable<br>1'b0: Disable                                                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26         | RW          | 0x0                | hwt_en<br>Halfword word transform<br>Only valid when VDW select 16bit data.<br>1'b0: 32 bit data valid to AHB/APB bus. Low 16 bit for left channel and high 16 bit for right channel.<br>1'b1: Low 16bit data valid to AHB/APB bus, high 16 bit data invalid |
| 25         | RW          | 0x0                | filter_gate_en<br>Filter gate enable<br>If some filters not work, the filter and its corresponding memory clock will be gated if filter_gate_en is 1'b1, otherwise the clock will be still active.                                                           |
| 24         | RW          | 0x0                | sig_scale_mode<br>Signal scale mode select<br>1'b0: CIC outputs the normal latitude.<br>1'b1: Scale the CIC outputs to half of the normal latitude and scale 2 times after hpf-filter.                                                                       |
| 23:16      | RW          | 0x00               | int_div_20x_con<br>Integer divider for PDM filter operation.                                                                                                                                                                                                 |
| 15:8       | RW          | 0x03               | int_div_con<br>Integer divider<br>Can be written only when SYSCONFIG[2] is 0.                                                                                                                                                                                |
| 7:5        | RW          | 0x3                | sample_rate_sel<br>Selects which kind of sample rate.<br>3'b000: 12kHz/11.024kHz/8kHz<br>3'b001: 24kHz/22.05kHz/16kHz<br>3'b010: 32kHz<br>3'b011: 48kHz/44.1kHz<br>3'b100: 96kHz/88.2kHz/64kHz<br>3'b101~3'b111: 192kHz/176.4kHz/128kHz                      |
| 4:0        | RW          | 0x17               | data_vld_width<br>Can be written only when SYSCONFIG[2] is 0.<br>Valid Data width<br>0~14: Reserved<br>15: 16bit<br>16: 17bit<br>17: 18bit<br>18: 19bit<br>.....<br>n: (n+1)bit<br>.....<br>23: 24bit                                                        |

**PDM CTRL1**

Address: Operational Base + offset (0x0008)

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

**PDM CLK CTRL**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                          |
| 15:14      | RW          | 0x3                | rx_path_select3<br>RX Path Select<br>2'b00: Path3 data from PDM data0<br>2'b01: Path3 data from PDM data1<br>2'b10: Path3 data from PDM data2<br>2'b11: Path3 data from PDM data3 |
| 13:12      | RW          | 0x2                | rx_path_select2<br>RX Path Select<br>2'b00: Path2 data from PDM data0<br>2'b01: Path2 data from PDM data1<br>2'b10: Path2 data from PDM data2<br>2'b11: Path2 data from PDM data3 |
| 11:10      | RW          | 0x1                | rx_path_select1<br>RX Path Select<br>2'b00: Path1 data from PDM data0<br>2'b01: Path1 data from PDM data1<br>2'b10: Path1 data from PDM data2<br>2'b11: Path1 data from PDM data3 |
| 9:8        | RW          | 0x0                | rx_path_select0<br>RX Path Select<br>2'b00: Path0 data from PDM data0<br>2'b01: Path0 data from PDM data1<br>2'b10: Path0 data from PDM data2<br>2'b11: Path0 data from PDM data3 |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                          |
| 5          | RW          | 0x0                | pdm_clk_en<br>PDM clk enable, working at PDM mode.<br>Can be written only when SYSCONFIG[2] is 0.<br>1'b0: PDM clk disable<br>1'b1: PDM clk enable                                |
| 4          | RW          | 0x0                | div_type_sel<br>Divider type select signal<br>Can be written only when SYSCONFIG[2] is 0.<br>1'b0: Fraction divider<br>1'b1: Integer divider                                      |
| 3          | RW          | 0x0                | lr_ch_ex<br>Left and right channel data exchange<br>1'b0: Not inverted<br>1'b1: Inverted                                                                                          |
| 2          | RW          | 0x0                | fir_com_bps<br>Fir compensate filter bypass<br>1'b0: Not bypass<br>1'b1: Bypass                                                                                                   |
| 1:0        | RW          | 0x01               | cic_ds_ratio<br>CIC filter decimation ratio<br>2'b00: 16 times decimation<br>2'b01: 8 times decimation<br>2'b10: 4 times decimation<br>other: 8 times decimation                  |

**PDM HPF CTRL**

Address: Operational Base + offset (0x0010)

| <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          | RW          | 0x0                | hpfile<br>High-pass filter enable for left channel<br>1'b0: High pass filter for right channel is disabled.<br>1'b1: High pass filter for right channel is enabled. |
| 2          | RW          | 0x0                | hpfre<br>High-pass filter enable for right channel<br>1'b0: High pass filter for right channel is disabled.<br>1'b1: High pass filter for right channel is enabled. |
| 1:0        | RW          | 0x0                | hpf_cf<br>High-pass filter configure<br>2'b00: 3.79Hz<br>2'b01: 60Hz<br>2'b10: 243Hz<br>2'b11: 493Hz                                                                |

**PDM FIFO CTRL**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:15      | RO          | 0x000000           | reserved                                                                                                                                                                    |
| 14:8       | RW          | 0x00               | 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 threshold interrupt is triggered. |
| 7:0        | RO          | 0x00               | rfl<br>Receive FIFO level<br>Contains the number of valid data entries in the receive FIFO.                                                                                 |

**PDM DMA CTRL**

Address: Operational Base + offset (0x0018)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                  |
| 8          | RW          | 0x0                | rde<br>Receive DMA enable<br>1'b0: Receive DMA disabled<br>1'b1: Receive DMA enabled                                                                                                                                                                                                      |
| 7          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                  |
| 6:0        | 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. |

**PDM INT EN**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                               |
| 1          | RW          | 0x0                | rxoie<br>RX overflow interrupt 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                | rxftie<br>RX full threshold interrupt enable<br>1'b0: Disable<br>1'b1: Enable |

**PDM INT 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                | rxoic<br>RX overflow interrupt clear (high active and auto cleared). |

**PDM INT ST**

Address: Operational Base + offset (0x0024)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                        |
| 1          | RO          | 0x0                | rxoi<br>RX overflow interrupt<br>1'b0: Inactive<br>1'b1: Active |
| 0          | RO          | 0x0                | rfxi<br>RX full interrupt<br>1'b0: Inactive<br>1'b1: Active     |

**PDM RXFIFO DATA REG**

Address: Operational Base + offset (0x0030)

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

**PDM DATA0R REG**

Address: Operational Base + offset (0x0034)

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

**PDM DATA0L REG**

Address: Operational Base + offset (0x0038)

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

**PDM DATA1R REG**

Address: Operational Base + offset (0x003c)

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

**PDM DATA1L REG**

Address: Operational Base + offset (0x0040)

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

**PDM DATA2R REG**

Address: Operational Base + offset (0x0044)

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

**PDM DATA2L REG**

Address: Operational Base + offset (0x0048)

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

**PDM DATA3R REG**

Address: Operational Base + offset (0x004c)

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

**PDM DATA3L REG**

Address: Operational Base + offset (0x0050)

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

**PDM DATA VALID**

Address: Operational Base + offset (0x0054)

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

**PDM VERSION**

Address: Operational Base + offset (0x0058)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>     |
|------------|-------------|--------------------|------------------------|
| 31:0       | RW          | 0x59313031         | version<br>PDM version |

**PDM INCR RXDR**

Address: Operational Base + offset (0x0400)

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

## 20.5 Interface Description

There are two groups of PDM IO interfaces embedded in the chip. Following figure shows the group 0 and group 1 PDM IO interface respectively.

Table 20-2 Group 0 PDM IO Interface Description

| Module Pin  | Direction | Pin Name                                                                           | IOMUX Setting                    |
|-------------|-----------|------------------------------------------------------------------------------------|----------------------------------|
| o_pdm_clk   | O         | I2S0_LRCK_RX_M0/PDM_CLK0_M0/ACOD<br>EC_ADC_SYNC/GPIO3_D4_d                         | GRF_GPIO3D_IOMUX_H[2:0]=3'b010   |
| o_pdm_clk   | O         | I2S0_SCLK_RX_M0/PDM_CLK1_M0/ACOD<br>EC_ADC_CLK/GPIO3_D1_d                          | GRF_GPIO3D_IOMUX_L[6:4]=3'b010   |
| i_pdm_data0 | I         | I2S0_SDIO0_M0/PDM_SDIO_M0/ACODEC_DAC_DATAL/GPIO3_D6_d                              | GRF_GPIO3D_IOMUX_H[10:8]=3'b010  |
| i_pdm_data1 | I         | I2S0_SDO3_SDI1_M0/PDM_SDI1_M0/AU<br>DPWM_R_M0/I2C4_SDA_M1/AUDDSM_RP<br>/GPIO4_A1_d | GRF_GPIO4A_IOMUX_L[6:4]=3'b010   |
| i_pdm_data2 | I         | I2S0_SDO2_SDI2_M0/PDM_SDI2_M0/AU<br>DPWM_L_M0/I2C4_SCL_M1/AUDDSM_RN<br>/GPIO4_A0_d | GRF_GPIO4A_IOMUX_L[2:0]=3'b010   |
| i_pdm_data3 | I         | I2S0_SDO1_SDI3_M0/PDM_SDI3_M0/AC<br>ODEC_ADC_DATA/GPIO3_D7_d                       | GRF_GPIO3D_IOMUX_H[14:12]=3'b010 |

Notes: I=Input, O=Output, I/O=Input/Output, bidirectional

Table 20-3 Group 1 PDM IO Interface Description

| Module Pin  | Direction | Pin Name                                                     | IOMUX Setting                    |
|-------------|-----------|--------------------------------------------------------------|----------------------------------|
| o_pdm_clk   | O         | CIF_D12_M0/RGMII_CLK_M0/PDM_CLK0_M1/SPI1_CLK_M0/GPIO3_C0_d   | GRF_GPIO3C_IOMUX_L[2:0]=3'b011   |
| o_pdm_clk   | O         | CIF_D15_M0/RGMII_MDIO_M0/PDM_CLK1_M1/GPIO3_C3_d              | GRF_GPIO3C_IOMUX_L[14:12]=3'b011 |
| i_pdm_data0 | I         | CIF_D13_M0/RGMII_RXDV_M0/PDM_SDI0_M1/GPIO3_C1_d              | GRF_GPIO3C_IOMUX_L[6:4]=3'b011   |
| i_pdm_data1 | I         | CIF_D14_M0/RGMII_RXER_M0/PDM_SDI1_M1/GPIO3_C2_d              | GRF_GPIO3C_IOMUX_L[10:8]=3'b011  |
| i_pdm_data2 | I         | CIF_D10_M0/RGMII_RXD0_M0/PDM_SDI2_M1/SPI1_MOSI_M0/GPIO3_B6_d | GRF_GPIO3B_IOMUX_H[10:8]=3'b011  |
| i_pdm_data3 | I         | CIF_D11_M0/RGMII_RXD1_M0/PDM_SDI3_M1/SPI1_MISO_M0/GPIO3_B7_d | GRF_GPIO3B_IOMUX_H[14:12]=3'b011 |

By configuring GRF\_IOFUNC\_SEL0[12] to 1'b0, the input bit stream from group 0 IO interface will be fed into PDM. Otherwise the group 1 IO interface will be selected.

## 20.6 Application Notes



Fig.20-6 PDM Operation Flow

## Chapter 21 CAN

### 21.1 Overview

CAN (Controller Area Network) bus is a robust vehicle bus standard designed to allow micro controllers and devices to communicate with each other in applications without a host computer. It is a message-based protocol, designed originally for multiplex electrical wiring within automobiles to save on copper, but is also used in many other contexts.

CAN controller supports the following features:

- Support CAN 2.0B protocol
- Support 32-bit APB bus
- Support transmit or receive standard frame
- Support transmit or receive extended frame
- Support transmit or receive data frame, remote frame, overload frame, error frame and frame interval
- Support transmit or receive error count
- Support ID mask
- Support bit error, bit stuffing error, form error, ack error and crc error
- Support 7 types of interrupt and all interrupt can be masked
- Support CAN controller status query
- Support capture the bit position of arbitration section where the arbitration was lost
- Support error code check
- Support self test mode
- Support single sample and three sample configurable
- Support SJW(reSyncronization Jump Width) configurable
- Support BRP(system prescaler coefficient) configurable
- Support bit timing configurable
- Support loop-back mode for self-test operation
- Support silent mode for debug
- Support receive self-transmit data mode(rxstx\_mode)
- Support TX data and RX data order select
- Support RX data cover mode
- Support auto retransmission mode
- Support auto bus on after bus-off state
- Support space\_rx\_mode

### 21.2 Block Diagram



Fig. 21-1 CAN Controller Block Diagram

## 21.3 Function Description

### 21.3.1 RECEIVING FILTER

The receiving filter performs filtering using the acceptance ID register and the ID mask register. The receiving filter uses one-time filtering. After sampling all the bits of the ID, it is compared with the ID register. It is not a comparison every time a bit is sampled. And don't check the bit in the ID mask register that is 1. After all the ID bits have passed the filtering, the controller considers the frame data as the desired ID, thereby performing the next operation.

### 21.3.2 BIT TIMING

#### 21.3.2.1 Bit Timing Logic

The bit timing logic controls the sampling point position through the buffer bits in the timing register to ensure the accuracy of the data sampling. The bit timing logic receives the clock frequency division signal for identification, sets the bus timing parameters, establishes synchronization parameters, and adjusts the bus transmission rate. At the same time, the bus is monitored and the message to be sent is transmitted to the bus at the set timing.

According to the provisions of the CAN protocol: the CAN bus is always at a high level when no message is sent, and the continuous recessive bit is monitored on the bus. At this time, the bus is in an idle state, and the arbitration priority is low, ready to receive data at any time. When the bus detects a transition from a recessive bit to a dominant bit, it is proved that the frame start bit starts transmitting, and the bus performs a hard synchronization in the bit start sync segment. Then, in the process of receiving the message, once the edge of the transition close to the sampling point is detected and the edge of the edge and the synchronization segment have a phase error lower than the synchronization width (SJW is taken when the value exceeds SJW), the controller executes once resynchronization, resynchronization can be performed multiple times during one data transmission.

#### 21.3.2.2 Bit Timing Definition

The transmission time of each bit is divided into 4 parts:

$$t_{nbt} = t_{sync\_seg} + t_{prop\_seg} + t_{phase\_seg1} + t_{phase\_seg2}$$

$t_{sync\_seg}$ ,  $t_{prop\_seg}$ ,  $t_{phase\_seg1}$  and  $t_{phase\_seg2}$  are integer multiples of the unit time( $tsclk$ ), and this unit time is a specific multiple of the system clock, which is determined by the division factor BRP in the bus timing register: 1. The counter is obtained by the BRP operation; 2. The system clock  $clk$  is counted by the counter; 3. When the limit is reached, a clock with a period of  $tsclk$  is generated.

In the system design, considering the cyclical occurrence of each time period, a state machine with three states is used in the bit timing design. The three states correspond to the sync segment( $sync\_seg$ ) and the phase buffer segment 1 ( $phase\_seg1=phase\_seg1+prog\_seg$ ) and the phase buffer segment 2 ( $phase\_seg2$ ), respectively. Where PHASE\_SEG1 range: 1~16; PHASE\_SEG2 range: 1~8; BRP range: 1~64.

$$t_{sync\_seg} = 1 \times tsclk$$

$$t_{prop\_seg} + t_{phase\_seg1} = tsclk \times (8 \times TSEG1.3 + 4 \times TSEG1.2 + 2 \times TSEG1.1 + TSEG1.0 + 1)$$

$$t_{phase\_seg2} = tsclk \times (4 \times TSEG2.2 + 2 \times TSEG2.1 + TSEG1.0 + 1)$$

Define a counter to count  $tsclk$ . When the count reaches the TSEG1, TSEG2 defined in the bus timing register and the length of the synchronization segment defined in the design, the system will generate the corresponding transition conditions: go\_seg1, go\_seg2, go\_sync. By judging these transition conditions, the control state machine cycles through the above three states.



Fig. 21-2 Bit timing FSM



Fig. 21-3 Bit timing waveform diagram

### 21.3.2.3 Sampling Point and Sending Point

**Sampling Point:** According to the agreement, the sample point sample\_point should be between phase\_seg1 and phase\_seg2. It is designed to be in the position of phase\_seg2 synchronization. The sampling pulse width is defined as one system clock cycle. Considering the accuracy of sampling, you can use the method of taking three samples to take the mean. The interval between each sample point is one tsclk.



Possible values are BRP = 000001, TSEG1 = 0101 and TSEG2 = 010.

Fig. 21-4 Three sampling diagram

**Sending Point:** The location of the transmission point(tx\_point) should be at the beginning of each bit time according to the protocol, and it is designed to synchronize it with the go\_sync signal. In addition, if it is in sync or resynchronize, tx\_point will be valid immediately.

### 21.3.2.4 Bit Synchronization

With the synchronization method, one or more nodes that satisfy the synchronization condition align their synchronization segments with the transmission data on the bus at a specific time. Synchronization occurs on the 1-to-0 transition edge in order to control the distance from the transition edge to the sample point. Two synchronization methods are defined in the CAN bus communication protocol: hard synchronization and resynchronization.

**Hard\_sync:** All nodes must be synchronized to the leading edge of the starting frame of the node that first started transmitting the message. At the beginning of each frame of data, a synchronization action is taken between the nodes.

Hard synchronization implementation method: determine whether the bus state meets the frame start condition specified in the protocol, and the node is not in the state of the data to be transmitted. At this time, a hard synchronization flag signal hard\_sync is generated, and the pulse width is a system clock; The hard\_sync entry is added to the control condition of the go\_seg1 signal, and go\_seg1 is valid immediately when the hard\_sync signal is '1'.

Therefore, once the hard synchronization condition is met, the system enters the phase\_seg1 segment, thereby achieving synchronization.



Fig. 21-5 Hard\_sync waveform diagram

**Resynchronization:** In addition to generating hard synchronization at the beginning of each frame of data, the CAN bus communication protocol also specifies the transmission of data for each frame. When the timing coordination between the nodes is not ideal, it will be resynchronized, so that the cooperation between the nodes is in a good state.

For the receiver, the bus changes it received should occur in the sync segment. Once the receiver's status violates this rule, the receiver will perform a resynchronization.

Two situations that require resynchronization:

1. The jump of the bus value '1' to '0' occurs between the sync segment and the sample point, which is a delay jump.
2. The jump of the bus value '1' to '0' occurs between the sample point and the sync segment, which is an early jump.



Fig. 21-6 Resynchronization

Resynchronization method:

1. Condition for resynchronization: the receiver is in a mode of receiving data (not inter-frame space or bus idle), and a resynchronization flag signal 'resync' is generated when a jump of the bus value '1' to '0' occurs.
2. According to the position of the resynchronization flag signal, it is determined that the abnormal jump is a delay jump or an early jump.
3. Counting the delay or the length of the advance by the counter.
4. In this bit, phase\_seg1 is added with a delay time or phase\_seg2 is subtracted from the advance time to obtain a new phase buffer time for the bit, thereby achieving synchronization.

### 21.3.3 STREAM PROCESS

#### 21.3.3.1 Data Buffering

The data cache includes two parts: a transmit buffer and a receive buffer. The data to be sent on the CAN bus is loaded into the memory area. This memory area is called the "transmission buffer"; The data received from the CAN bus is also stored in the memory area, which is called the "receiver buffer". The size of the buffer is 13 bytes, including 1 byte frame information, 2 to 4 byte identifiers (standard or extended frame), and 8 bytes of data.

After the CPU configures the transmission of the data information (frame information, identification code, data), the request bit is enabled. The data buffer sends the data to be sent to the bit stream processor, and splices into a parallel complete data to be transmitted (including the CRC check code) according to the current frame information.

The received message is placed in the receiving buffer. After receiving, the receiving completion interrupt will be generated. After receiving the interrupt, the CPU will read the data in the receiving buffer, and set CMD[1] to clear the receiving buffer, and STATE[0] will be 0. If the CPU does not read in time, STATE[1] will remain at 1. If a new message is received at this time, overflow will occur.

#### 21.3.3.2 Receive Data

According to the bus protocol, taking the data frame of the extended frame format as an example, the receiving data state machine is as follows:



Fig. 21-7 Receive data state diagram

Each state of the state machine corresponds to which "field" of the frame data the receiver is in when receiving data, and only one of all state flags is valid at the same time. The method of implementation is as follows:

Define a bit counter(bit\_cnt), add one to each sample point (provided by the bit timing module). At the same time, according to the current state of the state machine, it is determined in this state that the bit counter needs to count to what value (determined by the length of each field defined in the protocol) to generate a jump signal to the next state transition. Whenever a hopping signal is generated, the counter is cleared and ready to begin counting for the next state.

The receiving state machine ensures that the bus controller can automatically recognize the current receiving state when receiving data. After that, the data of each data field needs to be stored in the corresponding register according to different states, and then the next operation is performed.

#### 21.3.3.3 Transmit Data

Parallel data is serially transmitted to the bus according to a specific timing. The sending point is the tx\_point. The transmit counter is self-added in the valid data portion of the data frame, and is cleared when one frame of data is transmitted or the bus is in an error state.

The implementation is as follows:

1. Combine all the data to be sent into a completely parallel data chain according to the currently set frame type.

2. using tx\_pointer as a data link pointer, obtaining a serial data signal (tx\_bit) to be transmitted.
3. Determine what type of data to send according to the current state, and determine the data tx\_next to be sent at the next transmission time.
4. Synchronize the data transmission signal tx with the tx\_next through the transmission point tx\_point to obtain a true transmission signal tx.

#### **21.3.3.4 Bit Stuffing**

Bit stuffing is a function set to prevent burst errors. Add a bit of inversion data when the same level lasts 5 bits.

Sending unit: The data between the SOF and CRC segments when transmitting data frames and remote frames. If the same level lasts for 5 bits, the next bit (bit 6) is inserted with the level of the 1st bit and the first 5 bits.

Receiving unit: Data between SOF and CRC segments when receiving data frames and remote frames. If the same level lasts for 5 digits, the next bit (bit 6) needs to be deleted and received. If the 6th bit is the same level as the first 5 bits, it will be treated as an error and an error frame will be sent.



Fig. 21-8 Bit Stuffing

#### **21.3.4 ERROR PROCESS**

There are five types of errors. Multiple errors can occur at the same time.

##### **21.3.4.1 BIT ERROR**

A unit that is sending a bit on the bus also monitors the bus. A BIT ERROR has to be detected at that bit time, when the bit value that is monitored is different form the bit value that is sent. An exception is the sending of a 'recessive' bit during the stuffed bit stream of the ARBITRATION FIELD or during the ACK SLOT. Then no BIT ERROR occurs when a 'dominant' bit is monitored. A TRANSMITTER sending a PASSIVE ERROR FLAG and detecting a 'dominant' bit does not interpret this as a BIT ERROR.

##### **21.3.4.2 BIT STUFF ERROR**

A STUFF ERROR has to be detected at the bit time of the 6th consecutive equal bit level in a message field that should be coded by the method of bit stuffing.

##### **21.3.4.3 FORM ERROR**

A FORM ERROR has to be detected when a fixed-form bit field contains one or more illegal bits.

##### **21.3.4.4 ACK ERROR**

An ACK ERROR has to be detected by a transmitter whenever it does not monitor a 'dominant' bit during the ACK SLOT.

##### **21.3.4.5 CRC ERROR**

The CRC sequence consists of the result of the CRC calculation by the transmitter. The receivers calculate the CRC in the same way as the transmitter. A CRC ERROR has to be detected, if the calculated result is not the same as that received in the CRC sequence.

### **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                                                                                          |
|-----------------|--------|------|-------------|------------------------------------------------------------------------------------------------------|
| CAN_MODE        | 0x0000 | W    | 0x00000000  | CAN controller working mode configure register                                                       |
| CAN_CMD         | 0x0004 | W    | 0x00000000  | CAN command register                                                                                 |
| CAN_STATE       | 0x0008 | W    | 0x00000000  | CAN state register                                                                                   |
| CAN_INT         | 0x000c | W    | 0x00000000  | Interrupt state register                                                                             |
| CAN_INT_MASK    | 0x0010 | W    | 0x00000000  | Interrupt enable registers                                                                           |
| CAN_BITTIMING   | 0x0018 | W    | 0x00000000  | Bit timing configure register                                                                        |
| CAN_ARBITFAIL   | 0x0028 | W    | 0x00000000  | Arbit fail code register                                                                             |
| CAN_ERROR_CODE  | 0x002c | W    | 0x00000000  | Error code register                                                                                  |
| CAN_RXERRORCNT  | 0x0034 | W    | 0x00000000  | Receive error counter                                                                                |
| CAN_TXERRORCNT  | 0x0038 | W    | 0x00000000  | Transmit error counter                                                                               |
| CAN_IDCODE      | 0x003c | W    | 0x00000000  | CAN controller's identifier                                                                          |
| CAN_IDMASK      | 0x0040 | W    | 0x00000000  | Identification code bit mask register                                                                |
| CAN_TXFRAMEINFO | 0x0050 | W    | 0x00000000  | TX frame information configuration register                                                          |
| CAN_TXID        | 0x0054 | W    | 0x00000000  | CAN controller transmit ID                                                                           |
| CAN_TXDATA1     | 0x0058 | W    | 0x00000000  | CAN controller transmit DATA1                                                                        |
| CAN_TXDATA2     | 0x005c | W    | 0x00000000  | CAN controller transmit DATA2                                                                        |
| CAN_RXFRAMEINFO | 0x0060 | W    | 0x00000000  | RX frame information register.This register needs to be read(clear) before receiving the next frame. |
| CAN_RXID        | 0x0064 | W    | 0x00000000  | CAN controller receive ID.This register needs to be read(clear) before receiving the next frame.     |
| CAN_RXDATA1     | 0x0068 | W    | 0x00000000  | Receive Data Reg1.This register needs to be read(clear) before receiving the next frame.             |
| CAN_RXDATA2     | 0x006c | W    | 0x00000000  | Receive Data Reg2.This register needs to be read(clear) before receiving the next frame.             |
| CAN_RTL_VERSION | 0x0070 | W    | 0x00000021  | CAN RTL version                                                                                      |

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

## 21.4.3 Detail Registers Description

### CAN\_MODE

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                   |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | RO   | 0x00000     | reserved                                                                                                                                                                                                                                                                                                      |
| 12    | RW   | 0x0         | space_rx_mode<br>Interframe Spaceing RX Mode.<br>1'b0 : Enable.<br>1'b1 : Disable.                                                                                                                                                                                                                            |
| 11    | RW   | 0x0         | auto_bus_on<br>Auto Bus On Enable.<br>1'b0 : After the RKCAN has entered bus_off state, the software can start a bus_off_recovery sequence by resetting the work_mode to 0.<br>1'b1 : Automatic reset TEC/REC to bus_on after 128 occurrence of 11 consecutive recessive bits have been monitored on the bus. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RW          | 0x0                | auto_retx_mode<br>Auto Retransmission Mode.<br>1'b0 : Disable. RKCAN return to idle state after transmit DATA/RTR frame failed, and set tx_req to 0.<br>1'b1 : Enable. The RKCAN automatically retransmit frames which have lost arbitration or have been disturbed by errors during transmission.                                           |
| 9          | RW          | 0x0                | ovld_mode<br>Overload Mode.<br>1'b0: overload lite mode.<br>1'b1: overload extended mode. RKCAN                                                                                                                                                                                                                                              |
| 8          | RW          | 0x0                | cover_mode<br>Rx Data Cover Mode.<br>1'b0 : RKCAN can't receive new frame before receive registers cleared.<br>1'b1 : RKCAN can receive new frame before receive registers cleared, and new rxdata will cover old rxdata.                                                                                                                    |
| 7          | RW          | 0x0                | rxsort_mode<br>RX Data Sort Mode.<br>1'b0: The data received first is placed in the lower address.<br>1'b1: The data received first moves to the upper address, and the data received later is placed at the lower address.                                                                                                                  |
| 6          | RW          | 0x0                | txorder_mode<br>TX Data Order Mode.<br>1'b0: tx_data1[7:0] --> tx_data1[15:8] --> tx_data1[23:16] --> tx_data1[31:24] --> tx_data2[7:0] --> tx_data2[15:8] --> tx_data2[23:16] --> tx_data2[31:24].<br>1'b1: tx_data2[31:0] --> tx_data1[31:0].                                                                                              |
| 5          | RW          | 0x0                | rxstx_mode<br>Receive Self Transmit data mode.<br>1'b0: Disable;<br>1'b1: Enable. When the RKCAN sends data, it can also receive the data sent by itself.                                                                                                                                                                                    |
| 4          | RW          | 0x0                | lback_mode<br>Loopback Mode.<br>1'b0: Disable.<br>1'b1: Enable.                                                                                                                                                                                                                                                                              |
| 3          | RW          | 0x0                | silent_mode<br>Silent Mode.<br>1'b0: Disable.<br>1'b1: Enable.                                                                                                                                                                                                                                                                               |
| 2          | RW          | 0x0                | self_test<br>Self check ACK slot when TX frame.<br>1'b0: Normal<br>1'b1: Self test mode. When in self test mode, the receiver does not need to return an ACK signal when receiving data. Therefore, no ack_error will occur in self test mode. When in 'lback_mode' or 'silent_mode', it need to enable 'self_test' mode when sending frame. |
| 1          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                     |
| 0          | RW          | 0x0                | work_mode<br>Work Mode.<br>1'b0: Reset mode, CAN stop transmit and registers can be configured.<br>1'b1: Work mode, CAN enter the working mode, RX/TX data.                                                                                                                                                                                  |

**CAN CMD**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                     |
| 0          | WO          | 0x0                | <p>tx_req<br/>Transmit request enable<br/>1'b0: Disable;<br/>1'b1: Enable.</p> <p>When 'tx_req' is enable, the RKCAN is in the transmit mode and cannot receive frames from other CANs. When the RKCAN transmission frame complete, 'tx_req' is automatically cleared to 0. Also, when RKCAN is set 'work_mode' to 'reset_mode', tx_req is cleared to 0.</p> |

**CAN STATE**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:6       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                           |
| 5          | RO          | 0x0                | <p>bus_off_state<br/>1'b0: None<br/>1'b1: Bus off state: When the error counter is incremented to 255, the CAN controller will enter the bus off state, generate an error warning interrupt and enter reset mode, waiting for the CPU to restart. (rx/tx_err_cnt &gt;=32'd255)</p> |
| 4          | RO          | 0x0                | <p>error_warning_state<br/>1'b0: None<br/>1'b1: Error state: At least one error counter has reached the error warning threshold (rx/tx_err_cnt &gt;=32'd96)</p>                                                                                                                    |
| 3          | RO          | 0x0                | <p>tx_period<br/>1'b0: Not in transmitting state<br/>1'b1: CAN controller is in the transmitting state</p>                                                                                                                                                                         |
| 2          | RO          | 0x0                | <p>rx_period<br/>1'b0: Not in receiving state<br/>1'b1: CAN controller is in the receiving state</p>                                                                                                                                                                               |
| 1          | RO          | 0x0                | <p>tx_buffer_full<br/>Transmit buffer full flag bit<br/>1'b0: Not full<br/>1'b1: TX buffer is full. There is data in buffer waiting to be sent or being sent.</p>                                                                                                                  |
| 0          | RO          | 0x0                | <p>rx_buffer_full<br/>Receive buffer full flag bit<br/>1'b0: Not full<br/>1'b1: RX buffer is full. A complete message is stored in the buffer.</p>                                                                                                                                 |

**CAN INT**

Address: Operational Base + offset (0x000c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                                                                             |
| 6          | WO          | 0x0                | <p>error_int<br/>1'b0: None<br/>1'b1: CAN bus error interrupt. This interrupt is generated when a bus error is detected. Error details can refer to the ERROR_CODE register. Write 1 then clear.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | WO          | 0x0                | tx_arbit_fail_int<br>1'b0: None<br>1'b1: Arbitration loss interrupt. This interrupt is generated when the loss of arbitration is turned into a receiver. Write 1 then clear.                                                                                                    |
| 4          | WO          | 0x0                | passive_error_int<br>1'b0: None<br>1'b1: Passive error interrupt. This interrupt is generated when the controller enters an error passive state (at least one error counter reaches 127) or returns from the error passive state to the error active state. Write 1 then clear. |
| 3          | WO          | 0x0                | rx_buffer_overflow_int<br>Receive buffer overflow interrupt<br>1'b0: None<br>1'b1: This interrupt is generated when the data in the receiving buffer is not read and a new message is received. Write 1 then clear.                                                             |
| 2          | WO          | 0x0                | error_warning_int<br>Error warning interrupt<br>1'b0: None<br>1'b1: error_warning_int. This interrupt is generated when the error_warning_state bits change. Write 1 then clear.                                                                                                |
| 1          | WO          | 0x0                | tx_finish_int<br>Transmit finish interrupt<br>1'b0: None<br>1'b1: tx_finish_int. CAN controller sends the message and the buffer is empty. Write 1 then clear.                                                                                                                  |
| 0          | WO          | 0x0                | rx_finish_int<br>Receive finish interrupt<br>1'b0: None<br>1'b1: RX finish int. CAN controller has received the message and the rx_buffer is full. Write 1 then clear.                                                                                                          |

**CAN INT MASK**

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                | error_int<br>1'b0: Unmasked<br>1'b1: Masked              |
| 5          | RW          | 0x0                | tx_arbit_fail_int<br>1'b0: Unmasked<br>1'b1: Masked      |
| 4          | RW          | 0x0                | passive_error_int<br>1'b0: Unmasked<br>1'b1: Masked      |
| 3          | RW          | 0x0                | rx_buffer_overflow_int<br>1'b0: Unmasked<br>1'b1: Masked |
| 2          | RW          | 0x0                | error_warning_int_mask<br>1'b0: Unmasked<br>1'b1: Masked |
| 1          | RW          | 0x0                | tx_finish_int_mask<br>1'b0: Unmasked<br>1'b1: Masked     |

| Bit | Attr | Reset Value | Description                                          |
|-----|------|-------------|------------------------------------------------------|
| 0   | RW   | 0x0         | rx_finish_int_mask<br>1'b0: Unmasked<br>1'b1: Masked |

**CAN BITTIMING**

Address: Operational Base + offset (0x0018)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | RO   | 0x0000      | reserved                                                                                                                                                                                                |
| 16    | RW   | 0x0         | sample_mode<br>CAN controller sampling mode configuration register.<br>1'b0: Single sample mode<br>11'b1: Three sample mode                                                                             |
| 15:14 | RW   | 0x0         | sjw<br>SJW: reSynchronization Jump Width<br>Each unit has a synchronization error due to a clock frequency deviation or a transmission delay. SJW is to compensate for the maximum value of this error. |
| 13:8  | RW   | 0x00        | brp<br>brp: system prescaler coefficient<br>$Tsclk = 2 \times Tclk \times (brp + 1)$ .                                                                                                                  |
| 7     | RO   | 0x0         | reserved                                                                                                                                                                                                |
| 6:4   | RW   | 0x0         | tseg2<br>Phase buffer segment 2<br>$Tphase\_seg2 = Tsclk \times (tseg2 + 1)$                                                                                                                            |
| 3:0   | RW   | 0x0         | tseg1<br>Phase buffer segment 1<br>$Tphase\_seg1 = Tsclk \times (tseg1 + 1)$                                                                                                                            |

**CAN ARBITFAIL**

Address: Operational Base + offset (0x0028)

| Bit  | Attr | Reset Value | Description                                                                                                        |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------|
| 31:7 | RO   | 0x00000000  | reserved                                                                                                           |
| 6:0  | RO   | 0x00        | arbit_fail_code<br>This register indicates the bit position of arbitration section where the arbitration was lost. |

**CAN ERROR CODE**

Address: Operational Base + offset (0x002c)

| Bit   | Attr | Reset Value | Description                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | RO   | 0x00        | reserved                                                                                                                                  |
| 24:22 | RO   | 0x0         | error_type<br>Error type:<br>3'b000: BIT ERROR<br>3'b001: BIT STUFF ERROR<br>3'b010: FORM ERROR<br>3'b011: ACK ERROR<br>3'b100: CRC ERROR |
| 21    | RO   | 0x0         | error_direction<br>1'b0: TX error<br>1'b1: RX error                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20:14      | RW          | 0x00               | tx_error_position<br>Indicate transmit error position.<br>7'b000_0000 : TRANSMIT_IDLE.<br>7'b000_0010 : TRANSMIT_SOF_DATA.<br>7'b000_0100 : TRANSMIT_CRC.<br>7'b000_1000 : TRANSMIT_ACK_ROF.<br>7'b001_0000 : TRANSMIT_ACK.<br>7'b010_0000 : TRANSMIT_ERROR.<br>7'b100_0000 : TRANSMIT_OVERLOAD.                                                                                                                                                                                                                                                                                                         |
| 13:0       | RO          | 0x0000             | rx_error_position<br>Indicate receive error position<br>14'b0000000000000000: RECEIVE_IDLE<br>14'b0000000000000010: RECEIVE_ID1<br>14'b000000000000100: RECEIVE_RTR1~IDLE<br>14'b0000000000001000: RECEIVE_ID2<br>14'b00000000000010000: RECEIVE_RTR2~R1R0<br>14'b000000000100000: RECEIVE_R0<br>14'b000000001000000: RECEIVE_DLC<br>14'b000000010000000: RECEIVE_DATA<br>14'b000001000000000: RECEIVE_CRC<br>14'b000010000000000: RECEIVE_CRC_LIM<br>14'b000100000000000: RECEIVE_ACK<br>14'b001000000000000: RECEIVE_ACK_LIM<br>14'b010000000000000: RECEIVE_EOF<br>14'b100000000000000: RECEIVE_SPACE |

**CAN\_RXERRORCNT**

Address: Operational Base + offset (0x0034)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                         |
| 7:0        | RO          | 0x00               | rx_err_cnt<br>Receive Error Counter(REC).<br>Actual state of the Receive Error Counter. Value between 0 and 127. |

**CAN\_TXERRORCNT**

Address: Operational Base + offset (0x0038)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x000000           | reserved                                                                                                           |
| 8:0        | RO          | 0x000              | tx_err_cnt<br>Transmit Error Counter(TEC).<br>Actual state of the Transmit Error Counter. Value between 0 and 255. |

**CAN\_IDCODE**

Address: Operational Base + offset (0x003c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                     |
| 28:0       | RW          | 0x00000000         | id_code<br>CAN controller ID code:<br>Standard frame ID: id_code[10:0];<br>Extended frame ID: id_code[28:0]. |

**CAN\_IDMASK**

Address: Operational Base + offset (0x0040)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                      |
|------------|-------------|--------------------|-----------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                |
| 28:0       | RW          | 0x00000000         | id_mask<br>[0]: Unmasked<br>[1]: Masked |

**CAN TXFRAMEINFO**

Address: Operational Base + offset (0x0050)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                   |
| 7          | RW          | 0x0                | txframe_format<br>1'b0: Standard frame<br>1'b1: Extended frame                                                                                                                                                                                             |
| 6          | RW          | 0x0                | tx_rtr<br>1'b0: Data frame<br>1'b1: Remote frame                                                                                                                                                                                                           |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                   |
| 3:0        | RW          | 0x0                | txdata_length<br>Transmit data length configure register.(unit:byte)<br>4'b0000: 0byte<br>4'b0001: 1byte<br>4'b0010: 2byte<br>4'b0011: 3byte<br>4'b0100: 4byte<br>4'b0101: 5byte<br>4'b0110: 6byte<br>4'b0111: 7byte<br>4'b1000: 8byte<br>others: reserved |

**CAN TXID**

Address: Operational Base + offset (0x0054)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>       |
|------------|-------------|--------------------|--------------------------|
| 31:29      | RO          | 0x0                | reserved                 |
| 28:0       | RW          | 0x00000000         | tx_id<br>can_tx_id[28:0] |

**CAN TXDATA1**

Address: Operational Base + offset (0x0058)

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

**CAN TXDATA2**

Address: Operational Base + offset (0x005c)

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

**CAN RXFRAMEINFO**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                             |
|------------|-------------|--------------------|----------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                       |
| 7          | WO          | 0x0                | rxframe_format<br>1'b0: Standard frame<br>1'b1: Extended frame |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | WO          | 0x0                | rx_rtr<br>1'b0: Data frame<br>1'b1: Remote frame                                                                                                                                                                                                |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                        |
| 3:0        | WO          | 0x0                | rxdata_length<br>Receive data length register.(unit:byte)<br>4'b0000: 0byte<br>4'b0001: 1byte<br>4'b0010: 2byte<br>4'b0011: 3byte<br>4'b0100: 4byte<br>4'b0101: 5byte<br>4'b0110: 6byte<br>4'b0111: 7byte<br>4'b1000: 8byte<br>others: reserved |

**CAN\_RXID**

Address: Operational Base + offset (0x0064)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>   |
|------------|-------------|--------------------|----------------------|
| 31:29      | RO          | 0x0                | reserved             |
| 28:0       | WO          | 0x00000000         | rx_id<br>rx_id[28:0] |

**CAN\_RXDATA1**

Address: Operational Base + offset (0x0068)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | WO          | 0x00000000         | rx_data1<br>rx_data1[31:0] |

**CAN\_RXDATA2**

Address: Operational Base + offset (0x006c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | WO          | 0x00000000         | rx_data2<br>rx_data2[31:0] |

**CAN\_RTL\_VERSION**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                  |
|------------|-------------|--------------------|-------------------------------------|
| 31:0       | RO          | 0x00000021         | version<br>CAN rtl version = 32'h21 |

## 21.5 Application Notes

### 21.5.1 Controller Initialization Flow

The controller must configure the registers after power-up or hardware reset. During the operation of the controller, a software reset request may be sent and reconfigured (re-initialized) as shown below. After the initialization is completed, the controller enters the working mode, sends the frame to be sent to the buffer, and then sets the "send request" flag of the command register to start transmitting.



Fig. 21-9 Initialization Flow

### 21.5.2 Loop-back Mode

The controller must configure the registers after power-up or hardware reset. During the operation of the controller, a software reset request may be sent and reconfigured (re-initialized) as shown below.



Fig. 21-10 Loop-back Mode

### 21.5.3 Silent Mode

The controller must configure the registers after power-up or hardware reset. During the operation of the controller, a software reset request may be sent and reconfigured (re-initialized) as shown below.



Fig. 21-11 Silent Mode

### 21.5.4 RXSTX Mode

- rxstx\_mode=0, RKCAN cannot receive the data sent by itself
- rxstx\_mode=1, RKCAN can receive the data sent by itself, and when the ID of the frame is the same as the ID\_CODE of RKCAN itself, RKCAN will store the frame information into CAN\_RXDATA1/2

### 21.5.5 TXORDER Mode

The TXORDER Mode is used to determine the order in which data is sent.

- txorder\_mode=0, Data transmission order is "tx\_data1[7:0] --> tx\_data1[15:8] --> tx\_data1[23:16] --> tx\_data1[31:24] --> tx\_data2[7:0] --> tx\_data2[15:8] --> tx\_data2[23:16] --> tx\_data2[31:24]"
- txorder\_mode=1, Data transmission order is "tx\_data2[31:0] --> tx\_data1[31:0]"

### 21.5.6 RXSORT Mode

The TXSORT Mode is used to determine how the received data is stored.

- rxsrt\_mode=0: The data received first is placed in the lower address
- rxsrt\_mode=1: The data received first moves to the upper address, and the data received later is placed at the lower address

### 21.5.7 Cover Mode

- cover\_mode=1'b0 : RKCAN can't receive new frame before receive registers cleared
- cover\_mode=1'b1 : RKCAN can receive new frame before receive registers cleared, and new rxdata will cover old rxdata

### 21.5.8 Overload Mode

According to the CAN protocol, a CAN transceiver will generate an OVERLOAD frame in three cases:

CASE1: When the CAN is used as a receiver, if it is necessary to delay the next frame.

CASE2: Detection of a dominant bit at the first and second bit of Intermission.

CASE3: If an CAN node samples a dominant bit at the eight bit (the last bit) of an ERROR DELIMITER or OVERLOAD DELIMITER.

- overload\_mode=0: Overload Lite Mode: RKCAN only generates overload frames in the CASE2
- overload\_mode=1: Overload Extended Mode: RKCAN can generates overload frames in all three cases

### 21.5.9 Auto\_retx Mode

- auto\_retx\_mode=0 : Disable. RKCAN return to idle state after transmit DATA/RTR frame failed, and set tx\_req to 0
- auto\_retx\_mode=1 : Enable. The RKCAN automatically retransmit frames which have lost arbitration or have been disturbed by errors during transmission

### 21.5.10 Auto Bus On

- auto\_bus\_on=0 : After the RKCAN has entered bus\_off state, the software can start a bus\_off\_recovery sequence by resetting the work\_mode to 0
- auto\_bus\_on=1 : Automatic reset TEC/REC to bus\_on after 128 occurrence of 11 consecutive recessive bits have been monitored on the bus

## **Chapter 22 Pulse Width Modulation (PWM)**

### **22.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 the 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 switch channel IO between channel 3 and channel0/1/2
  - Support a 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 2 main clock input, one is from crystal oscillator and the frequency is fixed, the other one is from PLL and the frequency can be configured. Each channel can select one of the clocks according to requirement.
- Support two-level frequency division.
- Available low-power mode to reduce power consumption when the channel is inactive.

## 22.2 Block Diagram



Fig. 22-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.

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

### 22.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. 22-2 PWM Capture Mode

The capture result can also 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, user can poll the status to judge whether a power key access.

### 22.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. 22-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. 22-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).

### 22.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. 22-5 PWM One-shot Center-aligned Output Mode

## 22.4 Register Description

### 22.4.1 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                               |

| Name                 | Offset | Size | Reset Value | Description                                                  |
|----------------------|--------|------|-------------|--------------------------------------------------------------|
| 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 |
| 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    | 0x02120B34  | 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                |

| Name                       | Offset | Size | Reset Value | Description                                |
|----------------------------|--------|------|-------------|--------------------------------------------|
| 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_PWRCAPTUR_E_VALUE | 0x00CC | W    | 0x00000000  | Channel 3 Power Key Capture Value Register |
| PWM_CHANNEL_IO_CTRL        | 0x00D0 | W    | 0x00000000  | Channel IO 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

## 22.4.2 Detail Registers Description

### PWM\_PWM0\_CNT

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                  |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x00000000  | 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>period_hpr</p> <p>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.</p> <p>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.</p> <p>The value ranges from 0 to (<math>2^{32}-1</math>).</p> |

**PWM PWM0 DUTY LPR**

Address: Operational Base + offset (0x0008)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>duty_lpr</p> <p>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.</p> <p>If PWM is operated at the capture mode, this value indicates the effective low polarity cycles of input waveform.</p> <p>This value is based on the PWM clock. The value ranges from 0 to (<math>2^{32}-1</math>).</p> |

**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               | <p>rpt</p> <p>This field defines the repeated effective periods of output waveform in one-shot mode. The value N means N+1 repeated effective periods.</p>                                                                  |
| 23:16      | RW          | 0x00               | <p>scale</p> <p>This field defines the scale factor applied to prescaled clock. The value N means the clock is divided by <math>2^N</math>. If N is 0, it means that the clock is divided by 512(<math>2^{256}</math>).</p> |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                    |
| 14:12      | RW          | 0x0                | <p>prescale</p> <p>This field defines the prescale factor applied to input clock. The value N means that the input clock is divided by <math>2^N</math>.</p>                                                                |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 prescaled 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                                                                                                                                                     |
| 2:1        | RW          | 0x0                | pwm_mode<br>2'b00: One shot mode. PWM produces the waveform within the repeated times defined by PWM0_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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| <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 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)

| <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. This value is based on the PWM clock.<br>The value ranges from 0 to ( $2^{32}-1$ ). |

**PWM\_PWM1\_DUTY\_LPR**

Address: Operational Base + offset (0x0018)

| <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\_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^9).                                                                 |
| 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         | RO          | 0x0                | reserved                                                                                                                                                                                                                                           |
| 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 prescaled 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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                                     |
| 2:1        | RW          | 0x0                | pwm_mode<br>2'b00: One shot mode. PWM produces the waveform within the repeated times defined by PWM1_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. This value is based on the PWM clock.<br>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         | <p>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.</p> <p>If PWM is operated at the capture mode, this value indicates the effective low polarity cycles of input waveform.</p> <p>This value is based on the PWM clock. The value ranges from 0 to (<math>2^{32}-1</math>).</p> |

**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               | <p>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.</p>                                                                                      |
| 23:16      | RW          | 0x00               | <p>scale<br/>This field defines the scale factor applied to prescaled clock. The value N means the clock is divided by <math>2^N</math>. If N is 0, it means that the clock is divided by 512(<math>2^{19}</math>).</p>                      |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                                     |
| 14:12      | RW          | 0x0                | <p>prescale<br/>This field defines the prescale factor applied to input clock. The value N means that the input clock is divided by <math>2^N</math>.</p>                                                                                    |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                                                     |
| 10         | RW          | 0x0                | <p>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.</p> |
| 9          | RW          | 0x0                | <p>clk_sel<br/>1'b0: Non-scaled clock is selected as PWM clock source. It means that the prescaled clock is directly used as the PWM clock source.<br/>1'b1: Scaled clock is selected as PWM clock source.</p>                               |
| 8          | RW          | 0x0                | <p>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.</p>  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                                     |
| 2:1        | RW          | 0x0                | pwm_mode<br>2'b00: One shot mode. PWM produces the waveform within the repeated times defined by PWM2_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         | <p>period_hpr</p> <p>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.</p> <p>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.</p> <p>The value ranges from 0 to (<math>2^{32}-1</math>).</p> |

**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         | <p>duty_lpr</p> <p>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.</p> <p>If PWM is operated at the capture mode, this value indicates the effective low polarity cycles of input waveform.</p> <p>This value is based on the PWM clock. The value ranges from 0 to (<math>2^{32}-1</math>).</p> |

**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               | <p>rpt</p> <p>This field defines the repeated effective periods of output waveform in one-shot mode. The value N means N+1 repeated effective periods.</p>                                                                 |
| 23:16      | RW          | 0x00               | <p>scale</p> <p>This field defines the scale factor applied to prescaled clock. The value N means the clock is divided by <math>2^N</math>. If N is 0, it means that the clock is divided by 512(<math>2^{19}</math>).</p> |
| 15         | RO          | 0x0                | reserved                                                                                                                                                                                                                   |
| 14:12      | RW          | 0x0                | <p>prescale</p> <p>This field defines the prescale factor applied to input clock. The value N means that the input clock is divided by <math>2^N</math>.</p>                                                               |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 prescaled 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                                                                                                                                                     |
| 2:1        | RW          | 0x0                | pwm_mode<br>2'b00: One shot mode. PWM produces the waveform within the repeated times defined by PWM3_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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 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          | W1 C        | 0x0                | CH3_pwr_IntSts<br>1'b0: Channel 3 power key Interrupt not generated<br>1'b1: Channel 3 power key Interrupt generated                                                                                                                                                                                                                                                                               |
| 6:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 3          | W1 C        | 0x0                | CH3_IntSts<br>1'b0: Channel 3 Interrupt not generated<br>1'b1: Channel 3 Interrupt generated                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------|
| 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:4        | RO          | 0x0                | reserved                                                                                                      |
| 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'b0: Disabled. Select the channel PWM3 to FIFO mode and DMA mode.<br>1'b1: Enabled. Use dma_ch_sel to select the channel to FIFO mode and DMA mode. |
| 9          | RW          | 0x0                | timeout_en<br>FIFO timeout enable.                                                                                                                                    |
| 8          | RW          | 0x0                | dma_mode_en<br>1'b1: Enabled<br>1'b0: Disabled                                                                                                                        |
| 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      | RW          | 0x02               | 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 |
| 23:16      | RW          | 0x13               | minor_version<br>Minor version                                                                                         |
| 15:0       | RW          | 0x11B6             | 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_value<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_value<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_value<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_value<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_value<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_value<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_value<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_value<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_value<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_value<br>Power key match value 9. |

**PWM\_PWM3\_PWRCAPTURE\_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\_CHANNEL\_IO\_CTRL**

Address: Operational Base + offset (0x00D0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                         |
|------------|-------------|--------------------|------------------------------------------------------------|
| 31:19      | RO          | 0x0000             | reserved                                                   |
| 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 |

## 22.5 Interface Description

Table 22-1 PWM Interface Description

| Module Pin | Direction | Pin Name                                                                                | IOMUX Setting                         |
|------------|-----------|-----------------------------------------------------------------------------------------|---------------------------------------|
| PWM0CH0    | I/O       | GPIO0_B6/UART1_TX_M0/PWM0_M0                                                            | PMUGRF_GPIO0B_IOMUX_X_H[10:8]=3'b011  |
|            |           | GPIO2_B3/LCDC_D7/I2S2_MCLK_M1/CIF_D3_M1/UART5_CTSN_M1/PWM0_M1/SP_I0_CS1N_M2/I2C5_SDA_M0 | GRF_GPIO2B_IOMUX_L[14:12]=3'b101      |
| PWM0CH1    | I/O       | GPIO0_B7/UART1_RX_M0/PWM1_M0                                                            | PMUGRF_GPIO0B_IOMUX_X_H[14:12]=3'b011 |
|            |           | GPIO2_B2/LCDC_D6/I2S2_LRCK_M1/UART5_RTSN_M1/PWM1_M1/SPI0_CLK_M2                         | GRF_GPIO2B_IOMUX_L[10:8]=3'b101       |
| PWM0CH2    | I/O       | GPIO0_C0/SDMMC0_PWR/UART1_RTSN_M0/PWM2_M0                                               | PMUGRF_GPIO0C_IOMUX_X_L[2:0]=3'b011   |
|            |           | GPIO2_B1/LCDC_D5/I2S2_SCLK_M1/UART5_RX_M1/PWM2_M1/SPI0_MISO_M2                          | GRF_GPIO2B_IOMUX_L[6:4]=3'b101        |
| PWM0CH3    | I/O       | GPIO0_C1/PMU_DEBUG/UART1_CTSN_M0/PWM3_IR_M0                                             | PMUGRF_GPIO0C_IOMUX_X_L[6:4]=3'b011   |
|            |           | GPIO2_B0/LCDC_D4/I2S2_SDI_M1/UART5_TX_M1/PWM3_IR_M1/SPI0_MOSI_M2                        | GRF_GPIO2B_IOMUX_L[2:0]=3'b101        |
| PWM1CH0    | I/O       | GPIO0_C2/I2C2_SCL/PWM4_M0                                                               | PMUGRF_GPIO0C_IOMUX_X_L[10:8]=3'b011  |
|            |           | GPIO2_A7/LCDC_D3/I2S2_SDO_M1/UART4_RX_M1/PWM4_M1/SPI0_CS0N_M2                           | GRF_GPIO2A_IOMUX_H[14:12]=3'b101      |
| PWM1CH1    | I/O       | GPIO0_C3/I2C2_SDA/PWM5_M0                                                               | PMUGRF_GPIO0C_IOMUX_X_L[14:12]=3'b011 |
|            |           | GPIO2_A6/LCDC_D2/RGMII_COL_M1/CIF_D2_M1/UART4_TX_M1/PWM5_M1                             | GRF_GPIO2A_IOMUX_H[10:8]=3'b101       |
| PWM1CH2    | I/O       | GPIO0_B2/PMIC_SLEEP/TSADC_SHUT_M1/PWM6_M0                                               | PMUGRF_GPIO0B_IOMUX_X_L[10:8]=3'b011  |
|            |           | GPIO2_D4/LCDC_DEN/PWM6_M1/SPI1_CS0N_M2/I2C3_SCL_M1                                      | GRF_GPIO2D_IOMUX_H[2:0]=3'b101        |
| PWM1CH3    | I/O       | GPIO0_B1/PMIC_INT/PWM7_IR_M0                                                            | PMUGRF_GPIO0B_IOMUX_X_L[6:4]=3'b011   |
|            |           | GPIO3_A0/CAN_RXD_M0/UART3_TX_M2/PWM7_IR_M1/SPI1_CS1N_M2/I2C4_SCL_M0                     | GRF_GPIO3A_IOMUX_L[2:0]=3'b101        |
| PWM2CH0    | I/O       | GPIO3_A4/CIF_D0_M0/I2S0_SCLK_TX_M1/UART4_TX_M0/I2C3_SCL_M0/PWM8_M0                      | GRF_GPIO3A_IOMUX_H[2:0]=3'b110        |
|            |           | GPIO2_D7/LCDC_CLK/UART3_CTSN_M2/PWM8_M1/SPI1_MISO_M2                                    | GRF_GPIO2D_IOMUX_H[14:12]=3'b101      |

| Module Pin | Direction | Pin Name                                                                            | IOMUX Setting                        |
|------------|-----------|-------------------------------------------------------------------------------------|--------------------------------------|
| PWM2CH1    | I/O       | GPIO3_A5/CIF_D1_M0/RGMII_CRS_M0/I<br>2S0_LRCK_TX_M1/UART4_RX_M0/I2C3_SDA_M0/PWM9_M0 | GRF_GPIO3A_IOMUX_H<br>[6:4]=3'b110   |
|            |           | GPIO2_D6/LCDC_VSYNC/UART3_RTSN_M2/PWM9_M1/SPI1_MOSI_M2                              | GRF_GPIO2D_IOMUX_H<br>[10:8]=3'b101  |
| PWM2CH2    | I/O       | GPIO3_A6/CIF_D2_M0/RGMII_COL_M0/I<br>2S0_SDO0_M1/UART5_TX_M0/CAN_RXD_M1/PWM10_M0    | GRF_GPIO3A_IOMUX_H<br>[10:8]=3'b110  |
|            |           | GPIO2_D5/LCDC_HSYNC/PWM10_M1/SPI1_CLK_M2/I2C3_SDA_M1                                | GRF_GPIO2D_IOMUX_H<br>[6:4]=3'b101   |
| PWM2CH3    | I/O       | GPIO3_A7/CIF_D3_M0/RGMII_RXD2_M0/I2S0_SDI0_M1/UART5_RX_M0/CAN_TXD_M1/PWM11_IR_M0    | GRF_GPIO3A_IOMUX_H<br>[14:12]=3'b110 |
|            |           | GPIO3_A1/CAN_TXD_M0/UART3_RX_M2/PWM11_IR_M1/I2C4_SDA_M0                             | GRF_GPIO3A_IOMUX_L<br>[6:4]=3'b101   |

Notes: Unused Module Pin is tied to zero! I=input, O=output, I/O=input/output, bidirectional

## 22.6 Application Notes

### 22.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 and PWM\_PWMx\_CTRL.clk\_src\_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\_CHANNEL\_IO\_CTRL.filter\_number, then Enable the PWM\_CHANNEL\_IO\_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.

### 22.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 and PWM\_PWMx\_CTRL.clk\_src\_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\_CHANNEL\_IO\_CTRL.filter\_number, then Enable the PWM\_CHANNEL\_IO\_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.

### 22.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\_CHANNEL\_IO\_CTRL.filter\_number, then Enable the PWM\_CHANNEL\_IO\_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. Poll INTSTS. CH3\_pwr\_IntSts ==1, and refer to PWM\_PWM3\_PWR\_CAPTURE\_VALUE to know the power key capture value.
11. Write '0' to PWM\_PWM3\_CTRL.pwm\_en to disable the channel.

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

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

### 22.6.6 Other notes

When the channel is active to produce waveforms, it is free to program the PWM\_PWMx\_PERIOD\_HPC and PWM\_PWMx\_DUTY\_LPC register. User can use PWM\_PWMx\_CTRL.conlock to take period and duty effect at the same time. The usage flow is as follow:

1. Set PWM\_PWMx\_CTRL.conlock to '1'.
2. Set PWM\_PWMx\_PERIOD\_HPC and PWM\_PWMx\_DUTY\_LPC.
3. Set PWM\_PWMx\_CTRL.conlock to '0', others bits in PWM\_PWMx\_CTRL should be appropriate.

After above configuration, the change will not take effect immediately until the current period ends.

An active channel can be changed to another operation mode without disable the PWM channel. However, during the transition of the operation mode there may be some irregular output waveforms. So does changing the clock division factor when the channel is active.

## Chapter 23 I2C Interface

### 23.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:

- Supports 6 independent I2C: I2C0/1/2/3/4/5, with 6 pairs of 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

### 23.2 Block Diagram



Fig. 23-1 I2C Architecture

#### 23.2.1 I2C\_RF

I2C\_RF module is used to control the I2C controller operation by the host with APB interface. It implements the register set and the interrupt functionality. The CSR component operates synchronously with the pclk clock.

#### 23.2.2 I2C\_PE

I2C\_PE module implements the I2C master operation for transmit data to and receive data from other I2C devices. The I2C master controller operates synchronously with the pclk.

#### 23.2.3 I2C\_TOP

I2C\_TOP module is the top module of the I2C controller.

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

### 23.3.1 Initialization

The I2C controller is based on AMBA APB bus architecture and usually is part of a SOC. So before I2C operates, some system setting and configuration must be conformed, which includes:

- I2C interrupt connection type: CPU interrupt scheme should be considered. If the I2C interrupt is connected to extra Interrupt Controller module, we need decide the INTC vector.
- I2C Clock Rate: The I2C controller uses the APB clock as the working clock so the APB clock will determine the I2C bus clock. The correct register setting is subject to the system requirement.

### **23.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. 23-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. 23-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. 23-4 I2C Acknowledge

➤ Byte transfer

The master own I2C bus might initiate multiple 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. 23-5 I2C Byte Transfer

## 23.4 Register Description

### 23.4.1 Registers Summary

| Name            | Offset | Size | Reset Value | Description                                            |
|-----------------|--------|------|-------------|--------------------------------------------------------|
| RKI2C_CON       | 0x0000 | W    | 0x00030000  | Control Register                                       |
| RKI2C_CLKDIV    | 0x0004 | W    | 0x00000001  | Clock Divider Register                                 |
| RKI2C_MRXADDR   | 0x0008 | W    | 0x00000000  | The Slave Address Accessed for Master RX Mode          |
| RKI2C_MRXRADDR  | 0x000C | W    | 0x00000000  | The Slave Register Address Accessed for Master RX Mode |
| RKI2C_MTXCNT    | 0x0010 | W    | 0x00000000  | Master TX Count Register                               |
| RKI2C_MRXCNT    | 0x0014 | W    | 0x00000000  | Master RX Count Register                               |
| RKI2C_IEN       | 0x0018 | W    | 0x00000000  | Interrupt Enable Register                              |
| RKI2C_IPD       | 0x001C | W    | 0x00000000  | Interrupt Pending Register                             |
| RKI2C_FCNT      | 0x0020 | W    | 0x00000000  | Finished Count Register                                |
| RKI2C_SCL_OE_DB | 0x0024 | W    | 0x00000020  | Slave Hold Debounce 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                                 |

| Name          | Offset | Size | Reset Value | Description            |
|---------------|--------|------|-------------|------------------------|
| 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  |

Notes: **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 Register Description

#### RKI2C\_CON

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                         |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0003      | 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                                                                                                                                                                                |
| 11:8  | RW   | 0x0         | data_upd_st<br>SDA update point config.<br>Used to config sda change state when scl is low, and 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.<br>When this bit is written to 1, I2C will generate stop signal.                                                                                                                                                                                                                                               |
| 3     | RW   | 0x0         | start<br>Start enable.<br>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: Not enable<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         |
| 25         | RW          | 0x0                | addmvld<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. |

**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                | sraddmvld<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           | sraddr<br>Slave register address accessed.                              |

**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>Specify the total bytes to be transmitted (0~32). |

**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>Specify the total bytes to be received(0~32). |

**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                                                                                    |
| 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          | 0x00000000         | 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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 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          | RW          | 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          | RW          | 0x0                | startipd<br>interrupt pending bit.<br>1'b0: No interrupt available<br>1'b1: Start operation finished interrupt appear, write 1 to clear                                   |
| 3          | RW          | 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          | RW          | 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          | RW          | 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          | RW          | 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        | RW          | 0x00               | fcnt<br>The count of data which has been transmitted or received. |

**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          | 0x0000000          | 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. |

**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. |

**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. |

**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. |

**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. |

**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. |

**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. |

**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. |

**RKI2C RXDATA0**

Address: Operational Base + offset (0x0200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | rxdata0<br>Data0 received. |

**RKI2C RXDATA1**

Address: Operational Base + offset (0x0204)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | rxdata1<br>Data1 received. |

**RKI2C RXDATA2**

Address: Operational Base + offset (0x0208)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | rxdata2<br>Data2 received. |

**RKI2C\_RXDATA3**

Address: Operational Base + offset (0x020C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | rxdata3<br>Data3 received. |

**RKI2C\_RXDATA4**

Address: Operational Base + offset (0x0210)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | rxdata4<br>Data4 received. |

**RKI2C\_RXDATA5**

Address: Operational Base + offset (0x0214)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | rxdata5<br>Data5 received. |

**RKI2C\_RXDATA6**

Address: Operational Base + offset (0x0218)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | rxdata6<br>Data6 received. |

**RKI2C\_RXDATA7**

Address: Operational Base + offset (0x021C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>         |
|------------|-------------|--------------------|----------------------------|
| 31:0       | RW          | 0x00000000         | rxdata7<br>Data7 received. |

**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          | RW          | 0x0                | scl_st<br>Scl status.<br>1'b0: Scl status low<br>1'b0: Scl status high |
| 0          | RW          | 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                                                                                                                                                                                |
| 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<br>SCL_HIGH (SCL_HIGH including h0~h7) |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------|
| 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 edge 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.                              |

## 23.5 Interface Description

Table 23-1 I2C Interface Description

| <b>Module Pin</b>     | <b>Direction</b> | <b>Pin Name</b>                                                                           | <b>IOMUX Setting</b>                  |
|-----------------------|------------------|-------------------------------------------------------------------------------------------|---------------------------------------|
| IOMUX0 I2C0 Interface |                  |                                                                                           |                                       |
| I2C_SDA0              | I/O              | I2C0_SDA/GPIO0_B5_u                                                                       | PMUGRF_GPIO0B_IOMUX_SEL_H[3:0]=4'h1   |
| I2C_SCL0              | I/O              | I2C0_SCL/GPIO0_B4_u                                                                       | PMUGRF_GPIO0B_IOMUX_SEL_H[7:4]=4'h1   |
| IOMUX0 I2C1 Interface |                  |                                                                                           |                                       |
| I2C_SDA1              | I/O              | I2C1_SDA/UART4_RTSN_M2/GPIO1_D2_u                                                         | PMUGRF_GPIO1D_IOMUX_SEL_L[11:8]=4'h1  |
| I2C_SCL1              | I/O              | I2C1_SCL/UART4_CTSN_M2/GPIO1_D3_u                                                         | PMUGRF_GPIO1D_IOMUX_SEL_L[15:12]=4'h1 |
| IOMUX0 I2C2 Interface |                  |                                                                                           |                                       |
| I2C_SDA2              | I/O              | I2C2_SDA/PWM5_M0/GPIO0_C3_d                                                               | PMUGRF_GPIO0C_IOMUX_SEL_L[15:12]=4'h1 |
| I2C_SCL2              | I/O              | I2C2_SCL/PWM4_M0/GPIO0_C2_d                                                               | PMUGRF_GPIO0C_IOMUX_SEL_L[11:8]=4'h1  |
| IOMUX0 I2C3 Interface |                  |                                                                                           |                                       |
| I2C_SDA3              | I/O              | CIF_D1_M0/RGMII_CRS_M0/I2S0_LRCK_TX_M1/UART4_RX_M0/I2C3_SDA_M0/PWM9_M0/GPIO3_A5_d         | GRF_GPIO3A_IOMUX_SEL_H[7:4]=4'h5      |
| I2C_SCL3              | I/O              | CIF_D0_M0/I2S0_SCLK_TX_M1/UART4_TX_M0/I2C3_SCL_M0/PWM8_M0/GPIO3_A4_d                      | GRF_GPIO3A_IOMUX_SEL_H[3:0]=4'h5      |
| IOMUX0 I2C4 Interface |                  |                                                                                           |                                       |
| I2C_SDA4              | I/O              | CAN_TXD_M0/UART3_RX_M2/PWM11_IR_M1/I2C4_SDA_M0/GPIO3_A1_u                                 | GRF_GPIO3A_IOMUX_SEL_L[7:4]=4'h7      |
| I2C_SCL4              | I/O              | CAN_RXD_M0/UART3_TX_M2/PWM7_IR_M1/SPI1_CS1n_M2/I2C4_SCL_M0/GPIO3_A0_u                     | GRF_GPIO3A_IOMUX_SEL_L[3:0]=4'h7      |
| IOMUX0 I2C5 Interface |                  |                                                                                           |                                       |
| I2C_SDA5              | I/O              | LCD_C_D7/I2S2_MCLK_M1/CIF_D3_M1/UART5_CTSN_M1/SPI0_CS1n_M2/PWM0_M1/I2C5_SDA_M0/GPIO2_B3_d | GRF_GPIO2B_IOMUX_SEL_L[15:12]=4'h7    |
| I2C_SCL5              | I/O              | LCD_C_D1/RGMII_CRS_M1/CIF_D1_M1/UART4_CTSN_M1/I2C5_SCL_M0/GPIO2_A5_d                      | GRF_GPIO2A_IOMUX_SEL_H[7:4]=4'h7      |
| IOMUX1 I2C3 Interface |                  |                                                                                           |                                       |
| I2C_SDA3              | I/O              | LCD_C_HSYNC/PWM10_M1/SPI1_CLK_M2/I2C3_SDA_M1/GPIO2_D5_d                                   | GRF_GPIO2D_IOMUX_SEL_H[3:0]=4'h7      |
| I2C_SCL3              | I/O              | LCD_C_DEN/PWM6_M1/SPI1_CS0n_M2/I2C3_SCL_M1/GPIO2_D4_d                                     | GRF_GPIO2D_IOMUX_SEL_H[7:4]=4'h7      |
| IOMUX1 I2C4 Interface |                  |                                                                                           |                                       |
| I2C_SDA4              | I/O              | I2S0_SDO3_SDI1_M0/PDM_SDI1_M0/AUDP_WM_R_M0/I2C4_SDA_M1/AUDDSM_RP/GPIO4_A1_d               | GRF_GPIO4A_IOMUX_SEL_L[7:4]=4'h4      |
| I2C_SCL4              | I/O              | I2S0_SDO2_SDI2_M0/PDM_SDI2_M0/AUDP_WM_L_M0/I2C4_SCL_M1/AUDDSM_RN/GPIO4_A0_d               | GRF_GPIO4A_IOMUX_SEL_L[3:0]=4'h4      |
| IOMUX1 I2C5 Interface |                  |                                                                                           |                                       |

|                       |     |                                                                              |                                    |
|-----------------------|-----|------------------------------------------------------------------------------|------------------------------------|
| I2C_SDA5              | I/O | CIF_D5_M0/RGMII_TXD2_M0/I2S0_SCLK_RX_M1/UART5_CTSN_M0/I2C5_SDA_M1/GPIO3_B1_d | GRF_GPIO3B_IOMUX_SEL_L[7:4]=4'h5   |
| I2C_SCL5              | I/O | CIF_D4_M0/RGMII_RXD3_M0/I2S0_MCLK_M1/UART5_RTSN_M0/I2C5_SCL_M1/GPIO3_B0_d    | GRF_GPIO3B_IOMUX_SEL_L[3:0]=4'h5   |
| IOMUX2 I2C3 Interface |     |                                                                              |                                    |
| I2C_SDA3              | I/O | SPI0_MISO_M1/I2S1_LRCK_M1/I2C3_SDA_M2/GPIO1_D7_d                             | GRF_GPIO1D_IOMUX_SEL_H[15:12]=4'h3 |
| I2C_SCL3              | I/O | SPI0_MOSI_M1/I2S1_SCLK_M1/I2C3_SCL_M2/GPIO1_D6_d                             | GRF_GPIO1D_IOMUX_SEL_H[11:8]=4'h3  |
| IOMUX2 I2C5 Interface |     |                                                                              |                                    |
| I2C_SDA5              | I/O | SDMMC1_PWR/I2C5_SDA_M2/UART1_RX_M1/GPIO1_D1_d                                | GRF_GPIO1D_IOMUX_SEL_L[7:4]=4'h4   |
| I2C_SCL5              | I/O | I2S2_MCLK_M0/SDMMC1_DET/SPI1_CS1n_M1/I2C5_SCL_M2/UART1_TX_M1/GPIO1_D0_d      | GRF_GPIO1D_IOMUX_SEL_L[3:0]=4'h4   |

## 23.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. 23-6 I2C Flow Chat for Transmit Only Mode

- Receive only mode (I2C\_CON[1:0]=2'b10)



Fig. 23-7 I2C Flow Chat for Receive Only Mode

- Mix mode (I2C\_CON[1:0]=2'b01 or I2C\_CON[1:0]=2'b11)



Fig. 23-8 I2C Flow Chat for Mix Mode

## Chapter 24 UART

### 24.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 64Bytes FIFOs for data receive and transmit
- All support auto flow-control except
- 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

### 24.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. 23-9 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. This makeup of serial data, referred to as a character can exit the block in two forms, either serial UART format or IrDA 1.0 SIR format.

### **Serial Receiver**

Converts the serial data character (as specified by the control register) received in either the UART or IrDA 1.0 SIR format to parallel form. Parity error detection, framing error detection and line break detection is carried out in this block.

## **24.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. 23-10 UART Serial protocol

### **IrDA 1.0 SIR Protocol**

The Infrared Data Association (IrDA) 1.0 Serial Infrared (SIR) mode supports bi-directional datacommunications with remote devices using infrared radiation as the transmission medium. IrDA 1.0 SIR mode specifies a maximum baud rate of 115.2 Kbaud.

Transmitting a single infrared pulse signals a logic zero, while a logic one is represented by not sending a pulse. The width of each pulse is 3/16ths of a normal serial bit time. Data transfers can only occur in half-duplex fashion when IrDA SIR mode is enabled.



Fig. 23-11 IrDA 1.0

### **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. 23-12 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 UART0/UART1/UART2 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. 23-13 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. 23-14 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. 23-15 UART AUTO CTS TIMING

## 24.4 Register Description

This section describes the control/status registers of the design. There are 3 UARTs in RK3228, and each one has its own base address.

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

| Name       | Offset | Size | Reset Value | Description                      |
|------------|--------|------|-------------|----------------------------------|
| 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              |
| 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    | 0x00000000  | Component Parameter Register     |
| UART_UCV   | 0x00f8 | W    | 0x00000000  | UART Component Version           |
| UART_CTR   | 0x00fc | W    | 0x44570110  | Component Type Register          |

#### 24.4.2 Detail Register Description

##### UART\_RBR

Address: Operational Base + offset (0x0000)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | RO   | 0x0000000   | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7:0  | RO   | 0x00        | rbr<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.<br>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 are lost and an over-run error occurs. |

##### UART\_DLL

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7:0        | RW          | 0x00               | <p>dll</p> <p>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 DW_apb_uart clock should be allowed to pass before transmitting or receiving data.</p> |

### UART THR

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7:0        | WO          | 0x00               | <p>thr</p> <p>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)

| <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          | 0x00               | <p>dlh</p> <p>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 disabled and no serial communications occur. Also, once the DLH is set, at least 8 clock cycles of the slowest DW_apb_uart clock should be allowed to pass before transmitting or receiving data.</p> |

**UART\_IER**

Address: Operational Base + offset (0x0004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                                                                                                                          |
| 7          | RW          | 0x0                | <p>ptime</p> <p>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>edssi</p> <p>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>                                |
| 2          | RW          | 0x0                | <p>elsi</p> <p>Enable Receiver Line Status Interrupt. This is used to enable/disable the generation of Receiver Line Status Interrupt. This is the 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>                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p>etbei</p> <p>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.</p> <p>1'b0: Disabled<br/>1'b1: Enabled</p>                                                         |
| 0          | RW          | 0x0                | <p>erbf</p> <p>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.</p> <p>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>rt</p> <p>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 Suppor". The following trigger levels are supported:</p> <p>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>tet</p> <p>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:</p> <p>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                | <p>dmam</p> <p>DMA Mode. This determines the DMA signalling mode used for the <code>dma_tx_req_n</code> and <code>dma_rx_req_n</code> output signals when additional DMA handshaking signals are not selected (<code>DMA_EXTRA == No</code>). For details on DMA support, refer to DMA Support.</p> <p>1'b0: Mode 0<br/>1'b1: Mode 1</p>                |
| 2          | WO          | 0x0                | <p>xfifor</p> <p>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 (<code>DMA_EXTRA == YES</code>). Note that this bit is 'self-clearing'. It is not necessary to clear this bit.</p> |
| 1          | WO          | 0x0                | <p>rfifor</p> <p>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 (<code>DMA_EXTRA == YES</code>). Note that this bit is 'self-clearing'. It is not necessary to clear this bit.</p>  |
| 0          | WO          | 0x0                | <p>fifoe</p> <p>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.</p>                                                                                                                                             |

**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                | <p>fifose</p> <p>FIFOs Enabled. This is used to indicate whether the FIFOs are enabled or disabled.</p> <p>2'b00: Disabled<br/>2'b11: Enabled</p> |
| 5:4        | RO          | 0x0                | reserved                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0        | RO          | 0x1                | <p>iid<br/>Interrupt ID. This indicates the highest priority pending interrupt which can be one of the following types:</p> <ul style="list-style-type: none"> <li>4'b0000: Modem status</li> <li>4'b0001: No interrupt pending</li> <li>4'b0010: THR empty</li> <li>4'b0100: Received data available</li> <li>4'b0110: Receiver line status</li> <li>4'b0111: Busy detect</li> <li>4'b1100: Character timeout</li> </ul> <p>The interrupt priorities are split into four levels that are detailed in Table X.</p> <p>Bit 3 indicates an interrupt can only occur when the FIFOs are enabled and used to distinguish a Character Timeout condition interrupt.</p> |

**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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7          | RW          | 0x0                | <p>dlab<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.</p>                                                                                                                                                                                                  |
| 6          | RW          | 0x0                | <p>bc<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.</p> |
| 5          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4          | RW          | 0x0                | <p>eps<br/>Even Parity Select. Writeable 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.</p>                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | <p>pen</p> <p>Parity Enable. Writeable 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.</p> <p>1'b0: Parity disabled<br/>1'b1: Parity enabled</p>                                                                                                                                                                                                                                                                                                                                                     |
| 2          | RW          | 0x0                | <p>stop</p> <p>Number of stop bits. Writeable 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.</p> <p>1'b0: 1 stop bit<br/>1'b1: 1.5 stop bits when DLS (LCR[1:0]) is zero, else 2 stop bit.</p> |
| 1:0        | RW          | 0x0                | <p>dls</p> <p>Data Length Select. Writeable 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. The number of bit that may be selected areas follows:</p> <p>2'b00: 5 bits<br/>2'b01: 6 bits<br/>2'b10: 7 bits<br/>2'b11: 8 bits</p>                                                                                                                                                                                                                                                                                              |

### 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>sire</p> <p>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> <p>1'b0: IrDA SIR Mode disabled<br/>1'b1: IrDA SIR Mode enabled</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | <p>afce</p> <p>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> <p>1'b0: Auto Flow Control Mode disabled<br/>1'b1: Auto Flow Control Mode enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4          | RW          | 0x0                | <p>lb</p> <p>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</p> <p>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> <p>1'b0: Out2_n de-asserted (logic 1)<br/>1'b1: Out2_n asserted (logic 0)</p> <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>                                                                                                                                                                                                                                                                                                                     |
| 2          | RW          | 0x0                | <p>out1</p> <p>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>                                                                                                                                                                                                                                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p>rts</p> <p>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>dtr</p> <p>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          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7          | RO          | 0x0                | <p>rfe</p> <p>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> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RO          | 0x1                | <p>temt</p> <p>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>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5          | RO          | 0x1                | <p>thre</p> <p>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>bi</p> <p>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. 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> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RO          | 0x0                | <p>fe</p> <p>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>pe</p> <p>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>                                                                                                                                                                                                                                                                                       |
| 1          | RO          | 0x0                | <p>oe</p> <p>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</p> <p>Reading the LSR clears the OE bit.</p>                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | <p>dr</p> <p>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</p> <p>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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7          | RO          | 0x0                | <p>dcd</p> <p>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)</p> <p>In Loopback Mode (MCR[4] set to one), DCD is the same as MCR[3] (Out2).</p>               |
| 6          | RO          | 0x0                | <p>ri</p> <p>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)</p> <p>In Loopback Mode (MCR[4] set to one), RI is the same as MCR[2] (Out1).</p>                 |
| 5          | RO          | 0x0                | <p>dsr</p> <p>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 DW_apb_uart.</p> <p>1'b0: dsr_n input is de-asserted (logic 1)<br/>1'b1: dsr_n input is asserted (logic 0)</p> <p>In Loopback Mode (MCR[4] set to one), DSR is the same as MCR[0] (DTR).</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | <p>cts<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 DW_apb_uart.</p> <p>1'b0: cts_n input is de-asserted (logic 1)<br/>1'b0: 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>ddcd<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>teri<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>ddsr<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>       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | dcts<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.<br>1'b0: No change on ctsdsr_n since last read of MSR<br>1'b1: Change on ctsdsr_n since last read of MSR 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. |

**UART SCR**

Address: Operational Base + offset (0x001c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                        |
| 7:0        | RW          | 0x00               | scr<br>Scratchpad register. This register is for programmers to use as a temporary storage space. It has no defined purpose in the DW_apb_uart. |

**UART SRBR**

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        | RO          | 0x00               | srbr<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:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0          | WO          | 0x0                | <p>sthr</p> <p>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.</p> |

**UART FAR**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0          | RW          | 0x0                | <p>far</p> <p>Writes have no effect when FIFO_ACCESS == No, always readable. This register is use 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)

| <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        | RO          | 0x00               | tfr<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.<br>When FIFOs are not implemented or not enabled, reading this register gives the data in the THR. |

**UART RFW**

Address: Operational Base + offset (0x0078)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10      | RO          | 0x000000           | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9          | WO          | 0x0                | refe<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.                                                                   |
| 8          | WO          | 0x0                | repe<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.                                                                      |
| 7:0        | WO          | 0x00               | r fwd<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.<br>When FIFOs are not implemented or not enabled, the data that is written to the RFWD is pushed into the RBR. |

**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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | rfe<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                | rfne<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                | tfe<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                | tfnf<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                | 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: DW_apb_uart is idle or inactive<br>1'b1: DW_apb_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 DW_apb_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 DW_apb_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               | tfl<br>Transmit FIFO Level. This is 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                                                                                     |
| 5:0        | RO          | 0x00               | rfl<br>Receive FIFO Level. This is 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                | xfr<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                | rfr<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                | ur<br>UART Reset. This asynchronously resets the DW_apb_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                | srts<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 DW_apb_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). 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                | sbcr<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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>sdmam</p> <p>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).</p> <p>1'b0: Mode 0<br/>1'b1: Mode 1</p> |

**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                | <p>sfe</p> <p>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.</p> |

**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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1:0        | RW          | 0x0                | <p>srt</p> <p>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> <p>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> |

**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>stet</p> <p>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>htx</p> <p>This register is use to halt transmissions for testing, so that the transmit FIFO can be filled by the master when FIFOs are implemented and enabled.</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>dmasa</p> <p>This register is use 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 DW_apb_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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                               |
| 23:16      | RO          | 0x00               | <p>fifo_mode<br/>8'h0: 0<br/>8'h0: 16<br/>8'h0: 32<br/>to<br/>8'h80: 2048<br/>8'h81-8'hff:reserved</p> |
| 15:14      | RO          | 0x0                | reserved                                                                                               |
| 13         | RO          | 0x0                | <p>dma_extra<br/>1'b0: False<br/>1'b1: Ture</p>                                                        |
| 12         | RO          | 0x0                | <p>uart_add_encoded_params<br/>1'b0: False<br/>1'b1: Ture</p>                                          |
| 11         | RO          | 0x0                | <p>shadow<br/>1'b0: False<br/>1'b1: Ture</p>                                                           |
| 10         | RO          | 0x0                | <p>fifo_stat<br/>1'b0: False<br/>1'b1: Ture</p>                                                        |
| 9          | RO          | 0x0                | <p>fifo_access<br/>1'b0: False<br/>1'b1: Ture</p>                                                      |
| 8          | RO          | 0x0                | <p>new_feat<br/>1'b0: False<br/>1'b1: Ture</p>                                                         |
| 7          | RO          | 0x0                | <p>sir_lp_mode<br/>1'b0: False<br/>1'b1: Ture</p>                                                      |
| 6          | RO          | 0x0                | <p>sir_mode<br/>1'b0: False<br/>1'b1: Ture</p>                                                         |
| 5          | RO          | 0x0                | <p>thre_mode<br/>1'b0: False<br/>1'b1: Ture</p>                                                        |
| 4          | RO          | 0x0                | <p>afce_mode<br/>1'b0: False<br/>1'b1: Ture</p>                                                        |
| 3:2        | RO          | 0x0                | reserved                                                                                               |
| 1:0        | RO          | 0x0                | <p>apb_data_width<br/>2'b00: 8 bits<br/>2'b01: 16 bits<br/>2'b10: 32 bits<br/>2'b11: reserved</p>      |

**UART UCV**

Address: Operational Base + offset (0x00f8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:0       | RO          | 0x00000000         | ucv<br>ASCII value for each number in the version. |

**UART CTR**

Address: Operational Base + offset (0x00fc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------|
| 31:0       | RO          | 0x44570110         | id<br>This register contains the peripherals identification code. |

## 24.5 Interface Description

Table 23-2UART Interface Description

| <b>Module Pin</b>          | <b>Direction</b> | <b>Pad Name</b>                                                               | <b>IOMUX Setting</b>                          |
|----------------------------|------------------|-------------------------------------------------------------------------------|-----------------------------------------------|
| <b>UART0mux0 Interface</b> |                  |                                                                               |                                               |
| uart0_sin                  | I                | GPIO1_C2/UART0_RX                                                             | GRF_GPIO1C_IOMUX<br>_SEL_L[11:8]=4'h1         |
| uart0_sout                 | O                | GPIO1_C3/UART0_TX                                                             | GRF_GPIO1C_IOMUX<br>_SEL_L[15:12]=4'h1        |
| uart0_cts_n                | I                | GPIO1_C1/UART0_CTSN                                                           | GRF_GPIO1C_IOMUX<br>_SEL_L[7:4]=4'h1          |
| uart0_rts_n                | O                | GPIO1_C0/UART0_RTSN                                                           | GRF_GPIO1C_IOMUX<br>_SEL_L[3:0]=4'h1          |
| <b>UART1mux0 Interface</b> |                  |                                                                               |                                               |
| uart1_sin                  | I                | GPIO0_B7/UART1_RX_M0/PWM1_M0                                                  | PMUGRF_GPIO0B_IO<br>MUX_SEL_H[15:12]=<br>4'h2 |
| uart1_sout                 | O                | GPIO0_B6/UART1_TX_M0/PWM0_M0                                                  | PMUGRF_GPIO0B_IO<br>MUX_SEL_H[11:8]=4'<br>h2  |
| uart1_cts_n                | I                | GPIO0_C1/PMU_DEBUG/UART1_CTSN_<br>M0/PWM3_IR_M0                               | PMUGRF_GPIO0C_IO<br>MUX_SEL_L[7:4]=4'h<br>2   |
| uart1_rts_n                | O                | GPIO0_C0/SDMMC0_PWR/UART1_RTS<br>N_M0/PWM2_M0                                 | PMUGRF_GPIO0C_IO<br>MUX_SEL_L[3:0]=4'h<br>2   |
| <b>UART1mux1 Interface</b> |                  |                                                                               |                                               |
| uart1_sin                  | I                | GPIO1_D1/SDMMC1_PWR/I2C5_SDA_<br>M2/UART1_RX_M1                               | GRF_GPIO1D_IOMUX<br>_SEL_L[7:4]=4'h5          |
| uart1_sout                 | O                | GPIO1_D0/I2S2_MCLK_M0/SDMMC1_D<br>ET/SPI1_CS1N_M1/I2C5_SCL_M2/UAR<br>T1_TX_M1 | GRF_GPIO1D_IOMUX<br>_SEL_L[3:0]=4'h5          |
| uart1_cts_n                | I                | GPIO1_C7/I2S2_LRCK_M0/SPI1_CS0N                                               | GRF_GPIO1C_IOMUX                              |

|                            |   |                                                                     |                                        |
|----------------------------|---|---------------------------------------------------------------------|----------------------------------------|
|                            |   | _M1/UART1_CTSN_M1                                                   | _SEL_H[15:12]=4'h5                     |
| uart1_rts_n                | O | GPIO1_C6/I2S2_SCLK_M0/SPI1_CLK_M1/PRELIGHT_TRIG_OUT/UART1_RTSN_M1   | GRF_GPIO1C_IOMUX<br>_SEL_H[11:8]=4'h5  |
| <b>UART2mux0 Interface</b> |   |                                                                     |                                        |
| uart2_sin                  | I | GPIO1_A4/SDMMC0_D0/TEST_CLK1_O<br>UT/UART2_RX_M0                    | GRF_GPIO1A_IOMUX<br>_SEL_H[3:0]=4'h3   |
| uart2_sout                 | O | GPIO1_A5/SDMMC0_D1/TEST_CLK0_O<br>UT/UART2_TX_M0/RISC-V_JTAG_TRSTn  | GRF_GPIO1A_IOMUX<br>_SEL_H[7:4]=4'h3   |
| <b>UART2mux1 Interface</b> |   |                                                                     |                                        |
| uart2_sin                  | I | GPIO3_A3/UART2_RX_M1/A7_JTAG_TM_S_M1                                | GRF_GPIO3A_IOMUX<br>_SEL_L[11:8]=4'h1  |
| uart2_sout                 | O | GPIO3_A2/UART2_TX_M1/A7_JTAG_TC_K_M1                                | GRF_GPIO3A_IOMUX<br>_SEL_L[15:12]=4'h1 |
| <b>UART3mux0 Interface</b> |   |                                                                     |                                        |
| uart3_sin                  | I | GPIO3_C7/CIF_HSYNC_M0/RGMII_RXC_LK_M0/UART3_RX_M0                   | GRF_GPIO3C_IOMUX<br>_SEL_H[15:12]=4'h4 |
| uart3_sout                 | O | GPIO3_C6/CIF_CLKOUT_M0/RGMII_TX_CLK_M0/UART3_TX_M0                  | GRF_GPIO3C_IOMUX<br>_SEL_H[11:8]=4'h4  |
| uart3_cts_n                | I | GPIO3_C5/CIF_CLKIN_M0/CLK_OUT_E<br>THERNET_M0/UART3_CTSN_M0         | GRF_GPIO3C_IOMUX<br>_SEL_H[7:4]=4'h4   |
| uart3_rts_n                | O | GPIO3_C4/CIF_VSYNC_M0/RGMII_MDC_M0/UART3_RTSN_M0                    | GRF_GPIO3C_IOMUX<br>_SEL_H[3:0]=4'h4   |
| <b>UART3mux1 Interface</b> |   |                                                                     |                                        |
| uart3_sin                  | I | GPIO1_A6/SDMMC0_D2/UART3_RX_M1<br>/A7_JTAG_TCK_M0/RISC-V_JTAG_TCK   | GRF_GPIO1A_IOMUX<br>_SEL_H[11:8]=4'h2  |
| uart3_sout                 | O | GPIO1_A7/SDMMC0_D3/UART3_TX_M1<br>/A7_JTAG_TMS_M0/RISC-V_JTAG_TMS   | GRF_GPIO1A_IOMUX<br>_SEL_H[15:12]=4'h2 |
| uart3_cts_n                | I | GPIO1_B1/SDMMC0_CMD/UART3_CTS_N_M1/RISC-V_JTAG_TDI                  | GRF_GPIO1B_IOMUX<br>_SEL_L[7:4]=4'h2   |
| uart3_rts_n                | O | GPIO1_B0/SDMMC0_CLK/UART3_RTSN_M1/RISC-V_JTAG_TDO                   | GRF_GPIO1B_IOMUX<br>_SEL_L[3:0]=4'h2   |
| <b>UART3mux2 Interface</b> |   |                                                                     |                                        |
| uart3_sin                  | I | GPIO3_A1/CAN_RXD_M0/UART3_RX_M2/PWM11_IR_M1/I2C4_SDA_M0             | GRF_GPIO3A_IOMUX<br>_SEL_L[7:4]=4'h4   |
| uart3_sout                 | O | GPIO3_A0/CAN_RXD_M0/UART3_TX_M2/PWM7_IR_M1/SPI1_CS1N_M2/I2C4_SCL_M0 | GRF_GPIO3A_IOMUX<br>_SEL_L[3:0]=4'h4   |
| uart3_cts_n                | I | GPIO2_D7/LCDC_CLK/UART3_CTSN_M2/PWM8_M1/SPI1_MISO_M2                | GRF_GPIO2D_IOMUX<br>_SEL_H[15:12]=4'h4 |
| uart3_rts_n                | O | GPIO2_D6/LCDC_VSYNC/UART3_RTSN_M2/PWM9_M1/SPI1_MOSI_M2              | GRF_GPIO2D_IOMUX<br>_SEL_H[11:8]=4'h4  |
| <b>UART4mux0 Interface</b> |   |                                                                     |                                        |
| uart4_sin                  | I | GPIO3_A5/CIF_D1_M0/RGMII_CRS_M0<br>/I2S0_LRCK_TX_M1/UART4_RX_M0/I2  | GRF_GPIO3A_IOMUX<br>_SEL_H[7:4]=4'h4   |

|                            |   |                                                                                  |                                    |
|----------------------------|---|----------------------------------------------------------------------------------|------------------------------------|
|                            |   | C3_SDA_M0/PWM9_M0                                                                |                                    |
| uart4_sout                 | O | GPIO3_A4/CIF_D0_M0/I2S0_SCLK_TX_M1/UART4_RX_M0/I2C3_SCL_M0/PWM8_M0               | GRF_GPIO3A_IOMUX_SEL_H[3:0]=4'h4   |
| uart4_cts_n                | I | GPIO3_B3/CIF_D7_M0/RGMII_TXD0_M0/I2S0_SDO1_SDID3_M1/UART4_CTSN_M0                | GRF_GPIO3B_IOMUX_SEL_L[15:12]=4'h4 |
| uart4_rts_n                | O | GPIO3_B2/CIF_D6_M0/RGMII_TXD3_M0/I2S0_LRCK_RX_M1/UART4_RTSN_M0                   | GRF_GPIO3B_IOMUX_SEL_L[11:8]=4'h4  |
| <b>UART4mux1 Interface</b> |   |                                                                                  |                                    |
| uart4_sin                  | I | GPIO2_A7/LCDC_D3/I2S2_SDO_M1/UART4_RX_M1/PWM4_M1/SPI0_CS0N_M2                    | GRF_GPIO2A_IOMUX_SEL_H[15:12]=4'h4 |
| uart4_sout                 | O | GPIO2_A6/LCDC_D2/RGMII_COL_M1/IF_D2_M1/UART4_TX_M1/PWM5_M1                       | GRF_GPIO2A_IOMUX_SEL_H[11:8]=4'h4  |
| uart4_cts_n                | I | GPIO2_A5/LCDC_D1/RGMII_CRS_M1/IF_D1_M1/UART4_CTSN_M1/I2C5_SCL_M0                 | GRF_GPIO2A_IOMUX_SEL_H[7:4]=4'h4   |
| uart4_rts_n                | O | GPIO2_A4/LCDC_D0/RGMII_TXD3_M1/CIF_D0_M1/UART4_RTSN_M1                           | GRF_GPIO2A_IOMUX_SEL_H[3:0]=4'h4   |
| <b>UART4mux2 Interface</b> |   |                                                                                  |                                    |
| uart4_sin                  | I | GPIO1_D4/UART4_RX_M2                                                             | GRF_GPIO1D_IOMUX_SEL_H[3:0]=4'h3   |
| uart4_sout                 | O | GPIO1_D5/SPI0_CS1n_M1/I2S1_MCLK_M1/UART4_TX_M2                                   | GRF_GPIO1D_IOMUX_SEL_H[7:4]=4'h3   |
| uart4_cts_n                | I | GPIO1_D3/I2C1_SCL/UART4_CTSN_M2                                                  | GRF_GPIO1D_IOMUX_SEL_L[15:12]=4'h3 |
| uart4_rts_n                | O | GPIO1_D2/I2C1_SDA/UART4_RTSN_M2                                                  | GRF_GPIO1D_IOMUX_SEL_L[11:8]=4'h3  |
| <b>UART5mux0 Interface</b> |   |                                                                                  |                                    |
| uart5_sin                  | I | GPIO3_A7/CIF_D3_M0/RGMII_RXD2_M0/I2S0_SDI0_M1/UART5_RX_M0/CAN_RXD_M1/PWM11_IR_M0 | GRF_GPIO3A_IOMUX_SEL_H[15:12]=4'h4 |
| uart5_sout                 | O | GPIO3_A6/CIF_D2_M0/RGMII_COL_M0/I2S0_SDO0_M1/UART5_TX_M0/CAN_RXD_M1/PWM10_M0     | GRF_GPIO3A_IOMUX_SEL_H[11:8]=4'h4  |
| uart5_cts_n                | I | GPIO3_B1/CIF_D5_M0/RGMII_TXD2_M0/I2S0_SCLK_RX_M1/UART5_CTSN_M0/I2C5_SDA_M1       | GRF_GPIO3B_IOMUX_SEL_L[7:4]=4'h4   |
| uart5_rts_n                | O | GPIO3_B0/CIF_D4_M0/RGMII_RXD3_M0/I2S0_MCLK_M1/UART5_RTSN_M0/I2C5_SCL_M1          | GRF_GPIO3B_IOMUX_SEL_L[3:0]=4'h4   |
| <b>UART5mux1 Interface</b> |   |                                                                                  |                                    |
| uart5_sin                  | I | GPIO2_B1/LCDC_D5/I2S2_SCLK_M1/UART5_RX_M1/PWM2_M1/SPI0_MISO_M2                   | GRF_GPIO2B_IOMUX_SEL_L[7:4]=4'h4   |
| uart5_sout                 | O | GPIO2_B0/LCDC_D4/I2S2_SDI_M1/UA                                                  | GRF_GPIO2B_IOMUX                   |

|                            |   |                                                                                                |                                        |
|----------------------------|---|------------------------------------------------------------------------------------------------|----------------------------------------|
|                            |   | RT5_TX_M1/PWM3_IR_M1/SPI0_MOSI_M2                                                              | _SEL_L[3:0]=4'h4                       |
| uart5_cts_n                | I | GPIO2_B3/LCDC_D7/I2S2_MCLK_M1/C<br>IF_D3_M1/UART5_CTSN_M1/PWM0_M1<br>/SPI0_CS1N_M2/I2C5_SDA_M0 | GRF_GPIO2B_IOMUX<br>_SEL_L[15:12]=4'h4 |
| uart5_rts_n                | O | GPIO2_B2/LCDC_D6/I2S2_LRCK_M1/U<br>ART5_RTSN_M1/PWM1_M1/SPI0_CLK_M2                            | GRF_GPIO2B_IOMUX<br>_SEL_L[11:8]=4'h4  |
| <b>UART5mux2 Interface</b> |   |                                                                                                |                                        |
| uart5_sin                  | I | GPIO2_A1/SPI0_CLK_M1/I2S1_SDO_M1/UART5_RX_M2                                                   | GRF_GPIO2A_IOMUX<br>_SEL_L[7:4]=4'h3   |
| uart5_sout                 | O | GPIO2_A0/SPI0_CS0n_M1/I2S1_SDI_M1/UART5_TX_M2                                                  | GRF_GPIO2A_IOMUX<br>_SEL_L[3:0]=4'h3   |
| uart5_cts_n                | I | GPIO2_A3/MIPI_CSI_CLK0/UART5_CTS_N_M2                                                          | GRF_GPIO2A_IOMUX<br>_SEL_L[15:12]=4'h3 |
| uart5_rts_n                | O | GPIO2_A2/MIPI_CSI_CLK1/UART5_RTS_N_M2                                                          | GRF_GPIO2A_IOMUX<br>_SEL_L[11:8]=4'h3  |

## 24.6 Application Notes

### 24.6.1 None FIFO Mode Transfer Flow



Fig. 23-16 UART none fifo mode

## 24.6.2 FIFO Mode Transfer Flow



Fig. 23-17 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.

## 24.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. 23-18 UART clock generation

**UART baud rate configuration**

The following table provides some reference configuration for different UART baud rates.

Table 23-3 UART baud rate configuration

| Baud Rate  | Reference Configuration                                                                                                         |
|------------|---------------------------------------------------------------------------------------------------------------------------------|
| 115.2 Kbps | Configure PLL to get 648MHz clock output;<br>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;<br>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;<br>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;<br>Configure UART_DLL to 1                  |
| 3 Mbps     | Choose PLL to get 384MHz clock output;Divide 384MHz clock by 8 to get 48MHz clock;<br>Configure UART_DLL to 1                   |
| 4 Mbps     | Configure PLL to get 384MHz clock output;Divide 384MHz clock by 6 to get 64MHz clock;<br>Configure UART_DLL to 1                |

## Chapter 25 Serial Peripheral Interface (SPI)

### 25.1 Overview

The serial peripheral interface is an APB slave device. A four wire full duplex serial protocol from Motorola. There are four possible combinations for the serial clock phase and polarity. The clock phase (SCPH) determines whether the serial transfer begins with the falling edge of slave select signals or the first edge of the serial clock. The slave select line is held high when the SPI is idle or disabled. This SPI controller can work as either master or slave mode.

SPI Controller supports the following features:

- Support Motorola SPI,TI Synchronous Serial Protocol and National Semiconductor Micro wire interface
- Support 32-bit APB bus
- Support two internal 16-bit wide and 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 combine interrupt output
- Support up to half of SPI clock frequency transfer in master mode and one sixth of SPI clock frequency transfer in slave mode
- Support full and half duplex mode transfer
- Stop transmitting SCLK if transmit FIFO is empty or receive FIFO is full in master mode
- Support configurable delay from chip select active to SCLK active in master mode
- Support configurable period of chip select inactive between two parallel data in master mode
- Support big and little endian, MSB and LSB first transfer
- Support two 8-bit audio data store together in one 16-bit wide location
- Support sample RXD 0~3 SPI clock cycles later
- Support configurable SCLK polarity and phase
- Support fix and incremental address access to transmit and receive FIFO
- 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.

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

## 25.3 Function Description



Fig. 25-2 SPI Master and Slave Interconnection

The SPI controller support dynamic switching between master and slave in a system. The diagram show how the SPI controller connects with other SPI devices.

### Operation Modes

The SPI can be configured in the following two fundamental modes of operation: Master

Mode when SPI\_CTRLR0 [20] is 1'b0, Slave Mode when SPI\_CTRLR0 [20] is 1'b1.

### Transfer Modes

The SPI operates in the following three modes when transferring data on the serial bus.

1). Transmit and Receive

When SPI\_CTRLR0 [19:18] == 2'b00, both transmit and receive logic are valid.

2). Transmit Only

When SPI\_CTRLR0 [19:18] == 2'b01, the receive data are invalid and should not be stored in the receive FIFO.

3). Receive Only

When SPI\_CTRLR0 [19:18] == 2'b10, the transmit data are invalid.

### Clock Ratios

A summary of the frequency ratio restrictions between the bit-rate clock (sclk\_out/sclk\_in) and the SPI peripheral clock (spi\_clk) are described as,

When SPI Controller works as master, the  $F_{spi\_clk} \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. 25-3 SPI Format (SCPH=0 SCPOL=0)



Fig. 25-4 SPI Format (SCPH=0 SCPOL=1)

When the configuration parameter SCPH = 1, both master and slave peripherals begin transmitting data on the first serial clock edge after the slave select line is activated. The first data bit is captured on the second (trailing) serial clock edge. Data are propagated by the master and slave peripherals on the leading edge of the serial clock. During continuous data frame transfers, the slave select line may be held active-low until the last bit of the last frame has been captured. The following two figures show the timing diagram for the SPI format when the configuration parameter SCPH = 1.



Fig. 25-5 SPI Format (SCPH=1 SCPOL=0)



Fig. 25-6 SPI Format (SCPH=1 SCPOL=1)

## 25.4 Register Description

### 25.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        |
| 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: **B**- Byte (8 bits) access, **H**- Half WORD (16 bits) access, **W**-WORD (32 bits) access

### 25.4.2 Detail Register Description

#### SPI\_CTRLR0

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                | <p>fbm</p> <p>1'b0: First bit is MSB.</p> <p>1'b1: First bit is LSB.</p>                                                                                                                                                                                                                                                                                                     |
| 11         | RW          | 0x0                | <p>em</p> <p>Serial endian mode can be configured by this bit. APB endian mode is always little endian.</p> <p>1'b0: Little endian</p> <p>1'b1: Big endian</p>                                                                                                                                                                                                               |
| 10         | RW          | 0x0                | <p>ssd</p> <p>Valid when the frame format is set to Motorola SPI and SPI used as a master.</p> <p>1'b0: The period between ss_n active and sclk_out active is half sclk_out cycles.</p> <p>1'b1: The period between ss_n active and sclk_out active is one sclk_out cycle.</p>                                                                                               |
| 9:8        | RW          | 0x0                | <p>csm</p> <p>Valid when the frame format is set to Motorola SPI and SPI used as a master.</p> <p>2'b00: ss_n keep low after every frame data is transferred.</p> <p>2'b01: ss_n be high for half sclk_out cycles after every frame data is transferred.</p> <p>2'b10: ss_n be high for one sclk_out cycle after every frame data is transferred.</p> <p>2'b11: Reserved</p> |
| 7          | RW          | 0x0                | <p>scpol</p> <p>Valid when the frame format is set to Motorola SPI.</p> <p>1'b0: Inactive state of serial clock is low.</p> <p>1'b1: Inactive state of serial clock is high.</p>                                                                                                                                                                                             |
| 6          | RW          | 0x0                | <p>scph</p> <p>Valid when the frame format is set to Motorola SPI.</p> <p>1'b0: Serial clock toggles in middle of first data bit.</p> <p>1'b1: Serial clock toggles at start of first data bit.</p>                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                    |
| 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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------|
| 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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 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. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 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. |
| 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.       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 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          | 0x00000000         | 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 posdege 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. |
| 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 littel 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.                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 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. |

## 25.5 Interface Description

Table 25-1 SPI interface description

| <b>Module Pin</b>         | <b>Direction</b> | <b>Pad Name</b>                                                     | <b>IOMUX Setting</b>                      |
|---------------------------|------------------|---------------------------------------------------------------------|-------------------------------------------|
| <b>SPI0mux0 Interface</b> |                  |                                                                     |                                           |
| spi0_sclk                 | I/O              | GPIO0_B0/SPI0_CLK_M0                                                | PMUGRF_GPIO0B_IOMUX_SE<br>L_L[3:0]=4'h1   |
| spi0_rxd                  | I                | GPIO0_A7/SPI0_MISO_M0                                               | PMUGRF_GPIO0A_IOMUX_SE<br>L_H[15:12]=4'h1 |
| spi0_txd                  | O                | GPIO0_A6/SPI0莫斯I_M0                                                 | PMUGRF_GPIO0A_IOMUX_SE<br>L_H[11:8]=4'h1  |
| spi0_csn0                 | I/O              | GPIO0_A5/SPI0_CS0N_M0                                               | PMUGRF_GPIO0A_IOMUX_SE<br>L_H[7:4]=4'h1   |
| spi0_csn1                 | O                | GPIO0_A4/SPI0_CS1N_M0                                               | PMUGRF_GPIO0A_IOMUX_SE<br>L_H[3:0]=4'h1   |
| <b>SPI0mux1 Interface</b> |                  |                                                                     |                                           |
| spi0_sclk                 | I/O              | GPIO2_A1/SPI0_CLK_M1/I2S1_SDO_M1/UAR<br>T5_RX_M2                    | GRF_GPIO2A_IOMUX_SEL_L[<br>7:4]=4'h1      |
| spi0_rxd                  | I                | GPIO1_D7/SPI0_MISO_M1/I2S1_LRCK_M1/I<br>2C3_SDA_M2                  | GRF_GPIO1D_IOMUX_SEL_H<br>[15:12]=4'h1    |
| spi0_txd                  | O                | GPIO1_D6/SPI0莫斯I_M1/I2S1_SCLK_M1/I<br>2C3_SCL_M2                    | GRF_GPIO1D_IOMUX_SEL_H<br>[11:8]=4'h1     |
| spi0_csn0                 | I/O              | GPIO2_A0/SPI0_CS0n_M1/I2S1_SDI_M1/UA<br>RT5_TX_M2                   | GRF_GPIO2A_IOMUX_SEL_L[<br>3:0]=4'h1      |
| spi0_csn1                 | O                | GPIO1_D5/SPI0_CS1n_M1/I2S1_MCLK_M1/U<br>ART4_TX_M2                  | GRF_GPIO1D_IOMUX_SEL_H<br>[7:4]=4'h1      |
| <b>SPI0mux2 Interface</b> |                  |                                                                     |                                           |
| spi0_sclk                 | I/O              | GPIO2_B2/LCDC_D6/I2S2_LRCK_M1/UART5_<br>RTSN_M1/PWM1_M1/SPI0_CLK_M2 | GRF_GPIO2B_IOMUX_SEL_L[<br>11:8]=4'h6     |
| spi0_rxd                  | I                | GPIO2_B1/LCDC_D5/I2S2_SCLK_M1/UART5_<br>RX_M1/PWM2_M1/SPI0_MISO_M2  | GRF_GPIO2B_IOMUX_SEL_L[<br>7:4]=4'h6      |
| spi0_txd                  | O                | GPIO2_B0/LCDC_D4/I2S2_SDI_M1/UART5_T<br>X_M1/PWM3_IR_M1/SPI0莫斯I_M2  | GRF_GPIO2B_IOMUX_SEL_L[<br>3:0]=4'h6      |

| Module Pin                | Direction | Pad Name                                                                                | IOMUX Setting                      |
|---------------------------|-----------|-----------------------------------------------------------------------------------------|------------------------------------|
| spi0_csn0                 | I/O       | GPIO2_A7/LCDC_D3/I2S2_SDO_M1/UART4_RX_M1/PWM4_M1/SPI0_CS0N_M2                           | GRF_GPIO2A_IOMUX_SEL_H[15:12]=4'h6 |
| spi0_csn1                 | O         | GPIO2_B3/LCDC_D7/I2S2_MCLK_M1/CIF_D3_M1/UART5_CTSN_M1/PWM0_M1/SPI0_CS1_N_M2/I2C5_SDA_M0 | GRF_GPIO2B_IOMUX_SEL_L[15:12]=4'h6 |
| <b>SPI1mux0 Interface</b> |           |                                                                                         |                                    |
| spi1_sclk                 | I/O       | GPIO3_C0/CIF_D12_M0/RGMII_CLK_M0/PDM_CLK0_M1/SPI1_CLK_M0                                | GRF_GPIO3C_IOMUX_SEL_L[3:0]=4'h5   |
| spi1_rxd                  | I         | GPIO3_B7/CIF_D11_M0/RGMII_RXD1_M0/PD_M_SDI3_M1/SPI1_MISO_M0                             | GRF_GPIO3B_IOMUX_SEL_H[15:12]=4'h5 |
| spi1_txd                  | O         | GPIO3_B6/CIF_D10_M0/RGMII_RXD0_M0/PD_M_SDI2_M1/SPI1_MOSI_M0                             | GRF_GPIO3B_IOMUX_SEL_H[11:8]=4'h5  |
| spi1_csn0                 | I/O       | GPIO3_B5/CIF_D9_M0/RGMII_TXEN_M0/I2S0_SDO3_SDI1_M1/SPI1_CS0N_M0                         | GRF_GPIO3B_IOMUX_SEL_H[7:4]=4'h5   |
| spi1_csn1                 | O         | GPIO3_B4/CIF_D8_M0/RGMII_TXD1_M0/I2S0_SDO2_SDI2_M1/SPI1_CS1N_M0                         | GRF_GPIO3B_IOMUX_SEL_H[3:0]=4'h5   |
| <b>SPI1mux1 Interface</b> |           |                                                                                         |                                    |
| spi1_sclk                 | I/O       | GPIO1_C6/I2S2_SCLK_M0/SPI1_CLK_M1/PR_ELIGHT_TRIG_OUT/UART1_RTSN_M1                      | GRF_GPIO1C_IOMUX_SEL_H[11:8]=4'h3  |
| spi1_rxd                  | I         | GPIO1_C5/I2S2_SDI_M0/SPI1_MISO_M1/FLASH_TRIG_IN                                         | GRF_GPIO1C_IOMUX_SEL_H[7:4]=4'h3   |
| spi1_txd                  | O         | GPIO1_C4/I2S2_SDO_M0/SPI1_MOSI_M1/FLASH_TRIG_OUT                                        | GRF_GPIO1C_IOMUX_SEL_H[3:0]=4'h3   |
| spi1_csn0                 | I/O       | GPIO1_C7/I2S2_LRCK_M0/SPI1_CS0N_M1/UART1_CTSN_M1                                        | GRF_GPIO1C_IOMUX_SEL_H[15:12]=4'h3 |
| spi1_csn1                 | O         | GPIO1_D0/I2S2_MCLK_M0/SDMMC1_DET/SP11_CS1N_M1/I2C5_SCL_M2/UART1_TX_M1                   | GRF_GPIO1D_IOMUX_SEL_L[3:0]=4'h3   |
| <b>SPI1mux2 Interface</b> |           |                                                                                         |                                    |
| spi1_sclk                 | I/O       | GPIO2_D5/LCDC_HSYNC/PWM10_M1/SPI1_CLK_M2/I2C3_SDA_M1                                    | GRF_GPIO2D_IOMUX_SEL_H[7:4]=4'h6   |
| spi1_rxd                  | I         | GPIO2_D7/LCDC_CLK/UART3_CTSN_M2/PWM8_M1/SPI1_MISO_M2                                    | GRF_GPIO2D_IOMUX_SEL_H[15:12]=4'h6 |
| spi1_txd                  | O         | GPIO2_D6/LCDC_VSYNC/UART3_RTSN_M2/PWM9_M1/SPI1_MOSI_M2                                  | GRF_GPIO2D_IOMUX_SEL_H[11:8]=4'h6  |
| spi1_csn0                 | I/O       | GPIO2_D4/LCDC_DEN/PWM6_M1/SPI1_CS0N_M2/I2C3_SCL_M1                                      | GRF_GPIO2D_IOMUX_SEL_H[3:0]=4'h6   |
| spi1_csn1                 | O         | GPIO3_A0/CAN_RXD_M0/UART3_TX_M2/PWM7_IR_M1/SPI1_CS1N_M2/I2C4_SCL_M0                     | GRF_GPIO3A_IOMUX_SEL_L[3:0]=4'h6   |

Notes: I=input, O=output, I/O=input/output, bidirectional. spi\_csn1 can only be used in master mode

## 25.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 6 \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. 25-7 SPI Master transfer flow diagram



Fig. 25-8 SPI Slave transfer flow diagram

# Chapter 26 Flexible Serial Peripheral Interface (FSPI)

## 26.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 a 128-bit Memory-Mapped AHB slave to read from and write data to external device directly
- Support Memory-Mapped read with optional prefetch buffer
- Support independent clock for system bus HCLK and controller SCLK
- Support maskable interrupt generation
- Support sampling clock with optionally configurable delay line
- Support 2 CS# operation

## 26.2 Block Diagram



Fig. 26-1 FSPI Architecture

## 26.3 Function Description

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

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

### 26.3.3 Memory-Mapped AHB Slave

After the software initialize the controller based on the specialized memory device, CPU and other system bus masters can read data from external memory directly. If the external memory is SRAM or pSRAM, it also supports write data to it. The Memory-Mapped AHB Slave module can generate the relative CS# based on the access address from system address, example CS#0 and CS#1.

### 26.3.4 REG File

The REG File is configurable register bank to control the store the static configuration and dynamic status of controller.

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

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

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

## 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 FSPI Address Mapping Table

| Name      | Address Base | Size |
|-----------|--------------|------|
| FSPI CFG  | 0xFFC90000   | 64KB |
| FSPI MEM0 | 0xFD000000   | 16MB |
| FSPI MEM1 | 0xFFCA0000   | 64KB |

The address of FSPI MEM0 is accessible only when the INTCONNET\_CON0[3] is set to "1".

### 26.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_FTMR  | 0x000C | W    | 0x00001010  | FIFO Threshold Level Register   |
| FSPI_RCVR  | 0x0010 | W    | 0x00000000  | FSPI Recover Register           |

| Name                | Offset | Size | Reset Value | Description                                                 |
|---------------------|--------|------|-------------|-------------------------------------------------------------|
| 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    | 0x00000004  | Version Register                                            |
| FSPI_QOP            | 0x0030 | W    | 0x00000000  | Quad Line Operation IO Level Pre-set Register               |
| 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_DEVRGN         | 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: **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

#### FSPI\_CTRL0

Address: Operational Base + offset (0x0000)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14 | RO   | 0x00000     | reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 13:12 | RW   | 0x0         | <p>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.</p>                                                                                                                                          |
| 11:10 | RW   | 0x0         | <p>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.</p>                                                                                                                                       |
| 9:8   | RW   | 0x0         | <p>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.</p>                                                                                                                                       |
| 7:4   | RW   | 0x0         | <p>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.</p>     |
| 3:2   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 1     | RW   | 0x0         | <p>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".</p>                                                                                                                       |
| 0     | RW   | 0x0         | <p>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.</p> |

#### 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                                                                                                                                                                                         |
| 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                | RXFIM<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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 6          | W1<br>C     | 0x0                | NSPIC<br>NSPI Error Interrupt Clear<br>1'b0: No action<br>1'b1: Clear interrupt<br>Write "1" to clear the NSPIS.           |
| 5          | W1<br>C     | 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          | W1<br>C     | 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          | W1<br>C     | 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          | W1<br>C     | 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          | W1<br>C     | 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          | W1<br>C     | 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. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | RW          | 0x10               | <p>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/>...</p> <p>When the number of transmit FIFO entries is less than or equal to this value, the transmit FIFO empty interrupt is triggered.</p> |

**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 SC      | 0x0                | <p>RCVR<br/>FSPI Recover<br/>Write any values to trigger the recovery of SMC NSPI state machine, FIFO state and other logic state.</p> |

**FSPI\_AX0**

Address: Operational Base + offset (0x0014)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x000000           | reserved                                                                                                                                          |
| 7:0        | RW          | 0x00               | <p>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".</p> |

**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               | <p>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.</p> |

**FSPI\_ISR**

Address: Operational Base + offset (0x001C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31:8       | RO          | 0x00000000         | reserved                                                                                                                    |
| 7          | RO          | 0x0                | <p>DMAS<br/>DMA Finish Interrupt Status<br/>1'b0: No interrupt<br/>1'b1: Active interrupt generated</p>                     |
| 6          | RO          | 0x0                | <p>NSPIS<br/>NSPI Transaction Decode Error Interrupt Status<br/>1'b0: No interrupt<br/>1'b1: Active interrupt generated</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------|
| 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 |
| 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                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------|
| 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          | 0x0000000          | 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. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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          | 0x0004             | 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. |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                 |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.                         |
| 7:4  | RW   | 0x2         | 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.                         |
| 3:0  | RW   | 0x3         | 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. |

**FSPI DLL CTRL0**

Address: Operational Base + offset (0x003C)

| Bit   | Attr | Reset Value | Description                                                                                                          |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 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               | AX_SETUP_PAT<br>Auxiliary Setup Data Pattern<br>The AX data pattern that setup the continuous/enhance/XIP read mode     |
| 7:0        | RW          | 0xff               | AX_CANCEL_PAT<br>Auxiliary Cancel Data Pattern<br>The AX data pattern that cancel the continuous/enhance/XIP read mode. |

**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\_WCMD0**

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                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                      |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 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.                                                   |
| 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:14      | RO          | 0x00000            | reserved                                                                                                                                       |
| 13         | RO          | 0x0                | reserved                                                                                                                                       |
| 12         | RO          | 0x0                | reserved                                                                                                                                       |
| 11:8       | RO          | 0x0                | reserved                                                                                                                                       |
| 7          | RO          | 0x0                | 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. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------|
| 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          | 0x0000000          | 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                                                                                                                                                                                                                                                          |
| 4:0        | RW          | 0x17               | 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<br>In Memory-Mapped mode, the CS is controlled by AHB address bus, region size is used to generate CS. |

**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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0        | RW          | 0x12               | 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<br>Device size is used to generate slop over status. |

**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                | SCLK_INATM_EN<br>SCLK Inactive Timeout Enable<br>1'b0: Disable<br>1'b1: Enable |
| 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               | RX_FULL_WTMRK<br>Memory Mapped Mode Receiver FIFO Water Mark.<br>Default is enough. |

**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                                                     |
| 0          | W1C         | 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 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 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. |

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

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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         | SPI<br>Serial Peripheral Interface Mode<br>1'b0: Mode 0<br>1'b1: Mode 3<br>SPI 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)

| Bit  | Attr | Reset Value | Description                                                                                                                              |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 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\_ABIT1**

Address: Operational Base + offset (0x0218)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:5 | RO   | 0x0000000   | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 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. |
| 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.                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                           |
|------------|-------------|--------------------|--------------------------------------------------------------|
| 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          | 0x00000000         | reserved                                                                                                                                                                                                        |
| 4:0        | RW          | 0x12               | 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. |

**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           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | SCLK_INATM_EN<br>SCLK Inactive Timeout Enable<br>1'b0: Disable<br>1'b1: Enable |
| 0          | RO          | 0x0                | reserved                                                                       |

## 26.5 Interface Description

Table 26-2 FSPI(SFC) interface description

| <b>Module Pin</b> | <b>Direction</b> | <b>Pin Name</b>                              | <b>IOMUX Setting</b>             |
|-------------------|------------------|----------------------------------------------|----------------------------------|
| sfc_clk           | O                | FLASH_WPn/EMMC_RSTn/FSPI_CLK/GPIO1_A3_d      | GRF_GPIO1A_IOMUX_L[15:12]=3'b011 |
| sfc_csn0          | O                | FLASH_CS0n/FSPI_CS0n/I2S1_MCLK_M0/GPIO0_D4_u | GRF_GPIO0B_IOMUX_H[2:0]=3'b011   |
| sfc_csn1          | O                | FLASH_D5/EMMC_D5/FSPI_CS1n/GPIO0_D1_u        | GRF_GPIO0D_IOMUX_L[6:4]=3'b011   |
| sfc_sio0          | I/O              | FLASH_ALE/FSPI_D0/I2S1_LRCK_M0/GPIO1_A0_d    | GRF_GPIO0D_IOMUX_H[2:0]=3'b011   |
| sfc_sio1          | I/O              | FLASH_RDYn/FSPI_D1/I2S1_SCLK_M0/GPIO1_A1_u   | GRF_GPIO1A_IOMUX_L[6:4]=3'b011   |
| sfc_sio2          | I/O              | FSPI_D2/I2S1_SDO_M0/GPIO0_D6_d               | GRF_GPIO0D_IOMUX_H[10:8]=3'b011  |
| sfc_sio3          | I/O              | FLASH_RDn/FSPI_D3/I2S1_SD_M0/GPIO1_A2_u      | GRF_GPIO1A_IOMUX_L[10:8]=3'b011  |

Notes: **I**=input, **O**=output, **I/O**=input/output, bidirectional.

## 26.6 Application Notes

### 26.6.1 Typical Program Flow Without DMA



Fig. 26-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.

## 26.6.2 Typical READ Flow Without DMA



Fig. 26-3 Read Flow

### 26.6.3 Command Flow with DMA



Fig. 26-4 Command with DMA Flow

The total transfer bytes is decided by TRB register in FSPI\_CMD and must be aligned to 2 bytes.

## 26.6.4 SPI Mode and Shift Phase

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\_out. If SHIFTPHASE=1, it will sample the data at the negedge of sclk\_out.



Fig. 26-5 SPI mode

## 26.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 red 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 not idle level cycles.



Fig. 26-6 Idle cycles

## 26.6.6 Memory-Mapped Mode

After the Controller is configured as Memory-Mapped mode, the normal operation mode is not allowed which means indirect command transaction is forbidden unless software configures the FSPI\_MODE back to indirect access mode.

Before switching into Memory-Mapped mode, the software should initiate some transactions to configure the external device, such as Quad IO enable and IO Drive Strength.

In Memory-Mapped mode, it supports read transaction from serial NOR Flash and serial pSRAM, and the write transaction is only support by serial pSRAM.

## **Chapter 27 Mobile Storage Host Controller**

### **27.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

### **27.2 Block Diagram**

The Host Controller consists of the following main functional blocks.



Fig. 27-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.

## 27.3 Function Description

### 27.3.1 Bus Interface Unit

The Bus Interface Unit provides the following functions:

- Host interface
- Interrupt control
- Register access

- External FIFO access
- Power control and card detection

### **27.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.

### **27.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 – Command
- SDMMC\_CMDARG – Command Argument
- SDMMC\_BYTCNT – Byte Count
- SDMMC\_BLKSIZ – Block Size
- SDMMC\_CLKDIV – Clock Divider
- SDMMC\_CLKENA – Clock Enable
- SDMMC\_CLKSRC – Clock Source
- SDMMC\_TMOUT – Timeout
- SDMMC\_CTYPE – Card Type

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.

### **27.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 27-1 Bits in Interrupt Status Register

| <b>Bits</b> | <b>Interrupt</b>                          | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 competed.                                                             |
| 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. 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 occur due to a programming error on MSIZE and watermark values in SDMMC_FIFOTH register. |
| 10          | Data Starvation by Host Timeout (HTO)     | 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                 |

| <b>Bits</b> | <b>Interrupt</b>                  | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |                                   | <p>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> <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)          | 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.                                                                                                                                                                                                                                                                                                               |

| Bits | Interrupt           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                     | <p>Recommendation:<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:<br><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.<br/>Software should read card-detect register to determine current card status.</p> <p>Recommendation: 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> |

#### 27.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).

*Notes: The FIFO controller does not support simultaneous read/write access from the same port. For debugging purposes, the software may try to write into the FIFO and read back the data; results are indeterminate, since the design does not support read/write access from the same port.*

#### 27.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. 27-2 SD/MMC Card-Detect Signal

#### 27.3.2 Card Interface Unit

The Card Interface Unit (CIU) interfaces with the Bus Interface Units (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

### **27.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. 27-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\_CCSS 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.

#### **27.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. 27-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. 27-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 27-2 Auto-Stop Generation

| <b>Card type</b> | <b>Transfer type</b> | <b>Byte Count</b> | <b>send_auto_stop bit set</b> | <b>Comments</b>                    |
|------------------|----------------------|-------------------|-------------------------------|------------------------------------|
| 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 read  | 0                 | No                            | Open-ended multiple block          |
| SDIO             | Multiple-block read  | >0                | No                            | Pre-defined multiple block         |
| SDIO             | Multiple-block write | 0                 | No                            | Open-ended multiple block          |
| SDIO             | Multiple-block       | >0                | No                            | Pre-defined multiple block         |

| Card type | Transfer type | Byte Count | send_auto_stop bit set | Comments |
|-----------|---------------|------------|------------------------|----------|
|           | write         |            |                        |          |

*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 top 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.

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

| Base Address<br>[12:8]                       | CMD<br>27     | CMD<br>30                                     | CMD<br>42              | ACMD<br>13    | ACMD<br>22 | ACMD<br>51    |
|----------------------------------------------|---------------|-----------------------------------------------|------------------------|---------------|------------|---------------|
| wait_prevdata_complete                       | 0             | 0                                             | 0                      | 0             | 0          | 0             |
| stop_abort_cmd                               | 0             | 0                                             | 0                      | 0             | 0          | 0             |
| <b>Command Argument register programming</b> |               |                                               |                        |               |            |               |
|                                              | stuff<br>bits | 32-bit<br>write<br>protect<br>data<br>address | stuff bits             | stuff<br>bits | stuff bits | stuff<br>bits |
| <b>Block Size register programming</b>       |               |                                               |                        |               |            |               |
|                                              | 16            | 4                                             | Num_bytes <sup>D</sup> | 64            | 4          | 8             |
| <b>Byte Count register programming</b>       |               |                                               |                        |               |            |               |
|                                              | 16            | 4                                             | Num_bytes <sup>D</sup> | 64            | 4          | 8             |

<sup>D</sup>: Num\_bytes = No. of bytes specified as per the lock card data structure (Refer to the SD specification and the MMC specification)

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

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

### **27.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.

### **27.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.

#### **27.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.

#### **27.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. 27-6 Dual-Buffer Descriptor Structure

- Chain Structure – Each descriptor points to a unique buffer and the next descriptor.



Fig. 27-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.

Descriptor format  
for 32-bit bus width

Fig. 27-8 Descriptor Formats for 32-bit AHB Address Bus Width

- The DES0 element in the IDMAC contains control and status information.

Table 27-4 Bits in IDMAC DES0 Element

| Bit | Name                     | Description                                                                                                                                                                                                                 |
|-----|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | OWN                      | When set, this bit indicates that the descriptor is owned by the IDMAC.<br>When this bit is reset, it indicates that the descriptor is owned by the Host.<br>The IDMAC clears this bit when it completes the data transfer. |
| 30  | Card Error Summary (CES) | These error bits indicate the status of the transaction to or from the card.<br>These bits are also present in SDMMC_RINTSTS. Indicates the logical OR of the following bits:                                               |

| Bit  | Name                                  | Description                                                                                                                                                                                                                                                                                                                                                |
|------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                                       | <ul style="list-style-type: none"> <li>● EBE: End Bit Error</li> <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 27-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 27-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 |

| Bit  | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                     | 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 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 27-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. |

### 27.3.3.3 Initialization

IDMAC initialization occurs as follows:

- 1) Write to IDMAC Bus Mode Register—SDMMC\_BMOD to set Host bus access parameters.
- 2) Write to IDMAC Interrupt Enable Register—SDMMC\_IDINTEN to mask unnecessary interrupt causes.
- 3) 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.
- 4) 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.

### 27.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. 27-9 Clock Generation Unit

## 27.4 Register Description

### 27.4.1 Registers Summary

| Name          | Offset | Size | Reset Value | Description                      |
|---------------|--------|------|-------------|----------------------------------|
| SDMMC_CTRL    | 0x0000 | W    | 0x00000000  | Control register                 |
| SDMMC_PWREN   | 0x0004 | W    | 0x00000000  | Power enable register            |
| SDMMC_CLKDIV  | 0x0008 | W    | 0x00000000  | Clock divider register           |
| SDMMC_CLKSRC  | 0x000c | W    | 0x00000000  | SD clock source register         |
| SDMMC_CLKENA  | 0x0010 | W    | 0x00000000  | Clock enable register            |
| SDMMC_TMOUT   | 0x0014 | W    | 0xFFFFF40   | Timeout register                 |
| SDMMC_CTYPE   | 0x0018 | W    | 0x00000000  | Card type register               |
| SDMMC_BLKSIZ  | 0x001c | W    | 0x00000200  | Block size register              |
| SDMMC_BYTCNT  | 0x0020 | W    | 0x00000200  | Byte count register              |
| SDMMC_INTMASK | 0x0024 | W    | 0x00000000  | Interrupt mask register          |
| SDMMC_CMDARG  | 0x0028 | W    | 0x00000000  | Command argument register        |
| SDMMC_CMD     | 0x002c | W    | 0x20000000  | Command register                 |
| SDMMC_RESP0   | 0x0030 | W    | 0x00000000  | Response register 0              |
| SDMMC_RESP1   | 0x0034 | W    | 0x00000000  | Response register 1              |
| SDMMC_RESP2   | 0x0038 | W    | 0x00000000  | Response register 2              |
| SDMMC_RESP3   | 0x003c | W    | 0x00000000  | Response register 3              |
| SDMMC_MINTSTS | 0x0040 | W    | 0x00000000  | Masked interrupt status register |

| Name                | Offset | Size | Reset Value | Description                                      |
|---------------------|--------|------|-------------|--------------------------------------------------|
| SDMMC_RINTSTS       | 0x0044 | W    | 0x00000000  | Raw interrupt status register                    |
| SDMMC_STATUS        | 0x0048 | W    | 0x00000106  | Status register                                  |
| SDMMC_FIFOTH        | 0x004c | W    | 0x00FF0000  | FIFO threshold register                          |
| SDMMC_CDETECT       | 0x0050 | W    | 0x00000001  | Card detect register                             |
| SDMMC_WRTPRT        | 0x0054 | W    | 0x00000000  | Write protect register                           |
| SDMMC_TCBCNT        | 0x005c | W    | 0x00000000  | Transferred card byte count register             |
| SDMMC_TBBCNT        | 0x0060 | W    | 0x00000000  | Transferred host to FIFO byte count register     |
| SDMMC_DEBNCE        | 0x0064 | W    | 0x00FFFFFF  | Debounce count register                          |
| SDMMC_USRID         | 0x0068 | W    | 0x00000000  | User ID register                                 |
| SDMMC_VERID         | 0x006c | W    | 0x5342270A  | Version ID register                              |
| SDMMC_HCON          | 0x0070 | W    | 0x04C434C1  | Hardware configuration register                  |
| SDMMC_UHSREG        | 0x0074 | W    | 0x00000000  | UHS-1 control register                           |
| SDMMC_RSTN          | 0x0078 | W    | 0x00000001  | Hardware reset register                          |
| SDMMC_BMOD          | 0x0080 | W    | 0x00000000  | Bus mode register                                |
| SDMMC_PLDMND        | 0x0084 | W    | 0x00000000  | Poll demand register                             |
| SDMMC_DBADDR        | 0x0088 | W    | 0x00000000  | Descriptor list base address register            |
| SDMMC_IDSTS         | 0x008c | W    | 0x00000000  | Internal DMAC status register                    |
| SDMMC_IDINTEN       | 0x0090 | W    | 0x00000000  | Internal DMAC interrupt enable register          |
| SDMMC_DSCADDR       | 0x0094 | W    | 0x00000000  | Current host descriptor address register         |
| SDMMC_BUFADDR       | 0x0098 | W    | 0x00000000  | Current buffer descriptor address register       |
| SDMMC_CARDTHRCTL    | 0x0100 | W    | 0x00000000  | Card threshold control register                  |
| SDMMC_BACKEND_POWER | 0x0104 | W    | 0x00000000  | Back-end power register                          |
| SDMMC_EMMCDDR_REG   | 0x010c | W    | 0x00000000  | eMMC4.5 DDR start bit detection control register |
| SDMMC_RDYINT_GEN    | 0x0120 | W    | 0x00FF0000  | Card ready interrupt generation control register |
| SDMMC_FIFO_BASE     | 0x0200 | W    | 0x00000000  | FIFO base address register                       |

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

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RW          | 0x0                | <p>ceata_device_interrupt_status<br/>           1'b0: Interrupts not enabled in CE-ATA device<br/>           1'b1: Interrupts are enabled in CE-ATA device</p> <p>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 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</p> <p>NOTE: Always set send_auto_stop_ccsd and send_ccsd bits together send_auto_stop_ccsd should not be set independent of send_ccsd.</p> <p>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</p> <p>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.</p> <p>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.</p> <p>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>                                                                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RW          | 0x0                | read_wait<br>1'b0: Clear read wait<br>1'b1: Assert read wait<br>For sending read-wait to SDIO cards.                                                                                                                                                                                                                                                                                                                                                                                       |
| 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          | WO          | 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          | WO          | 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          | WO          | 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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   | 0x000000    | reserved                                                                                                                                                                                                                   |
| 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)

| Bit  | Attr | Reset Value | Description                                                                                                                                         |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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<br>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)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                        |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                   |
| 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         | cmd_arg<br>Value indicates command argument to be passed to card. |

**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:<br>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_TMOOUT, 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         | WO          | 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         | WO          | 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       | WO          | 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------|
| 1          | RO          | 0x1                | fifo_tx_watermark<br>FIFO reached Transmit watermark level; not qualified with data transfer. |
| 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                | 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 |

**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                | write_protect<br>Value on card_write_prt input port. 1 represents write protection. |

**SDMMC\_TCBCNT**

Address: Operational Base + offset (0x005c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | trans_card_byte_count<br>Number of bytes transferred by CIU unit to card. |

**SDMMC\_TBBCNT**

Address: Operational Base + offset (0x0060)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | trans_fifo_byte_count<br>Number of bytes transferred between host/DMA memory and BIU FIFO. |

**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: DW_DMA<br>2'b10: GENERIC_DMA<br>2'b11: NON-DW-DMA       |
| 15:10      | RO          | 0x1f               | 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. 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         | 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. |

**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                                                                                                                                                                                                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0x0         | <p>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:</p> <ul style="list-style-type: none"> <li>EBC: End Bit Error</li> <li>RTO: Response Timeout/Boot Ack Timeout</li> <li>RCRC: Response CRC</li> <li>SBE: Start Bit Error</li> <li>DRTO: Data Read Timeout/BDS timeout</li> <li>DCRC: Data CRC for Receive</li> <li>RE: Response Error</li> </ul> <p>Writing a 1 clears this bit.</p> <p>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.</p> |
| 4   | RW   | 0x0         | <p>dui<br/>Descriptor unavailable interrupt. This bit is set when the descriptor is unavailable due to OWN bit = 0 (DES0[31] =0). Writing a 1 clears this bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2   | RW   | 0x0         | <p>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1   | RW   | 0x0         | <p>ri<br/>Receive interrupt.<br/>Indicates the completion of data reception for a descriptor. Writing a 1 clears this bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0   | RW   | 0x0         | <p>ti<br/>Transmit interrupt.<br/>Indicates that data transmission is finished for a descriptor. Writing 1 clears this bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**SDMMC\_IDINTEN**

Address: Operational Base + offset (0x0090)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                     |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:10 | RO   | 0x000000    | reserved                                                                                                                                                                                                                                                        |
| 9     | RW   | 0x0         | <p>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</p>                                      |
| 8     | RW   | 0x0         | <p>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</p> |
| 7:6   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.                             |
| 0          | RW          | 0x0                | ti<br>Transmit interrupt enable.<br>When set with normal interrupt summary enable, transmit interrupt is enabled.<br>When reset, transmit interrupt is disabled.                          |

**SDMMC\_DSCADDR**

Address: Operational Base + offset (0x0094)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | 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. |

**SDMMC\_BUFAADDR**

Address: Operational Base + offset (0x0098)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | 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. |

**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                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 zcard_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                                                                                                             |
| 0          | RW          | 0x0                | <p>back_end_power<br/>Back end power.<br/>1'b0: Off; Reset<br/>1'b1: Back-end power supplied to card application</p> |

**SDMMC EMMCDDR REG**

Address: Operational Base + offset (0x010c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                    |
| 0          | RW          | 0x0                | <p>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.</p> |

**SDMMC RDYINT GEN**

Address: Operational Base + offset (0x0120)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:25      | RO          | 0x00               | reserved                                                                                                                 |
| 24         | RO          | 0x0                | <p>rdyint_cnt_finish<br/>Counter finish indication.<br/>When high, it indicates that the rdyint counter is finished.</p> |
| 23:16      | RO          | 0xff               | rdyint_cnt_status<br>Counter status, reflect internal counter value.                                                     |
| 15:9       | RO          | 0x00               | reserved                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                  |
|------------|-------------|--------------------|-------------------------------------|
| 31:0       | RW          | 0x00000000         | fifo_base_addr<br>FIFO base address |

**27.5 Interface Description****27.5.1 SDMMC Interface Description**

Table 27-8 SDMMC Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>PIN Name</b>                                                  | <b>IOMUX Setting</b>           |
|-------------------|------------------|------------------------------------------------------------------|--------------------------------|
| sdmmc_cclk        | O                | SDMMC0_CLK/UART3_RTS_N_M1/RISC-V_JTAG_TDO/GPIO1_B0_u             | GRF_GPIO1B_IOMUX_L[3:0]=4'h1   |
| sdmmc_ccmd        | I/O              | SDMMC0_CMD/UART3_CT_SN_M1/RISC-V_JTAG_TDI/GPIO1_B1_u             | GRF_GPIO1B_IOMUX_L[7:4]=4'h1   |
| sdmmc_cdata0      | I/O              | SDMMC0_D0/TEST_CLK1_OUT/UART2_RX_M0/GPIO1_A4_u                   | GRF_GPIO1A_IOMUX_H[3:0]=4'h1   |
| sdmmc_cdata1      | I/O              | SDMMC0_D1/TEST_CLK0_OUT/UART2_TX_M0/RISC-V_JTAG_TRSTn/GPIO1_A5_u | GRF_GPIO1A_IOMUX_H[7:4]=4'h1   |
| sdmmc_cdata2      | I/O              | SDMMC0_D2/UART3_RX_M1/A7_JTAG_TCK_M0/RIS_C-V_JTAG_TCK/GPIO1_A6_u | GRF_GPIO1A_IOMUX_H[11:8]=4'h1  |
| sdmmc_cdata3      | I/O              | SDMMC0_D3/UART3_TX_M1/A7_JTAG_TMS_M0/RIS_C-V_JTAG_TMS/GPIO1_A7_u | GRF_GPIO1A_IOMUX_H[15:12]=4'h1 |
| sdmmc_cdtn        | I                | SDMMC0_DET/GPIO0_A3_u                                            | GRF_GPIO0A_IOMUX_L[15:12]=4'h1 |
| sdmmc_pwr         | O                | SDMMC0_PWR/UART1_RTSN_M0/PWM2_M0/GPIO0_C0_d                      | GRF_GPIO0C_IOMUX_L[3:0]=4'h1   |

Notes: I=input, O=output, I/O=input/output, bidirectional

**27.5.2 SDIO Interface Description**

Table 27-9 SDIO Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>PIN Name</b>       | <b>IOMUX Setting</b>           |
|-------------------|------------------|-----------------------|--------------------------------|
| sdio_cclk         | O                | SDMMC1_CLK/GPIO1_B2_d | GRF_GPIO1B_IOMUX_L[11:8]=4'h1  |
| sdio_ccmd         | I/O              | SDMMC1_CMD/GPIO1_B3_u | GRF_GPIO1B_IOMUX_L[15:12]=4'h1 |

| <b>Module Pin</b> | <b>Direction</b> | <b>PIN Name</b>                                                         | <b>IOMUX Setting</b>              |
|-------------------|------------------|-------------------------------------------------------------------------|-----------------------------------|
| sdio_cdata0       | I/O              | SDMMC1_D0/GPIO1_B4_u                                                    | GRF_GPIO1B_IOMUX_H[3:0]<br>=4'h1  |
| sdio_cdata1       | I/O              | SDMMC1_D1/GPIO1_B5_u                                                    | GRF_GPIO1B_IOMUX_H[7:4]<br>=4'h1  |
| sdio_cdata2       | I/O              | SDMMC1_D2/GPIO1_B6_u                                                    | GRF_GPIO1B_IOMUX_H[11:8]<br>=4'h1 |
| sdio_cdata3       | I/O              | SDMMC1_D3/GPIO1_B7_u                                                    | GRF_GPIO1B_IOMUX_H[15:12]=4'h1    |
| sdio_cdetn        | I                | I2S2_MCLK_M0/SDMMC1_DET/SPI1_CS1n_M1/I2C5_SCL_M2/UART1_TX_M1/GPIO1_D0_d | GRF_GPIO1D_IOMUX_L[3:0]<br>=4'h2  |
| sdio_pwr          | O                | SDMMC1_PWR/I2C5_SDA_M2/UART1_RX_M1/GPIO1_D1_d                           | GRF_GPIO1D_IOMUX_L[7:4]<br>=4'h1  |

Notes: I=input, O=output, I/O=input/output, bidirectional

### 27.5.3 EMMC Interface Description

Table 27-10 EMMC Interface Description

| <b>Module Pin</b> | <b>Direction</b> | <b>PIN Name</b>                          | <b>IOMUX Setting</b>               |
|-------------------|------------------|------------------------------------------|------------------------------------|
| emmc_cclk         | O                | FLASH_CLE/EMMC_CLKO(GPIO0_D7_d)          | GRF_GPIO0D_IOMUX_H[15:12]=4'h2     |
| emmc_ccmd         | I/O              | FLASH_WRn/EMMC_CMD(GPIO0_D5_u)           | GRF_GPIO0D_IOMUX_H[7:4]=4'h2       |
| emmc_cdata0       | I/O              | FLASH_D0/EMMC_D0(GPIO0_C4_u)             | GRF_GPIO0C_IOMUX_H[3:0]<br>=4'h2   |
| emmc_cdata1       | I/O              | FLASH_D1/EMMC_D1(GPIO0_C5_u)             | GRF_GPIO0C_IOMUX_H[7:4]<br>=4'h2   |
| emmc_cdata2       | I/O              | FLASH_D2/EMMC_D2(GPIO0_C6_u)             | GRF_GPIO0C_IOMUX_H[11:8]<br>=4'h2  |
| emmc_cdata3       | I/O              | FLASH_D3/EMMC_D3(GPIO0_C7_u)             | GRF_GPIO0C_IOMUX_H[15:12]=4'h2     |
| emmc_cdata4       | I/O              | FLASH_D4/EMMC_D4(GPIO0_D0_u)             | GRF_GPIO0D_IOMUX_L[3:0]<br>=4'h2   |
| emmc_cdata5       | I/O              | FLASH_D5/EMMC_D5/FSPI_CS1n(GPIO0_D1_u)   | GRF_GPIO0D_IOMUX_L[7:4]<br>=4'h2   |
| emmc_cdata6       | I/O              | FLASH_D6/EMMC_D6(GPIO0_D2_u)             | GRF_GPIO0D_IOMUX_L[11:8]<br>=4'h2  |
| emmc_cdata7       | I/O              | FLASH_D7/EMMC_D7(GPIO0_D3_u)             | GRF_GPIO0D_IOMUX_L[15:12]<br>=4'h2 |
| emmc_rstn         | O                | FLASH_WPn/EMMC_RSTn/FSPI_CLK(GPIO1_A3_d) | GRF_GPIO1A_IOMUX_L[15:12]<br>=4'h2 |

Notes: I=input, O=output, I/O=input/output, bidirectional

## 27.6 Application Notes

### 27.6.1 Card-Detect and Write-Protect Mechanism

Following figure illustrates how the SD/MMC card detection and write-protect signals are connected. Most of the SD/MMC sockets have card-detect pins. When no card is present, card\_detect\_n is 1 due to the pull-up. When the card is inserted, the card-detect pin is shorted to ground, which makes card\_detect\_n go to 0. Similarly in SD cards, when the write-protect switch is toward the left, it shorts the write\_protect port to ground.



Fig. 27-10 SD/MMC Card-Detect and Write-Protect

### 27.6.2 SD/MMC Termination Requirement

Following Figure illustrates the SD/MMC termination requirements, which is required to pull up ccmd and cdata lines on the device bus. The recommended specification for pull-up on the ccmd line (Rcmd) is 4.7K - 100K for MMC, and 10K - 100K for an SD. The recommended pull-up on the cdata line (Rdat) is 50K - 100K.



Fig. 27-11 SD/MMC Card Termination

#### Rcmd and Rod Calculation

The SD/MMC card enumeration happens at a very low frequency – 100-400KHz. Since the MMC bus is a shared bus between multiple cards, during enumeration open-drive mode is used to avoid bus conflict. Cards that drive 0 win over cards that drive “z”. The pull-up in the command line pulls the bus to 1 when all cards drive “z”. During normal data transfer, the host chooses only one card and the card driver switches to push-pull mode.

For example, if enumeration is done at 400KHz and the total bus capacitance is 200 pF, the pull-up needed during enumeration is:

$$2.2 \text{ RC} = \text{rise-time} = 1/400\text{KHz}$$

$$R = 1/(2.2 * C * 100\text{KHz})$$

$$= 1/(2.2 * 200 * 10^{-12} * 400 * 10^3)$$

$$= 1/(17.6 * 10^{-5})$$

$$= 5.68\text{K}$$

The ROD and RCMD should be adjusted in such a way that the effective pull-up is at the maximum 5.68K during enumeration. If there are only a few cards in the bus, a fixed RCMD resistor is sufficient and there is no need for an additional ROD pull-up during enumeration. You should also ensure the effective pull-up will not violate the  $I_{OL}$  rating of the drivers.

In SD mode, since each card has a separate bus, the capacitance is less, typically in the order of 20-30pF (host capacitance + card capacitance + trace + socket capacitance). For example, if enumeration is done at 400KHz and the total bus capacitance is 20pF, the pull-up needed during enumeration is:

$$2.2 \text{ RC} = \text{rise-time} = 1/400\text{KHz}$$

$$R = 1/(2.2 * C * 100\text{KHz})$$

$$= 1/(2.2 * 20 * 10^{-12} * 400 * 10^3)$$

$$= 1/(1.76 * 10^{-5})$$

$$= 56.8\text{K}$$

Therefore, a fixed 56.8K permanent Rcmd is sufficient in SD mode to enumerate the cards.

The driver of the SD/MMC on the “command” port needs to be only a push-pull driver. During enumeration, the SD/MMC emulates an open-drain driver by driving only a 0 or a “z” by controlling the ccmd\_out and ccmd\_out\_en signals.

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

If the card is enumerated in SDR50, or DDR50 mode, then the application must program the use\_hold\_reg bit[29] in the SDMMC\_CMD register to 1'b0 (phase shift of cclk\_in\_drv = 0) or 1'b1 (phase shift of cclk\_in\_drv>0). If the card is enumerated in SDR12 or SDR25 mode, the application must program the use\_hold\_reg bit[29] in the SDMMC\_CMD register to 1'b1. This programming should be done for all data transfer commands and non-data commands that are sent to the card. When the use\_hold\_reg bit is programmed to 1'b0, the Host Controller bypasses the Hold Registers in the transmit path. The value of this bit should not be changed when a Command or Data Transfer is in progress. For more details on using use\_hold\_reg and the implementation requirements for meeting the Card input hold time, refer to “Recommended Usage” in following table.

Table 27-11 Recommended Usage of use\_hold\_reg

| No. | Speed Mode   | use_hold_reg | cclk_in (MHz) | clk_in_drv (MHz) | clk_divider | Phase shift |
|-----|--------------|--------------|---------------|------------------|-------------|-------------|
| 1   | SDR104       | 1'b0         | 200           | 200              | 0           | 0           |
| 2   | SDR104       | 1'b1         | 200           | 200              | 0           | Tunable> 0  |
| 3   | SDR50        | 1'b0         | 100           | 100              | 0           | 0           |
| 4   | SDR50        | 1'b1         | 100           | 100              | 0           | Tunable> 0  |
| 5   | DDR50 (8bit) | 1'b0         | 100           | 100              | 1           | 0           |
| 6   | DDR50 (8bit) | 1'b1         | 100           | 100              | 1           | Tunable> 0  |
| 7   | DDR50 (4bit) | 1'b0         | 50            | 50               | 0           | 0           |
| 8   | DDR50 (4bit) | 1'b1         | 50            | 50               | 0           | Tunable> 0  |
| 9   | SDR25        | 1'b1         | 50            | 50               | 0           | Tunable> 0  |
| 10  | SDR12        | 1'b1         | 50            | 50               | 1           | Tunable> 0  |

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 all clocks. 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 registers, 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.

## 27.6.4 Programming Sequence

### 27.6.4.1 Initialization

Following figure illustrates the initialization flow.



Fig. 27-12 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:0xfffff) in host clock cycle units in the SDMMC\_DEBNCE register.
    - FIFO threshold value in bytes in the SDMMC\_FIFOTH register.

#### **27.6.4.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.

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

### 27.6.4.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 long 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 27-12 Command Settings for No-Data Command

| Parameter            | Value | Description                                                                              |
|----------------------|-------|------------------------------------------------------------------------------------------|
| <b>Default</b>       |       |                                                                                          |
| start_cmd            | 1     | -                                                                                        |
| use_hold_reg         | 1/0   | 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)                                                                  |

| Parameter              | Value         | Description                                                                                                                                                                                                                                           |
|------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        |               | 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 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.

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

#### 27.6.4.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 27-13 Command Setting for Single or Multiple-Block Read

| Parameter            | Value | Description                                                                              |
|----------------------|-------|------------------------------------------------------------------------------------------|
| <b>Default</b>       |       |                                                                                          |
| start_cmd            | 1     | -                                                                                        |
| use_hold_reg         | 1/0   | 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           |

| Parameter              | Value         | Description                                                                                      |
|------------------------|---------------|--------------------------------------------------------------------------------------------------|
|                        | 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.

#### 27.6.4.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 27-14 Command Settings for Single or Multiple-Block Write

| Parameter            | Value | Description                                                                              |
|----------------------|-------|------------------------------------------------------------------------------------------|
| <b>Default</b>       |       |                                                                                          |
| start_cmd            | 1     | -                                                                                        |
| use_hold_reg         | 1/0   | 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)                                                                    |

| Parameter              | Value         | Description                                                                                      |
|------------------------|---------------|--------------------------------------------------------------------------------------------------|
|                        |               | 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.

#### 27.6.4.8 Stream Read

A stream read is like the block read mentioned in "Single-Block or Multiple-Block Read", except for the following bits in the Command register:

```
transfer_mode = 1; //Stream transfer
cmd_index = CMD20;
```

A stream transfer is allowed for only a single-bit bus width.

#### 27.6.4.9 Stream Write

A stream write is exactly like the block write mentioned in "Single-Block or Multiple-Block Write", except for the following bits in the Command register:

```
transfer_mode = 1;//Stream transfer
cmd_index = CMD11;
```

In a stream transfer, if the byte count is 0, then the software must send the STOP command. If the byte count is not 0, then when a given number of bytes completes a transfer, the Host Controller sends the STOP command. Completion of this AUTO\_STOP command is reflected by the Auto\_command\_done interrupt. A response to an AUTO\_STOP is stored in the SDMMC RESP1 register@0x34.

A stream transfer is allowed for only a single-bit bus width.

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

#### **27.6.4.11 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.
- 3) Clear the read\_wait bit in the SDMMC\_CTRL register.

#### **27.6.4.12 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.

#### **27.6.4.13 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.

#### **27.6.4.14 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.*

## **27.6.5 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.

### 27.6.5.1 Voltage Switch Operation

The Voltage Switch operation must be performed in SD mode only.



Fig. 27-13 Voltage Switching Command Flow Diagram

The following outlines the steps for the voltage switch programming sequence

- 1) Software Driver starts CMD0, which selects the bus mode as SD.
- 2) 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.
- 3) 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.



Fig. 27-14 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.

| 47 | 46 | 45-40  | 39      | 38     | 37      | 36-33          | 32      | 31-16     | 15-08          | 07-01   | 00 |
|----|----|--------|---------|--------|---------|----------------|---------|-----------|----------------|---------|----|
| S  | D  | Index  | Busy 31 | CCS 30 | Rsvd 29 | Reserved 28-25 | S18R 24 | OCR 23-08 | Reserved 07-00 | CRC7    | E  |
| 0  | 0  | 111111 | X       | X      | 0       | 0000           | X       | xxxxh     | 0000000        | 1111111 | 1  |

**Busy Status**  
 0b: On Initialization  
 1b: Initialization complete

**Card Capacity Status**  
 0b: SDSC  
 1b: SCHC or SCXC

**S18R: Switching to 1.8V Accepted**  
 0b: Continues current voltage signalling  
 1b: Ready for switching signal voltage

Fig. 27-15 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
- 4) 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".

### 27.6.5.2 Voltage Switch Normal Scenario



Fig. 27-16 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 * 10\mu s = 1600\mu s = 1.6ms \sim 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.

### 27.6.5.3 Voltage Switch Error Scenario



Fig. 27-17 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.

## **27.6.6 DDR Operation**

### **27.6.6.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.
- 2) 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.

### **27.6.6.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.
- 4) 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.

### **27.6.6.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.*

### **27.6.6.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.*

## **27.6.7 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.*

## 27.6.8 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

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

### 27.6.8.2 Programming of PBL and Watermark Levels

The DMAC performs data transfers depending on the programmed PBL and threshold values.

Table 27-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 |

## 27.6.9 Variable Delay Usage

The control signals for variable delay usage are shown as follows.

### 27.6.9.1 SDMMC Variable Delay Usage

Table 27-16 Configuration for SDMMC Variable Delay Usage

| Signal Name     | Source              | Default | Description                                 |
|-----------------|---------------------|---------|---------------------------------------------|
| init_state      | CRU_SDMMC_CON0[0]   | 0       | Soft initial state for phase shift.         |
| drv_degree[1:0] | CRU_SDMMC_CON0[2:1] | 2       | Phase shift for cclk_in_drv.<br>0: 0-degree |

| <b>Signal Name</b>   | <b>Source</b>        | <b>Default</b> | <b>Description</b>                                                                                                  |
|----------------------|----------------------|----------------|---------------------------------------------------------------------------------------------------------------------|
|                      |                      |                | 1: 90-degree<br>2: 180-degree<br>3: 270-degree                                                                      |
| drv_delaynum[7:0]    | CRU_SDMMC_CON0[10:3] | 0              | Element number in delay line for cclk_in_drv                                                                        |
| drv_sel              | CRU_SDMMC_CON0[11]   | 0              | cclk_in_drv source selection:<br>0: use clock after phase_shift<br>1: use clock after phase_shift and delay line    |
| sample_degree[1:0]   | CRU_SDMMC_CON1[2:1]  | 0              | Phase shift for cclk_in_sample.<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree                    |
| sample_delaynum[7:0] | CRU_SDMMC_CON1[10:3] | 0              | Element number in delay line for cclk_in_sample                                                                     |
| sample_sel           | CRU_SDMMC_CON1[11]   | 0              | cclk_in_sample source selection:<br>0: use clock after phase_shift<br>1: use clock after phase_shift and delay line |

### 27.6.9.2 SDIO Variable Delay Usage

Table 27-17 Configuration for SDIO Variable Delay Usage

| <b>Signal Name</b>   | <b>Source</b>       | <b>Default</b> | <b>Description</b>                                                                                                  |
|----------------------|---------------------|----------------|---------------------------------------------------------------------------------------------------------------------|
| init_state           | CRU_SDIO_CON0[0]    | 0              | Soft initial state for phase shift.                                                                                 |
| drv_degree[1:0]      | CRU_SDIO_CON0[2:1]  | 2              | Phase shift for cclk_in_drv.<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree                       |
| drv_delaynum[7:0]    | CRU_SDIO_CON0[10:3] | 0              | Element number in delay line for cclk_in_drv                                                                        |
| drv_sel              | CRU_SDIO_CON0[11]   | 0              | cclk_in_drv source selection:<br>0: use clock after phase_shift<br>1: use clock after phase_shift and delay line    |
| sample_degree[1:0]   | CRU_SDIO_CON1[2:1]  | 0              | Phase shift for cclk_in_sample.<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree                    |
| sample_delaynum[7:0] | CRU_SDIO_CON1[10:3] | 0              | Element number in delay line for cclk_in_sample.                                                                    |
| sample_sel           | CRU_SDIO_CON1[11]   | 0              | cclk_in_sample source selection:<br>0: use clock after phase_shift<br>1: use clock after phase_shift and delay line |

### 27.6.9.3 EMMC Variable Delay Usage

Table 27-18 Configuration for EMMC Variable Delay Usage

| <b>Signal Name</b> | <b>Source</b>      | <b>Default</b> | <b>Description</b>                                                                            |
|--------------------|--------------------|----------------|-----------------------------------------------------------------------------------------------|
| init_state         | CRU_EMMC_CON0[0]   | 0              | Soft initial state for phase shift.                                                           |
| drv_degree[1:0]    | CRU_EMMC_CON0[2:1] | 2              | Phase shift for cclk_in_drv.<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree |

| <b>Signal Name</b>   | <b>Source</b>       | <b>Default</b> | <b>Description</b>                                                                                                  |
|----------------------|---------------------|----------------|---------------------------------------------------------------------------------------------------------------------|
| drv_delaynum[7:0]    | CRU_EMMC_CON0[10:3] | 0              | Element number in delay line for cclk_in_drv                                                                        |
| drv_sel              | CRU_EMMC_CON0[11]   | 0              | cclk_in_drv source selection:<br>0: use clock after phase_shift<br>1: use clock after phase_shift and delay line    |
| sample_degree[1:0]   | CRU_EMMC_CON1[2:1]  | 0              | Phase shift for cclk_in_sample.<br>0: 0-degree<br>1: 90-degree<br>2: 180-degree<br>3: 270-degree                    |
| sample_delaynum[7:0] | CRU_EMMC_CON1[10:3] | 0              | Element number in delay line for cclk_in_sample                                                                     |
| sample_sel           | CRU_EMMC_CON1[11]   | 0              | cclk_in_sample source selection:<br>0: use clock after phase_shift<br>1: use clock after phase_shift and delay line |

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.

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

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



Fig. 27-18 Card Detection Method 2

- Method3: Using card detection unit in GRF, outputting `sdmmc_detect_dual_edge_int` connecting to IRQ[105]. Similar to Method2, except that the debounce time is configurable by `PMUGRF_SD_DET_COUNT`; and the insertion/removal detection interrupt can be enabled or cleared respectively. The detailed register information is:

Table 27-19 Register for SDMMC Card Detection Method 3

| Signal Name                                      | Source                                  | Default | Description                                                                               |
|--------------------------------------------------|-----------------------------------------|---------|-------------------------------------------------------------------------------------------|
| <code>sd_detectn_rise_edge_irq_en</code>         | <code>PMUGRF_SD_DETECT_CON[0]</code>    | 0       | <code>sdmmc detect_n</code> signal rise edge interrupt enable.<br>1: enable<br>0: disable |
| <code>sd_detect_fall_edge_detect_en</code>       | <code>PMUGRF_SD_DETECT_CON[1]</code>    | 0       | <code>sd_detect_falling_edge</code> enable<br>0: disable<br>1: enable                     |
| <code>sd_detect_rising_edge_detect_status</code> | <code>PMUGRF_SD_DETECT_STATUS[0]</code> | 0       | <code>sd_detect_rising_edge</code> status<br>0: disable<br>1: enable                      |
| <code>sd_detect_fall_edge_detect_status</code>   | <code>PMUGRF_SD_DETECT_STATUS[1]</code> | 0       | <code>sd_detect_falling_edge</code> status<br>0: disable<br>1: enable                     |
| <code>sd_detect_rising_edge_detect_clr</code>    | <code>PMUGRF_SD_DETECT_CLR[0]</code>    | 0       | <code>sd_detect_rising_edge</code> clear<br>0: disable<br>1: enable                       |
| <code>sd_detect_fall_edge_detect_clr</code>      | <code>PMUGRF_SD_DETECT_CLR[1]</code>    | 0       | <code>sd_detect_falling_edge</code> clear<br>0: disable<br>1: enable                      |

- Method4: Using filtered `card_detect_n` with the debounce time `PMUGRF_SD_DET_COUNT` for interrupt source, connecting to IRQ [106] directly.



Fig. 27-19 Card Detection Method 4

### **27.6.12 SDMMC IOMUX With JTAG**

The IO for sdmmc\_cdata2/sdmmc\_cdata3 is shared with jtag\_tck/jtag\_tms. The condition of usage for SD/MMC or JTAG usage is as follows.

- If GRF\_IOFUNC\_SEL[3](grf\_force\_jtag) is equal to 1 and SD/MMC card is not detected within detection time(in the unit of XIN24M clock), the GPIOs are used for JTAG.
- Otherwise, the GPIOs' usage is defined by IOMUX configuration.

## **Chapter 28 USB2.0 OTG Controller**

### **28.1 Overview**

USB2.0 OTG Controller can act as static host, static device, USB2.0 A device or B device basing on the status of input ID from USB2.0 PHY. It can perform data transmission between host and device as host or device for High-Speed / Full-Speed / Low-Speed.

USB2.0 OTG controller supports the following features:

- General Features
  - 1. Compatible Specification
    - ◆ Universal Serial Bus Specification, Revision 2.0
    - ◆ eXtensible Host Controller Interface for Universal Serial Bus (xHCI), Revision 1.1
  - 2. Support Control/Bulk/Interrupt/Isochronous Transfer
  - 3. Descriptor caching and data pre-fetching used to improve system performance in high-latency systems
  - 4. Dynamic FIFO memory allocation for endpoints
  - 5. Keep-Alive feature in LS mode and (micro-)SOFs in HS/FS modes
  - 6. Low MIPS requirement
    - ◆ Driver involved only in setting up transfers and high-level error recovery
    - ◆ Hardware handles data packing and routing to a specific pipe
- Application Interface Features
  - 1. AHB Slave interface
  - 2. AXI Master interface
    - ◆ Programmable burst lengths up to 16
    - ◆ Handle fixed burst address alignment
    - ◆ Programmable number of outstanding read/write requests up to 16
- USB2.0 Device Features
  - 1. Up to 7 IN endpoints, including control endpoint 0
  - 2. Up to 6 OUT endpoints, including control endpoint 0
  - 3. Up to 13 endpoint transfer resources, each one for each endpoint
  - 4. Flexible endpoint configuration for multiple applications/USB set-configuration modes
  - 5. Isochronous endpoints with isochronous data in data buffers
  - 6. Flexible Descriptor with rich set of features to support buffer interrupt moderation, multiple transfers, isochronous, control, and scattered buffering support
- USB Class-Specific Device Features
  - 1. Gathering of scattered packet to support Ethernet Over USB
  - 2. Scheduling of multiple Ethernet packets without interrupt
  - 3. Variable FIFO buffer allocation for each endpoint
  - 4. For isochronous applications, scheduling of variable-length payloads for each microframe
  - 5. Microframe precise scheduling for isochronous applications
  - 6. Configurable endpoint type selection and dynamic FIFO allocation to facilitate multi-function/composite device implementation. During set-config or alternate-setting, device resources are reconfigured to meet the configuration or alternate setting requirements
- USB 2.0 Host Features
  - 1. Support up to 64 devices
  - 2. Support 1 interrupter
  - 3. Support 1 USB2.0 port
- USB 2.0 Dual-Role Device (DRD) Features
  - 1. Static Device Operation
  - 2. Static Host Operation
  - 3. USB2.0 OTG A device and B device basing on ID
  - 4. Not support USB2.0 OTG session request protocol(SRP), host negotiation protocol(HNP) and Role Swap Protocol(RSP)

## 28.2 Block Diagram

USB2.0 OTG Controller comprises with:

- Bus Interface/List Management: Register Interface/Data and Descriptors DMA management
  - HS/FS/LS MAC : USB2.0 part logic
- USB2.0 PHY: UTMI+ interface USB2.0 PHY



Fig. 28-1 USB2.0 OTG Block Diagram

## 28.3 Function Description

As a USB2.0 OTG controller, it can act as static host controller, static device controller, 2.0 OTG A device or B device basing on ID of USB2.0 PHY.

As device controller, it can work on USB2.0 speed and process USB transactions described in the descriptors (read back from external memory by AXI master) to/from UTMI+ interface PHY.

As host controller, it can work on USB2.0 speed and process USB transactions described in the descriptors (read back from external memory by AXI master) to/from UTMI+ interface.

## 28.4 Register Description

### 28.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

Table 28-1 USB2 Address Mapping

| Offset Address Range | Register Type                        |
|----------------------|--------------------------------------|
| 0x00000 ~ 0x07FFF    | xHCI Registers, see xHCI spec.       |
| 0x0C100 ~ 0x0C6FF    | Global Registers                     |
| 0x0C700 ~ 0x0CBFF    | Device Controller Registers          |
| 0x0CC00 ~ 0x0CFFF    | Unused/Reserved                      |
| 0x40000 ~ 0x7FFFF    | Internal RAM0 – Debug Access (256KB) |

## 28.4.2 Registers Summary

| Name                          | Offset | Size | Reset Value | Description                                                   |
|-------------------------------|--------|------|-------------|---------------------------------------------------------------|
| <u>usb2otg_GSBUSCFG0</u>      | 0xC100 | W    | 0x00000001  | Global SoC Bus Configuration Register 0                       |
| <u>usb2otg_GSBUSCFG1</u>      | 0xC104 | W    | 0x00000300  | Global SoC Bus Configuration Register 1                       |
| <u>usb2otg_GRXTHRCFG</u>      | 0xC10C | W    | 0x00000000  | Global Rx Threshold Control Register                          |
| <u>usb2otg_GCTL</u>           | 0xC110 | W    | 0x30C12004  | Global Core Control Register                                  |
| <u>usb2otg_GSTS</u>           | 0xC118 | W    | 0x7E800000  | Global Status Register                                        |
| <u>usb2otg_GUCTL1</u>         | 0xC11C | W    | 0x0404018A  | Global User Control Register 1                                |
| <u>usb2otg_GSNPSID</u>        | 0xC120 | W    | 0x5533300A  | Global SNPS ID Register                                       |
| <u>usb2otg_GGPIO</u>          | 0xC124 | W    | 0x00000000  | Global General Purpose Input/Output Register                  |
| <u>usb2otg_GUID</u>           | 0xC128 | W    | 0x20190520  | Global User ID Register                                       |
| <u>usb2otg_GUCTL</u>          | 0xC12C | W    | 0x02000010  | Global User Control Register                                  |
| <u>usb2otg_GBUSERRADDRLO</u>  | 0xC130 | W    | 0x00000000  | Global SoC Bus Error Address Register - Low                   |
| <u>usb2otg_GBUSERRADDRHI</u>  | 0xC134 | W    | 0x00000000  | Global SoC Bus Error Address Register - High                  |
| <u>usb2otg_GHWPARAMS0</u>     | 0xC140 | W    | 0x2020400A  | Global Hardware Parameters Register 0                         |
| <u>usb2otg_GHWPARAMS1</u>     | 0xC144 | W    | 0x0120C93B  | Global Hardware Parameters Register 1                         |
| <u>usb2otg_GHWPARAMS2</u>     | 0xC148 | W    | 0x20190520  | Global Hardware Parameters Register 2                         |
| <u>usb2otg_GHWPARAMS3</u>     | 0xC14C | W    | 0x069CD084  | Global Hardware Parameters Register 3                         |
| <u>usb2otg_GHWPARAMS4</u>     | 0xC150 | W    | 0x47822010  | Global Hardware Parameters Register 4                         |
| <u>usb2otg_GHWPARAMS5</u>     | 0xC154 | W    | 0x04204108  | Global Hardware Parameters Register 5                         |
| <u>usb2otg_GHWPARAMS6</u>     | 0xC158 | W    | 0x09D78020  | Global Hardware Parameters Register 6                         |
| <u>usb2otg_GHWPARAMS7</u>     | 0xC15C | W    | 0x00000000  | Global Hardware Parameters Register 7                         |
| <u>usb2otg_GDBGFIFOSPACE</u>  | 0xC160 | W    | 0x000A0000  | Global Debug Queue/FIFO Space Available Register              |
| <u>usb2otg_GDBGLNMCC</u>      | 0xC168 | W    | 0x00000000  | Global Debug LNMCC Register                                   |
| <u>usb2otg_GDBGBMU</u>        | 0xC16C | W    | 0x20300000  | Global Debug BMU Register                                     |
| <u>usb2otg_GDBGLSPMUX</u>     | 0xC170 | W    | 0x003F0000  | Global Debug LSP MUX Register - Device                        |
| <u>usb2otg_GDBGLSP</u>        | 0xC174 | W    | 0x00000000  | Global Debug LSP Register                                     |
| <u>usb2otg_GDBGEPIINFO0</u>   | 0xC178 | W    | 0x000000801 | Global Debug Endpoint Information Register 0                  |
| <u>usb2otg_GDBGEPIINFO1</u>   | 0xC17C | W    | 0x00800000  | Global Debug Endpoint Information Register 1                  |
| <u>usb2otg_GPRTBIMAP_HSL0</u> | 0xC180 | W    | 0x00000000  | Global High-Speed Port to Bus Instance Mapping Register - Low |
| <u>usb2otg_GPRTBIMAP_FSL0</u> | 0xC188 | W    | 0x00000000  | Global Full-Speed Port to Bus Instance Mapping Register - Low |
| <u>usb2otg_GUSB2PHYCFG0</u>   | 0xC200 | W    | 0x00101408  | Global USB2 PHY Configuration Register 0                      |

| Name                   | Offset | Size | Reset Value | Description                                                                            |
|------------------------|--------|------|-------------|----------------------------------------------------------------------------------------|
| usb2otg_GTXFIFOSIZn    | 0xC300 | W    | 0x04B9000A  | Global Transmit FIFO Size Register n, offset (0xc300 + 4*n), n=0~6                     |
| usb2otg_GRXFIFOSIZn    | 0xC380 | W    | 0x03340185  | Global Receive FIFO Size Register n,                                                   |
| usb2otg_GEVNTADRLO0    | 0xC400 | W    | 0xFF7001B0  | Global Event Buffer Address (Low) Register 0                                           |
| usb2otg_GEVNTADRHI0    | 0xC404 | W    | 0x00000000  | Global Event Buffer Address (High) Register 0                                          |
| usb2otg_GEVNTSIZ0      | 0xC408 | W    | 0x80000100  | Global Event Buffer Size Register 0                                                    |
| usb2otg_GEVNTCOUNT0    | 0xC40C | W    | 0x00000004  | Global Event Buffer Count Register 0                                                   |
| usb2otg_GHWPARAMS8     | 0xC600 | W    | 0x0000047C  | Global Hardware Parameters Register 8                                                  |
| usb2otg_GTXFIFOPRIDEV  | 0xC610 | W    | 0x00000000  | Global Device TX FIFO DMA Priority Register                                            |
| usb2otg_GTXFIFOPRIHOST | 0xC618 | W    | 0x00000000  | Global Host TX FIFO DMA Priority Register                                              |
| usb2otg_GRXFIFOPRIHOST | 0xC61C | W    | 0x00000000  | Global Host RX FIFO DMA Priority Register                                              |
| usb2otg_GFIFOPRIDBC    | 0xC620 | W    | 0x00000000  | Global Host Debug Capability DMA Priority Register                                     |
| usb2otg_GDMAHLRATIO    | 0xC624 | W    | 0x00000000  | Global Host FIFO DMA High-Low Priority Ratio Register                                  |
| usb2otg_GFLADJ         | 0xC630 | W    | 0x00000000  | Global Frame Length Adjustment Register                                                |
| usb2otg_DCFG           | 0xC700 | W    | 0x04080928  | Device Configuration Register                                                          |
| usb2otg_DCTL           | 0xC704 | W    | 0x80000A00  | Device Control Register                                                                |
| usb2otg_DEVTEN         | 0xC708 | W    | 0x0000121F  | Device Event Enable Register                                                           |
| usb2otg_DSTS           | 0xC70C | W    | 0x00038118  | Device Status Register                                                                 |
| usb2otg_DGCMDPAR       | 0xC710 | W    | 0x00000000  | Device Generic Command Parameter Register                                              |
| usb2otg_DGCMRD         | 0xC714 | W    | 0x00000000  | Device Generic Command Register                                                        |
| usb2otg_DALEPENA       | 0xC720 | W    | 0x00000003  | Device Active USB Endpoint Enable Register                                             |
| usb2otg_DEPnCMDPAR2    | 0xC800 | W    | 0x00000000  | Device Physical Endpoint-n Command Parameter 2 Register, offset (0xc800 + 4*n), n=0~12 |
| usb2otg_DEPnCMDPAR1    | 0xC804 | W    | 0xFF7002E0  | Device Physical Endpoint-n Command Parameter 1 Register, offset (0xc804 + 4*n), n=0~12 |
| usb2otg_DEPnCMDPAR0    | 0xC808 | W    | 0x00000006  | Device Physical Endpoint-n Command Parameter 0 Register, offset (0xc808 + 4*n), n=0~12 |
| usb2otg_DEPnCMD        | 0xC80C | W    | 0x00000000  | Device Physical Endpoint-n Command Register, offset (0xc80c + 4*n), n=0~12             |

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

### 28.4.3 Detail Registers Description

#### usb2otg\_GSBUSCFG0

Address: Operational Base + offset (0xC100)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RW          | 0x0                | datrdreqinfo<br>AXI-cache for Data Read (DatRdReqInfo).                                                                                                                                                                                               |
| 27:24      | RW          | 0x0                | desrdreqinfo<br>AXI-cache for Descriptor Read (DesRdReqInfo).                                                                                                                                                                                         |
| 23:20      | RW          | 0x0                | datwrreqinfo<br>AXI-cache for Data Write (DatWrReqInfo).                                                                                                                                                                                              |
| 19:16      | RW          | 0x0                | deswrreqinfo<br>AXI-cache for Descriptor Write (DesWrReqInfo).                                                                                                                                                                                        |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                              |
| 11         | RW          | 0x0                | datbigend<br>This bit controls the endian mode for data accesses.<br>1'b0: Little-endian (default)<br>1'b1: Big-endian                                                                                                                                |
| 10         | RW          | 0x0                | desbigend<br>This bit controls the endian mode for descriptor accesses.<br>1'b0: Little-endian (default)<br>1'b1: Big-endian                                                                                                                          |
| 9:8        | RO          | 0x0                | reserved                                                                                                                                                                                                                                              |
| 7          | RW          | 0x0                | incr256brstena<br>If software set this bit to 1, the AXI master uses INCR to do the 256-beat burst.                                                                                                                                                   |
| 6          | RW          | 0x0                | incr128brstena<br>If software set this bit to 1, the AXI master uses INCR to do the 128-beat burst.                                                                                                                                                   |
| 5          | RW          | 0x0                | incr64brstena<br>If software set this bit to 1, AXI master uses INCR to do the 64-beat burst.                                                                                                                                                         |
| 4          | RW          | 0x0                | incr32brstena<br>If software set this bit to 1, the AXI master uses INCR to do the 32-beat burst.                                                                                                                                                     |
| 3          | RW          | 0x0                | incr16brstena<br>If software set this bit to 1, the AXI master uses INCR to do the 16-beat burst.                                                                                                                                                     |
| 2          | RW          | 0x0                | incr8brstena<br>If software set this bit to 1, the AXI master uses INCR to do the 8-beat burst.                                                                                                                                                       |
| 1          | RW          | 0x0                | incr4brstena<br>When this bit is enabled the controller is allowed to do bursts of beat length 1, 2, 3, and 4. It is highly recommended that this bit is enabled to prevent descriptor reads and writes from being broken up into separate transfers. |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x1                | <p>incrbrstena<br/>This bit determines the set of burst lengths the master interface uses. It works in conjunction with the GSBUSCFG0[7:1] enables(INCR256/128/64/32/16/8/4).<br/>0: INCRX burst mode<br/>ARLEN/AWLEN do not use INCR. They use only the following burst lengths:<br/>1;<br/>4 (if GSBUSCFG0.INCR4BrstEna = 1);<br/>8 (if GSBUSCFG0.INCR8BrstEna = 1);<br/>16 (if GSBUSCFG0.INCR16BrstEna = 1);<br/>32 (if GSBUSCFG0.INCR32BrstEna = 1);<br/>64 (if GSBUSCFG0.INCR64BrstEna = 1);<br/>128 (if GSBUSCFG0.INCR128BrstEna = 1);<br/>256 (if GSBUSCFG0.INCR256BrstEna = 1);<br/>1: INCR (undefined length) burst mode;<br/>ARLEN/AWLEN uses any length less than or equal to the largest-enabled burst length of INCR4/8/16/32/64/128/256.<br/>For cache line-aligned applications, this bit is typically set to 0 to ensure that the master interface uses only power-of-2 burst lengths (as enabled via GSBUSCFG0[7:0]).</p> |

**usb2otg\_GSBUSCFG1**

Address: Operational Base + offset (0xC104)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 12         | RW          | 0x0                | <p>en1kpage<br/>1K Page Boundary Enable.<br/>By default (this bit is disabled) the AXI breaks transfers at the 4k page boundary. When this bit is enabled, the AXI master (DMA data) breaks transfers at the 1k page boundary.</p>                                                                                                                                                                                                                                                             |
| 11:8       | RW          | 0x3                | <p>pipe_trans_limit<br/>AXI Pipelined Transfers Burst Request Limit.<br/>The field controls the number of outstanding pipelined transfer requests the AXI master pushes to the AXI slave. When the AXI master reaches this limit, it does not make any more requests on the AXI ARADDR and AWADDR buses until the associated data phases complete.<br/>This field is encoded as follows:<br/>0: 1 request<br/>1: 2 requests<br/>2: 3 requests<br/>3: 4 requests<br/>...<br/>F: 16 requests</p> |
| 7:0        | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**usb2otg\_GRXTHRCFG**

Address: Operational Base + offset (0xC10C)

| <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         | RW          | 0x0                | <p>usb_rx_pkt_cntsel<br/>USB ReceivePacket Count Enable.<br/>This field enables/disables the USB reception multi-packet thresholding:<br/>1'b0: The core can only start reception on the USB when the RX FIFO has space for at least one packet.<br/>1'b1: Not applied.<br/>If you are using external buffer control (EBC) feature, disable this mode by setting USBRxPktCntSel to 0.</p>                                                                                                                                                                                                                                                                 |
| 28:13      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 12:0       | RW          | 0x0000             | <p>resvl_socout_spc<br/>Space reserved in rx fifo for ISOC OUT.<br/>In host mode, this field is not applicable and must be programmed to 0.<br/>In device mode, this value represents the amount of space to be reserved for ISOC OUT packets.<br/>The value to be programmed should be chosen so as to ensure that non ISOC packets are not completely dropped,<br/>If no space needs to be reserved for ISOC OUT packets, program this field to 0.<br/>This field is valid only in device mode. The maximum configurable depth of rx fifo is 8192. Therefore, this field is 13 bits wide.<br/>For HS/FS, the space reservation is the actual value.</p> |

**usb2otg GCTL**

Address: Operational Base + offset (0xC110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:19      | RW          | 0x0618             | pwrdnscale<br>Not applied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 18         | RW          | 0x0                | <p>masterfiltbypass<br/>Master Filter Bypass<br/>When this bit is set to 1'b1, all the filters are bypassed. The double synchronizers to mac_clk preceding the filters are also bypassed. For enabling the filters, this bit must be 1'b0.</p>                                                                                                                                                                                                                                                      |
| 17         | RW          | 0x0                | <p>bypassetaddr<br/>Bypass SetAddress in Device Mode.<br/>When BYPSSETADDR bit is set, the device core uses the value in the DCFG[DevAddr] bits directly for comparing the device address in the tokens.<br/>For simulation, you can use this feature to avoid sending an actual SET ADDRESS control transfer on the USB, and make the device core respond to a new address.<br/>Note: You can set this bit for simulation purposes only. In the actual hardware, this bit must be set to 1'b0.</p> |
| 16         | RW          | 0x1                | <p>u2rstecn<br/>Device controller on USB 2.0 reset checks for receiver termination eight times per attempt if this bit is set to zero, or only once per attempt if the bit is set to one.<br/>Note: This bit is applicable only in device mode.</p>                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:14      | RW          | 0x0                | <p>frmscldw</p> <p>This field scales down device view of a SOF/USOF duration.</p> <p>For HS mode:</p> <ul style="list-style-type: none"> <li>Value of 2'h3 implements interval to be 15.625 us</li> <li>Value of 2'h2 implements interval to be 31.25 us</li> <li>Value of 2'h1 implements interval to be 62.5 us</li> <li>Value of 2'h0 implements interval to be 125us</li> </ul> <p>For FS mode, the scale-down value is multiplied by 8.</p> <p>This field also scales down the MaxPacketSize of the IN and OUT bulk endpoint to allow more traffic during simulation. It can only be changed from a non-zero value during simulation.</p> <p>2'h0: 1024 bytes<br/>     2'h1: 512 bytes<br/>     2'h2: 256 bytes<br/>     2'h3: 128 bytes</p> |
| 13:12      | RW          | 0x2                | <p>prtcapdir</p> <p>PRTCAPDIR: Port Capability Direction (PrtCapDir)</p> <p>2'b01: for Host configurations<br/>     2'b10: for Device configurations</p> <p>SW should base on IDDIG input to set usb controller as an OTG 2.0 device with A-device or B-device.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11         | RW          | 0x0                | <p>coresoftreset</p> <p>Core Soft Reset (CoreSoftReset)</p> <p>1'b0: No soft reset;<br/>     1'b1: Soft reset to core</p> <p>Clears the interrupts and all the CSRs except the following registers:<br/>     GCTL; GUCTL; GSTS; GSNPSSID; GPIO; GUID; GUSB2PHYCFGn registers; GUSB3PIPECTLn registers; DCFG; DCTL; DEVREN; DSTS.</p>                                                                                                                                                                                                                                                                                                                                                                                                              |
| 10         | RW          | 0x0                | sofitpsync<br><p>Not applied.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 9          | RW          | 0x0                | u1u2_timescale<br><p>Not applied.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 8          | RW          | 0x0                | debugattach<br><p>Debug Attach.</p> <p>Not applied.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7:6        | RW          | 0x0                | <p>ramclksel</p> <p>RAM Clock Select (RAMClkSel)</p> <p>2'b00: bus clock<br/>     2'b01: pipe clock (Only used in device mode)<br/>     2'b10: In device mode, pipe/2 clock. In Host mode, controller switches ram_clk between pipe/2 clock, mac2_clk and bus_clk based on the status of the U2 ports<br/>     2'b11: In device mode, selects mac2_clk as ram_clk (when 8-bit UTMI or ULPI used. Not supported in 16-bit UTMI mode); In Host mode, controller switches ram_clk between pipe_clk, mac2_clk and bus_clk based on the status of the U2 ports.</p> <p>In device mode, upon a USB reset and USB disconnect, the hardware clears these bits to 2'b00.</p>                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:4        | RW          | 0x0                | scaledown<br>Scale-Down Mode (ScaleDown)<br>When Scale-Down mode is enabled for simulation, the core uses scaled-down timing values, resulting in faster simulations.<br>When Scale-Down mode is disabled, actual timing values are used. This is required for hardware operation.<br>HS/FS/LS Modes:<br>2'b00: Disables all scale-downs. Actual timing values are used.<br>2'b01: Enables scale-down of all timing values except Device mode suspend and resume. These include Speed enumeration, HNP/SRP, and Host mode suspend and resume<br>2'b10: Enables scale-down of Device mode suspend and resume timing values only.<br>2'b11: Enables bit 0 and bit 1 scale-down timing values. |
| 3          | RW          | 0x0                | disscramble<br>Disable Scrambling (DisScramble)<br>Transmit request to Link Partner on next transition to Recovery or Polling.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2          | RW          | 0x1                | u2exit_lfps<br>If this bit is:<br>1'b0: the link treats 248ns LFPS as a valid U2 exit.<br>1'b1: the link waits for 8us of LFPS before it detects a valid U2 exit.<br>This bit is added to improve interoperability with a third party host controller. This host controller in U2 state while performing receiver detection generates an LFPS glitch of about 4ms duration. This causes the device to exit from U2 state because the LFPS filter value is 248ns. With the new functionality enabled, the device can stay in U2 while ignoring this glitch from the host controller.                                                                                                         |
| 1          | RO          | 0x0                | gbl_hibernation_en<br>This bit enables hibernation at the global level. If hibernation is not enabled through this bit, the PMU immediately accepts the D0->D3 and D3->D0 power state change requests, but does not save or restore any core state. In addition, the PMUs never drive the PHY interfaces and let the core continue to drive the PHY interfaces.                                                                                                                                                                                                                                                                                                                             |
| 0          | RW          | 0x0                | dsblclkgtng<br>Disable Clock Gating.<br>This bit is set to 1 and the core is in Low Power mode, internal clock gating is disabled. You can set this bit to 1'b1 after Power On Reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**usb2otg GSTS**

Address: Operational Base + offset (0xC118)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x7e8              | cbelt<br>Current BELT Value.<br>In Host mode, this field indicates the minimum value of all received device BELT values and the BELT value that is set by the Set Latency Tolerance Value command. |
| 19:12      | RO          | 0x00               | reserved                                                                                                                                                                                           |
| 11         | RO          | 0x0                | SSIC_IP<br>Not applied.                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RO          | 0x0                | OTG_IP<br>OTG Interrupt Pending.<br>This field indicates that there is a pending interrupt pertaining to OTG in OEVT register.                                                                                       |
| 9          | RO          | 0x0                | bc_ip<br>Battery Charger Interrupt Pending<br>This field indicates that there is a pending interrupt pertaining to BC in BCEVT register.                                                                             |
| 8          | RO          | 0x0                | adp_ip<br>ADP Interrupt Pending.<br>This field indicates that there is a pending interrupt pertaining to ADP in ADPEVT register.                                                                                     |
| 7          | RO          | 0x0                | host_ip<br>Host Interrupt Pending.<br>This field indicates that there is a pending interrupt pertaining to xHC in the Host event queue.                                                                              |
| 6          | RO          | 0x0                | device_ip<br>Device Interrupt Pending<br>This field indicates that there is a pending interrupt pertaining to peripheral (device) operation in the Device event queue.                                               |
| 5          | W1C         | 0x0                | csr_timeout<br>When this bit is 1'b1, it indicates that the software performed a write or read to a core register that could not be completed within DWC_USB3_CSR_ACCESS_TIMEOUT bus clock cycles (default: h1FFFF). |
| 4          | W1C         | 0x0                | buserraddrvld<br>us Error Address Valid<br>Indicates that the GBUSERADDR register is valid and reports the first bus address that encounters a bus error.                                                            |
| 3:2        | RO          | 0x0                | reserved                                                                                                                                                                                                             |
| 1:0        | RO          | 0x0                | curmod<br>Current Mode of Operation.                                                                                                                                                                                 |

**usb2otg\_GUCTL1**

Address: Operational Base + offset (0xC11C)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29  | RW   | 0x0         | <p>filter_se0_fs_ls_eop<br/>           1'b0: Default behaviour, no change in Linestate check for SE0 detection in FS/LS.<br/>           1'b1: Feature enabled, FS/LS SE0 is filtered for 2 clocks for detecting EOP.</p> <p>This bit is applicable for FS/LS operation. If this feature is enabled, then SE0 on the linestate is validated for 2 consecutive utmi/ulpi clock edges for EOP detection. This feature is applicable only in FS in device mode and FS/LS mode of operation in host mode.</p> <p>Device mode: FS - If GUCTL1.FILTER_SE0_FSLS_EOP is set, then for device LPM handshake, the core will ignore single SE0 glitch on the linestate during transmit. Only 2 or more SE0 is considered as a valid EOP on FS.</p> <p>Host mode: FS/LS - If GUCTL1.FILTER_SE0_FSLS_EOP is set, then the core will ignore single SE0 glitch on the linestate during transmit. Only 2 or more SE0 is considered as a valid EOP on FS/LS port. Enable this feature if the LineState has SE0 glitches during transmission. This bit is quasi-static, i.e., should not be changed during device operation.</p>                                                                                                                                                             |
| 28  | RW   | 0x0         | <p>tx_ipgap_linecheck_dis<br/>           1'b0: Default behaviour, no change in Linestate check.<br/>           1'b1: Feature enabled, 2.0 MAC disables Linestate check during HS transmit.</p> <p>This bit is applicable for HS operation of u2mac. If this feature is enabled, then the 2.0 mac operating in HS ignores the UTMI/ULPI Linestate during the transmit of a token (during token-to-token and token-to-data IPGAP). When enabled, the controller implements a fixed 40-bit TxEndDelay after the packet is given on UTMI and ignores the Linestate during this time. This feature is applicable only in HS mode of operation.</p> <p>Device mode: If GUCTL1.TX_IPGAP_LINECHECK_DIS is set, then for device LPM handshake, the core will ignore the linestate after TX and wait for a fixed clocks (40 bit times equivalent) after transmitting ACK on utmi.</p> <p>Host mode: If GUCTL1.TX_IPGAP_LINECHECK_DIS is set, then the ipgap between (tkn to tkn/data) is added by 40 bit times of TXENDDELAY, and linestate is ignored during this 40 bit times delay.</p> <p>Enable this bit if the LineState will not reflect the expected line state (J) during transmission. This bit is quasi-static, i.e., should not be changed during device operation.</p> |
| 27  | RW   | 0x0         | <p>dev_trb_out_spr_ind<br/>           1'b0: Default behaviour, no change in TRB status dword.<br/>           1'b1: Feature enabled, OUT TRB status indicates Short Packet.</p> <p>This bit is applicable for device mode only (and ignored in host mode). If the device application (SW/HW) wants to know if a short packet was received for an OUT in the TRB status itself, then this feature can be enabled, so that a bit is set in the TRB writeback in the buf_size dword. Bit[26] - SPR of the trbstatus, RSVD, SPR,PCM1, bufsize dword will be set during an OUT transfer TRB write back if this is the last TRB used for that transfer descriptor. This bit is quasi-static, i.e., should not be changed during device operation.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 26  | RW   | 0x1         | dve_force_20clk_for_30clk<br>Not applied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25         | RW          | 0x0                | p3_in_u2<br>Not applied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 24         | RW          | 0x0                | dev_l1_exit_by_hw<br>1'b0: Default behaviour, disables device L1 hardware exit logic.<br>1'b1: feature enabled<br>This bit is applicable for device mode (2.0) only. This field enables device controller sending remote wakeup for L1 if the device becomes ready for sending/accepting data when in L1 state. If the host expects the device to send remote wkp signalling to resume after going into L1 in flow controlled state, then this bit can be set to send the remote wake signal automatically when the device controller becomes ready. This HW remote wake feature is applicable only to bulk and interrupt transfers, and not for Isoch/Control<br>When control transfers are in progress, the LPM will be rejected (NYET response). Only after control transfers are completed (either with ACK/STALL), LPM will be accepted<br>For Isoch transfers, the host needs to do the wake-up and start the transfer. Device controller will not do remote-wakeup when Isoch endpoints get ready. The device SW needs to keep the GUSB2PHYCFG[EnblISlpM] reset in order to keep the PHY clock to be running for keeping track of SOF intervals.<br>When L1 hibernation is enabled, the controller will not do automatic exit for hibernation requests thru L1.<br>This bit is quasi-static, i.e., should not be changed during device operation. |
| 23:21      | RW          | 0x0                | ip_gap_add_on<br>This register field is used to add on to the default inter packet gap setting in the USB 2.0 MAC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 20         | RW          | 0x0                | dev_lsp_tail_lock_dis<br>1'b0: Default behaviour, enables device lsp lock logic for tail TRB update.<br>1'b1: Fix disabled<br>This is a bug fix for STAR 9000716195 that affects the CSP mode for OUT endpoints in device mode. The issue is that tail TRB index is not synchronized with the cache Scratchpad bytecount update. If the fast-forward request comes in-between the bytecount update on a newly fetched TRB and the tail-index write update in TPF, the RDP works on an incorrect tail index and misses the byte count decrement for the newly fetched TRB in the fast-forwarding process. This fix needs to be present all the times.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 19         | RW          | 0x0                | nak_per_enh_fs<br>1'b1: Enables performance enhancement for FS async endpoints in the presence of NAKs.<br>1'b0: Enhancement not applied.<br>If a periodic endpoint is present, and if a bulk endpoint which is also active is being NAKed by the device, then this could result in a decrease in performance of other Full Speed bulk endpoint which is ACKed by the device. Setting this bit to 1, will enable the host controller to schedule more transactions to the async endpoints (bulk/ control) and hence will improve the performance of the bulk endpoint. This control bit should be enabled only if the existing performance with the default setting is not sufficient for your FullSpeed application. Setting this bit will only control, and is only required for Full Speed transfers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | RW          | 0x1                | <p>nak_per_enh_hs<br/>1'b1: Enables performance enhancement for HS async endpoints in the presence of NAKs.<br/>1'b0: Enhancement not applied.</p> <p>If a periodic endpoint is present, and if a bulk endpoint which is also active is being NAKed by the device, then this could result in a decrease in performance of other High Speed bulk endpoint which is ACKed by the device. Setting this bit to 1, will enable the host controller to schedule more transactions to the async endpoints (bulk/ control) and hence will improve the performance of the bulk endpoint. This control bit should be enabled only if the existing performance with the default setting is not sufficient for your HighSpeed application. Setting this bit will only control, and is only required for High Speed transfers.</p>                                                                                                                                                                                                                                                                                    |
| 17         | RW          | 0x0                | <p>parkmode_disable_ss<br/>Not applied.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 16         | RW          | 0x0                | <p>parkmode_disable_hs<br/>This bit is used only in host mode.<br/>When this bit is set to 1 all HS bus instances park mode are disabled.</p> <p>To improve performance in park mode, the xHCI scheduler queues in three requests of 4 packets each for High Speed asynchronous endpoints in a micro-frame. But if a device is slow and if it NAKs more than 3 times, then it is rescheduled only in the next micro-frame. This could decrease the performance of a slow device even further.</p> <p>In a few high speed devices (such as Sandisk Cruzer Blade 4GB VID: 1921, PID: 21863 and Flex Drive VID: 3744, PID: 8552) when an IN request is sent within 900ns of the ACK of the previous packet, these devices send a NAK. When connected to these devices, if required, the software can disable the park mode if you see performance drop in your system. When park mode is disabled, pipelining of multiple packet is disabled and instead one packet at a time is requested by the scheduler. This allows up to 12 NAKs in a micro-frame and improves performance of these slow devices.</p> |
| 15         | RW          | 0x0                | <p>parkmod_disavale_fsls<br/>This bit is used only in host mode, and is for debug purpose only.<br/>When this bit is set to 1 all FS/LS bus instances in park mode disabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 14:9       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | RW   | 0x1         | <p>I1_susp_thrld_en_for_host<br/>This bit is used only in host mode.<br/>The host controller asserts the utmi_l1_suspend_n and utmi_sleep_n output signals (see LPM Interface Signals table in the Databook) as follows:<br/>The controller asserts the utmi_l1_suspend_n signal to put the PHY into deep low-power mode in L1 when both of the following are true:<br/>The HIRD/BESL value used is greater than or equal to the value in L1_SUSP_THRLD_FOR_HOST field.<br/>The L1_SUSP_THRLD_EN_FOR_HOST bit is set to 1'b1. The controller asserts utmi_sleep_n on L1 when one of the following is true:<br/>The HIRD/BESL value used is less than the value in L1_SUSP_THRLD_FOR_HOST field.<br/>The L1_SUSP_THRLD_EN_FOR_HOST bit is set to 1'b0.</p> |
| 7:4 | RW   | 0x8         | <p>I1_susp_thrld_for_host<br/>This field is effective only when the L1_SUSP_THRLD_EN_FOR_HOST bit is set to 1. For more details, refer to the description of the L1_SUSP_THRLD_EN_FOR_HOST bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3   | RW   | 0x1         | <p>hc_errata_enable<br/>Not applied.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2   | RW   | 0x0         | <p>hc_parchk_disable<br/>Host Parameter Check Disable.<br/>When this bit is set to 0 (by default), the xHC checks that the input slot/EP context fields comply to the xHCI Specification. Upon detection of a parameter error during command execution, the xHC generates an event TRB with completion code indicating PARAMETER ERROR.<br/>When the bit is set to 1, the xHC does not perform parameter checks and does not generate PARAMETER ERROR completion code.</p>                                                                                                                                                                                                                                                                                |
| 1   | RW   | 0x1         | <p>ovrlid_l1_susp_com<br/>If this bit is set, the utmi_l1_suspend_com_n is overloaded with the utmi_sleep_n signal. This bit is usually set if the PHY stops the port clock during L1 sleep condition.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0   | RW   | 0x0         | <p>loa_filter_en<br/>If this bit is set, the USB 2.0 port babble is checked at least three consecutive times before the port is disabled. This prevents false triggering of the babble condition when using low quality cables.<br/>Note: This bit is valid only in host mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**usb2otg\_GSNPSID**

Address: Operational Base + offset (0xC120)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                             |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RO   | 0x5533300a  | <p>snpsid<br/>SNPSID[31:16] indicates Core Identification Number. 0x5533 is ASCII for U3 (DWC_usb3).<br/>SNPSID[15:0] indicates the release number. Current Release is 3.00a.<br/>Software uses this register to configure release-specific features in the driver.</p> |

**usb2otg\_GGPIO**

Address: Operational Base + offset (0xC124)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | gpo<br>General Purpose Output<br>This field's value is driven out on the gp_out[15:0] core output port. |
| 15:0       | RO          | 0x0000             | gpi<br>General Purpose Input<br>This field's read value reflects the gp_in[15:0] core input value.      |

**usb2otg\_GUID**

Address: Operational Base + offset (0xC128)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                           |
|------------|-------------|--------------------|----------------------------------------------|
| 31:0       | RW          | 0x20190520         | userid<br>Application-programmable ID field. |

**usb2otg\_GUCTL**

Address: Operational Base + offset (0xC12C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RW          | 0x008              | refclkper<br>This field indicates in terms of nano seconds the period of ref_clk.<br>The default value of this register is set to 'h8 (8ns/125 MHz).<br>This field needs to be updated during power-on initialization, if GCTL.SOFITPSYNC or GFLADJ.GFLADJ_REFCLK_LPM_SEL is set to 1. The programmable maximum value is 62ns, and the minimum value is 8ns.<br>You must use a reference clock with a period that is an integer multiple, so that ITP can meet the jitter margin of 32ns. The allowable ref_clk frequencies whose period is not integer multiples are 16/17/19.2/24/39.7MHz.<br>This field must not be set to 0 at any time. If you never plan to use this feature, then set this field to 'h8, the default value. |
| 21         | RW          | 0x0                | no_extr_di<br>No Extra Delay Between SOF and the First.<br>Some HS devices misbehave when the host sends a packet immediately after a SOF. However, adding an extra delay between a SOF and the first packet can reduce the USB data rate and performance.<br>This bit is used to control whether the host must wait for 2 microseconds before it sends the first packet after a SOF, or not.<br>User can set this bit to one to improve the performance if those problematic devices are not a concern in the user's host environment.<br>1'b0: Host waits for 2 microseconds after a SOF before it sends the first USB packet.<br>1'b1: Host doesn't wait after a SOF before it sends the first USB packet.                      |
| 20:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 17         | RW          | 0x0                | sprs_ctrl_trans_en<br>Sparse Control Transaction Enable.<br>Some devices are slow in responding to Control transfers.<br>Scheduling multiple transactions in one microframe/frame can cause these devices to misbehave.<br>If this bit is set to 1'b1, the host controller schedules transactions for a Control transfer in different microframes/frames.                                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RW          | 0x0                | <p>res_bw_hs_esp<br/>Reserving 85% Bandwidth for HS Periodic EPs.<br/>By default, HC reserves 80% of the bandwidth for periodic EPs. If this bit is set, the bandwidth is relaxed to 85% to accommodate two high speed, high bandwidth ISOC EPs.</p> <p>USB 2.0 required 80% bandwidth allocated for ISOC traffic. If two High-bandwidth ISOC devices (HD Webcams) are connected, and if each requires 1024-bytes X 3 packets per Micro-Frame, then the bandwidth required is around 82%. If this bit is set, then it is possible to connect two Webcams of 1024bytes X 3 payload per Micro-Frame each. Otherwise, you may have to reduce the resolution of the Webcams.</p> <p>This bit is valid in Host and DRD configuration and is used in host mode operation only. Ignore this bit in device mode.</p> |
| 15         | RW          | 0x0                | <p>cm_dev_addr<br/>Compliance Mode for Device Address.<br/>When this bit is 1'b1, Slot ID may have different value than Device Address if max_slot_enabled &lt; 128.</p> <p>1'b1: Increment Device Address on each Address Device command.</p> <p>1'b0: Device Address is equal to Slot ID.<br/>The xHCI compliance requires this bit to be set to 1. The 0 mode is for debug purpose only. This allows you to easily identify a device connected to a port in the Lecroy or Eliisys trace during hardware debug.</p> <p>This bit is valid in Host and DRD configuration and is used in host mode operation only. Ignore this bit in device mode.</p>                                                                                                                                                        |
| 14         | RW          | 0x0                | <p>usb_host_in_auto_retry_en<br/>Host IN Auto Retry.</p> <p>1'b0: Auto Retry Disabled<br/>1'b1: Auto Retry Enabled</p> <p>Note: This bit is also applicable to the device mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 13         | RW          | 0x0                | en_overlap_chk<br>Not applied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12   | RW   | 0x0         | <p>ext_cap_suppt_en<br/>External Extended Capability Support Enable<br/>When set, this field enables extended capabilities to be implemented outside the core.<br/>When the ExtCapSupEN is set and the Debug Capability is enabled, the Next Capability pointer in Debug Capability returns 16.<br/>A read to the first DWORD of the last internal extended capability (the "xHCI Supported Protocol Capability for USB 3.0" when the Debug Capability is not enabled) returns a value of 4 in the Next Capability Pointer field.</p> <p>This indicates to software that there is another capability four DWORDs after this capability (for example, at address N+16 where N is the address of this DWORD). If enabled, an external address decoder that snoops the xHC slave interface must be implemented.<br/>If it sees an access to N+16 or greater, the slave access is re-routed to a piece of hardware which returns the external capability pointer register of the new capability and also handles reads/writes to this new capability and the side effects.<br/>If disabled, a read to the first DWORD of the last internal extended capability returns 0 in the 'Next Capability Pointer' field.<br/>This indicates there are no more capabilities.</p> |
| 11   | RW   | 0x0         | <p>insrt_extr_fsbodi<br/>Insert Extra Delay Between FS Bulk OUT.<br/>Some FS devices are slow to receive Bulk OUT data and can get stuck when there are consecutive Bulk OUT transactions with short inter-transaction delays. This bit is used to control whether the host inserts extra delay between consecutive Bulk OUT transactions to a FS Endpoint.</p> <p>1'b0: Host doesn't insert extra delay between consecutive Bulk OUT transactions to a FS Endpoint.<br/>1'b1: Host inserts about 12us extra delay between consecutive Bulk OUT transactions to a FS Endpoint to work around the device issue.<br/>Note: Setting this bit to one will reduce the Bulk OUT transfer performance for most of the FS devices.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10:9 | RW   | 0x0         | <p>dtct<br/>Device Timeout Coarse Tuning.<br/>This field is a Host mode parameter which determines how long the host waits for a response from device before considering a timeout.</p> <p>The core first checks the DTCT value. If it is 0, then the timeout value is defined by the DTFT. If it is non-zero, then it uses the following timeout values:</p> <p>2'b00: 0 usec -&gt; use DTFT value instead<br/>2'b01: 500 usec<br/>2'b10: 1.5 msec<br/>2'b11: 6.5 msec</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0        | RW          | 0x010              | <p>ctft<br/>Device Timeout Fine Tuning.<br/>This field is a Host mode parameter which determines how long the host waits for a response from device before considering a timeout.<br/>For the DTFT field to take effect, DTCT must be set to 2'b00. The DTFT value is the number of 125 MHz clocks * 256 to count before considering a device timeout.<br/>The minimum value of DTFT is 2.<br/>For example, if the mac3_clk is 125 MHz clk (8 ns period), this is calculated as follows:<br/>(DTFT value) * 256 * (8 ns)<br/>Quick Reference:<br/>if DTFT = 0x2, 2*256*8 = 4usec timeout<br/>if DTFT = 0x5, 5*256*8 = 10usec timeout<br/>if DTFT = 0xA, 10*256*8 = 20usec timeout<br/>if DTFT = 0x10, 16*256*8 = 32usec timeout<br/>if DTFT = 0x19, 25*256*8 = 51usec timeout<br/>if DTFT = 0x31, 49*256*8 = 100usec timeout<br/>if DTFT = 0x62, 98*256*8 = 200usec timeout</p> |

**usb2otg GBUSERRADDRLO**

Address: Operational Base + offset (0xC130)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>buserraddr<br/>Bus Address - Low.<br/>This register contains the lower 32 bits of the first bus address that encountered a SoC bus error. It is valid when the GSTS.BusErrAddrVld field is 1. It can only be cleared by resetting the core.<br/>Note: Only supported in AHB and AXI configurations.</p> |

**usb2otg GBUSERRADDRHI**

Address: Operational Base + offset (0xC134)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RU          | 0x00000000         | <p>buserraddr<br/>Bus Address - High.<br/>This register contains the higher 32 bits of the first bus address that encountered a SoC bus error. It is valid when the GSTS.BusErrAddrVld field is 1. It can only be cleared by resetting the core.<br/>Note: Only supported in AHB and AXI configurations.</p> |

**usb2otg GHWPARAMS0**

Address: Operational Base + offset (0xC140)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RO          | 0x2020400a         | ghwparams0<br>Global Hardware Parameters Register 0. |

**usb2otg GHWPARAMS1**

Address: Operational Base + offset (0xC144)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RO          | 0x0120c93b         | ghwparams1<br>Global Hardware Parameters Register 1. |

**usb2otg\_GHWPARAMS2**

Address: Operational Base + offset (0xC148)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RO          | 0x20190520         | ghwparams2<br>Global Hardware Parameters Register 2. |

**usb2otg\_GHWPARAMS3**

Address: Operational Base + offset (0xC14C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RO          | 0x069cd084         | ghwparams3<br>Global Hardware Parameters Register 3. |

**usb2otg\_GHWPARAMS4**

Address: Operational Base + offset (0xC150)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RO          | 0x47822010         | ghwparams4<br>Global Hardware Parameters Register 4. |

**usb2otg\_GHWPARAMS5**

Address: Operational Base + offset (0xC154)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RO          | 0x04204108         | ghwparams5<br>Global Hardware Parameters Register 5. |

**usb2otg\_GHWPARAMS6**

Address: Operational Base + offset (0xC158)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RO          | 0x09d78020         | ghwparams6<br>Global Hardware Parameters Register 6. |

**usb2otg\_GHWPARAMS7**

Address: Operational Base + offset (0xC15C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                   |
|------------|-------------|--------------------|------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | ghwparams7<br>Global Hardware Parameters Register 7. |

**usb2otg\_GDBGFIFOSPACE**

Address: Operational Base + offset (0xC160)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x000a             | space_available<br>Space Available.                                                                                                                                                                                                                         |
| 15:9       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                    |
| 8:0        | RW          | 0x000              | fifo_queue_select<br>FIFO/Queue Select (or) Port-Select.<br>FIFO/Queue Select[8:5] indicates the FIFO/Queue Type.<br>FIFO/Queue Select[4:0] indicates the FIFO/Queue Number.<br>Port-Select[3:0] selects the port-number when accessing GDBGLTSSM register. |

**usb2otg\_GDBGLNMCC**

Address: Operational Base + offset (0xC168)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0        | RO          | 0x000              | Inmcc_berc<br>This field indicates the bit error rate information for the port selected in the GDBGIFOSPACE.PortSelect field. This field is for debug purposes only. |

**usb2otg\_GDBGBMU**

Address: Operational Base + offset (0xC16C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                    |
|------------|-------------|--------------------|---------------------------------------|
| 31:8       | RW          | 0x203000           | bmu_bcu<br>BMU_BCU Debug information. |
| 7:4        | RO          | 0x0                | bmu_dcu<br>BMU_DCU Debug information. |
| 3:0        | RO          | 0x0                | bmu_ccu<br>BMU_CCU Debug information. |

**usb2otg\_GDBGLSPMUX**

Address: Operational Base + offset (0xC170)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                        |
| 23:16      | RW          | 0x3f               | logic_analyzer_trace<br>Logic Analyzer Trace Port MUX Select.<br>Currently only bits[21:16] are used. A value of 6'h3F drives "0"s on the logic_analyzer_trace signal. If you plan to OR (instead using a mux) this signal with other trace signals in your system to generate a common trace signal, you can use this feature. |
| 15         | RW          | 0x0                | endbc<br>Enable debugging of Debug capability LSP in Host mode. Use HostSelect to select DbC LSP debug information presented in the GDBGLSP register.                                                                                                                                                                           |
| 14         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                        |
| 13:8       | RW          | 0x00               | hostselect<br>Host LSP Select.<br>Selects the LSP debug information presented in the GDBGLSP register in host mode.                                                                                                                                                                                                             |
| 7:4        | RW          | 0x0                | devselect<br>Device LSP Select.<br>Selects the LSP debug information presented in the GDBGLSP register in device mode. Or bit[7:4] of HOSTSELECT, Selects the LSP debug information presented in the GDBGLSP register in host mode.                                                                                             |
| 3:0        | RW          | 0x0                | epeselect<br>Device Endpoint Select.<br>Selects the Endpoint debug information presented in the GDBGEPINFO registers in device mode. Or bit[3:0] of HOSTSELECT, Selects the LSP debug information presented in the GDBGLSP register in host mode.                                                                               |

**usb2otg\_GDBGLSP**

Address: Operational Base + offset (0xC174)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                 |
|------------|-------------|--------------------|------------------------------------|
| 31:0       | RO          | 0x00000000         | lspdebug<br>LSP Debug Information. |

**usb2otg\_GDBGEPINFO0**

Address: Operational Base + offset (0xC178)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                |
|------------|-------------|--------------------|---------------------------------------------------|
| 31:0       | RO          | 0x00000801         | epdebug<br>Endpoint Debug Information Low 32-bit. |

**usb2otg\_GDBGEPINFO1**

Address: Operational Base + offset (0xC17C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                 |
|------------|-------------|--------------------|----------------------------------------------------|
| 31:0       | RO          | 0x00800000         | epdebug<br>Endpoint Debug Information High 32-bit. |

**usb2otg\_GPRTBIMAP\_HSL0**

Address: Operational Base + offset (0xC180)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                           |
| 3:0        | RW          | 0x0                | binum1<br>HS USB Instance Number for Port 1.<br>Application-programmable ID field. |

**usb2otg\_GPRTBIMAP\_FSL0**

Address: Operational Base + offset (0xC188)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------|
| 31:4       | RO          | 0x00000000         | reserved                                                                           |
| 3:0        | RW          | 0x0                | binum1<br>FS USB Instance Number for Port 1.<br>Application-programmable ID field. |

**usb2otg\_GUSB2PHYCFG0**

Address: Operational Base + offset (0xC200)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | physoftrst<br>UTMI PHY Soft Reset.<br>Causes the usb2phy_reset signal to be asserted to reset a UTMI PHY. Not applicable to ULPI because ULPI PHYs are reset via their FunctionControl. Reset register, and the core automatically writes to this register when the core is reset (vcc_reset_n, USBCMD.HCRST, DCTL.SoftReset, or GCTL.SoftReset).                                                                                                                                                                                                                          |
| 30         | RW          | 0x0                | u2_freeclk_exists<br>Specifies whether your USB 2.0 PHY provides a free-running PHY clock, which is active when the clock control input is active.<br>If your USB 2.0 PHY provides a free-running PHY clock, it must be connected to the utmi_clk[0] input. The remaining utmi_clk[n] must be connected to the respective port clocks. The core uses the Port-0 clock for generating the internal mac2 clock.<br>1'b0: USB 2.0 free clock does not exist<br>1'b1: USB 2.0 free clock exists<br>Note: When the core is configured as device-only, do not set this bit to 1. |
| 29:25      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:22      | RW          | 0x0                | <p>Istrd<br/>LS Turnaround Time.<br/>This field indicates the value of the Rx-to-Tx packet gap for LS devices. The encoding is as follows:</p> <ul style="list-style-type: none"> <li>3'h0: 2 bit times</li> <li>3'h1: 2.5 bit times</li> <li>3'h2: 3 bit times</li> <li>3'h3: 3.5 bit times</li> <li>3'h4: 4 bit times</li> <li>3'h5: 4.5 bit times</li> <li>3'h6: 5 bit times</li> <li>3'h7: 5.5 bit times</li> </ul> <p>Note:<br/>This field is applicable only in Host mode.<br/>For normal operation (to work with most LS devices), set the default value of this field to 3'h0 (2 bit times).<br/>The programmable LS device inter-packet gap and turnaround delays are provided to support some legacy LS devices that might require different delays than the default/fixed ones. For instance, the Open LS mouse requires 3 bit times of inter-packet gap to work correctly.</p>    |
| 21:19      | RW          | 0x2                | <p>Isipd<br/>LS Inter-Packet Time.<br/>This field indicates the value of Tx-to-Tx packet gap for LS devices.<br/>The encoding is as follows:</p> <ul style="list-style-type: none"> <li>3'h0: 2 bit times</li> <li>3'h1: 2.5 bit times</li> <li>3'h2: 3 bit times</li> <li>3'h3: 3.5 bit times</li> <li>3'h4: 4 bit times</li> <li>3'h5: 4.5 bit times</li> <li>3'h6: 5 bit times</li> <li>3'h7: 5.5 bit times</li> </ul> <p>Note:<br/>This field is applicable only in Host mode.<br/>For normal operation (to work with most LS devices), set the default value of this field to 3'h2 (3 bit times).<br/>The programmable LS device inter-packet gap and turnaround delays are provided to support some legacy LS devices that might require different delays than the default/fixed ones. For instance, the AOpen LS mouse requires 3 bit times of inter-packet gap to work correctly.</p> |
| 18:14      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:10      | RW          | 0x5                | <p>usbtrdim<br/>USB 2.0 Turnaround Time.<br/>Sets the turnaround time in PHY clocks.<br/>Specifies the response time for a MAC request to the Packet FIFO Controller (PFC) to fetch data from the DFIFO (SPRAM).<br/>The following are the required values for the minimum SoC bus frequency of 60 MHz. USB turnaround time is a critical certification criteria when using long cables and five hub levels.<br/>The required values for this field:<br/>4'h5: When the MAC interface is 16-bit UTMI+.<br/>4'h9: When the MAC interface is 8-bit UTMI+/ULPI.<br/>If SoC bus clock is less than 60 MHz, and USB turnaround time is not critical, this field can be set to a larger value.<br/>Note: This field is valid only in device mode.</p>                                                                     |
| 9          | RW          | 0x0                | <p>xcvrdly<br/>Transceiver Delay.<br/>Enables a delay between the assertion of the UTMI/ULPI Transceiver Select signal (for HS) and the assertion of the TxValid signal during a HS Chirp.<br/>When this bit is set to 1, a delay (of approximately 2.5 us) is introduced from the time when the Transceiver Select is set to 2'b00 (HS) to the time the TxValid is driven to 0 for sending the chirp-K.<br/>This delay is required for some UTMI/ULPI PHYs.<br/>Note:<br/>If you enable the hibernation feature when the device core comes out of power-off, you must re-initialize this bit with the appropriate value because the core does not save and restore this bit value during hibernation.<br/>This bit is valid only in device mode.</p>                                                               |
| 8          | RW          | 0x0                | <p>enblslpm<br/>Enable utmi_sleep_n and utmi_l1_suspend_n.<br/>The application uses this bit to control utmi_sleep_n and utmi_l1_suspend_n assertion to the PHY in the L1 state.<br/>1'b0: utmi_sleep_n and utmi_l1_suspend_n assertion from the core is not transferred to the external PHY.<br/>1'b1: utmi_sleep_n and utmi_l1_suspend_n assertion from the core is transferred to the external PHY.<br/>Note:<br/>This bit must be set high for Port0 if SNPS PHY is used.<br/>In Device mode - Before issuing any device endpoint command when operating in 2.0 speeds, disable this bit and enable it after the command completes. Without disabling this bit, if a command is issued when the device is in L1 state and if mac2_clk (utmi_clk/ulpi_clk) is gated off, the command will not get completed.</p> |
| 7          | RO          | 0x0                | <p>physel<br/>USB 2.0 High-Speed PHY or USB 1.1 Full-Speed.<br/>1'b0: USB 2.0 high-speed UTMI+ or ULPI PHY.<br/>1'b1: USB 1.1 full-speed serial transceiver.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | RW   | 0x0         | <p>suspendusb20<br/>Suspend USB2.0 HS/FS/LS PHY.<br/>When set, USB2.0 PHY enters Suspend mode if Suspend conditions are valid.<br/>For DRD/OTG configurations, it is recommended that this bit is set to 0 during coreConsultant configuration. If it is set to 1, then the application must clear this bit after power-on reset.<br/>Application needs to set it to 1 after the core initialization completes.</p> <p>For all other configurations, this bit can be set to 1 during core configuration.</p> <p>Note:<br/>In host mode, on reset, this bit is set to 1. Software can override this bit after reset.<br/>In device mode, before issuing any device endpoint command when operating in 2.0 speeds, disable this bit and enable it after the command completes. If you issue a command without disabling this bit when the device is in L2 state and if mac2_clk (utmi_clk/ulpi_clk) is gated off, the command will not get completed.</p>                               |
| 5   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4   | RO   | 0x0         | <p>ulpi_utmi_sel<br/>ULPI or UTMI+ Select.<br/>1'b0: UTMI+ Interface<br/>1'b1: ULPI Interface</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3   | RW   | 0x1         | <p>phyif<br/>If UTMI+ is selected, the application uses this bit to configure the core to support a UTMI+ PHY with an 8- or 16-bit interface.<br/>1'b0: 8 bits<br/>1'b1: 16 bits</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2:0 | RW   | 0x0         | <p>tout_cal<br/>HS/FS Timeout Calibration.<br/>The number of PHY clocks, as indicated by the application in this field, is multiplied by a bit-time factor; this factor is added to the high-speed/full-speed interpacket timeout duration in the core to account for additional delays introduced by the PHY. This may be required, since the delay introduced by the PHY in generating the linestate condition may vary among PHYs.<br/>The USB standard timeout value for high-speed operation is 736 to 816 (inclusive) bit times. The USB standard timeout value for full-speed operation is 16 to 18 (inclusive) bit times. The application must program this field based on the speed of connection. The number of bit times added per PHY clock are:<br/>High-speed operation:<br/>One 30-MHz PHY clock = 16 bit times<br/>One 60-MHz PHY clock = 8 bit times<br/>Full-speed operation:<br/>One 30-MHz PHY clock = 0.4 bit times<br/>One 60-MHz PHY clock = 0.2 bit times</p> |

**usb2otg\_GTXFIFOSIZn**

Address: Operational Base + offset (0xC300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x04B9             | txfstaddr_n<br>Transmit FIFOOn RAM Start Address.<br>This field contains the memory start address for TxFIFOOn in 64-bit words.      |
| 15:0       | RW          | 0x000A             | txfdep_n<br>TxFIFO Depth.<br>This field contains the depth of TxFIFOOn in 64-bit words.<br>Minimum value: 32; Maximum value: 32,768. |

**usb2otg\_GRXFIFOSIZn**

Address: Operational Base + offset (0xC380)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0334             | rxfstaddr_n<br>RxFIFOOn RAM Start Address.<br>This field contains the memory start address for RxFIFOOn in 64-bit words. |
| 15:0       | RW          | 0x0185             | rxdep_n<br>RxFIFOOn RAM Start Address.<br>This field contains the memory start address for RxFIFOOn in 64-bit words.     |

**usb2otg\_GEVNTADRLO0**

Address: Operational Base + offset (0xC400)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0xFF7001B0         | evntadrlo<br>Event Buffer Address.<br>Holds the lower 32 bits of start address of the external memory for the Event Buffer. During operation, hardware does not update this address. |

**usb2otg\_GEVNTADRHI0**

Address: Operational Base + offset (0xC404)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | evntadrhi<br>Event Buffer Address.<br>Holds the higher 32 bits of start address of the external memory for the Event Buffer. During operation, hardware does not update this address. |

**usb2otg\_GEVNTSIZ0**

Address: Operational Base + offset (0xC408)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x1                | evntintrptmask<br>Event Interrupt Mask.<br>When set to '1', this prevents the interrupt from being generated. However, even when the mask is set, the events are queued.                                                         |
| 30:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                         |
| 15:0       | RW          | 0x0100             | eventsiz<br>Event Buffer Size in bytes.<br>Holds the size of the Event Buffer in bytes; must be a multiple of four. This is programmed by software once during initialization. The minimum size of the event buffer is 32 bytes. |

**usb2otg\_GEVNTCOUNT0**

Address: Operational Base + offset (0xC40C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                             |
| 15:0       | RW          | 0x0004             | evntcount<br>Event Count.<br>When read, returns the number of valid events in the Event Buffer (in bytes).<br>When written, hardware decrements the count by the value written. The interrupt line remains high when count is not 0. |

**usb2otg\_GHWPARAMS8**

Address: Operational Base + offset (0xC600)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>            |
|------------|-------------|--------------------|-------------------------------|
| 31:0       | RO          | 0x00000047c        | ghwparams8_32_0<br>ghwparams8 |

**usb2otg\_GTXFIFOPRIDEV**

Address: Operational Base + offset (0xC610)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6:0        | RW          | 0x00               | gtxfifopridev<br>Device TxFIFO priority.<br>This register specifies the relative DMA priority level among the Device TXFIFOs (one per IN endpoint). Each register bit[n] controls the priority (1: high, 0: low) of each TXFIFO[n]. When multiple TXFIFOs compete for DMA service at a given time (that is, multiple TXQs contain TX DMA requests and their corresponding TXFIFOs have space available), the TX DMA arbiter grants access on a packet-basis in the following manner:<br>1. High-priority TXFIFOs are granted access using round-robin arbitration<br>2. Low-priority TXFIFOs are granted access using round-robin arbitration only after the high-priority TXFIFOs have no further processing to do (that is, either the TXQs are empty or the corresponding TXFIFOs are full).<br>For scatter-gather packets, the arbiter grants successive DMA requests to the same FIFO until the entire packet is completed. When configuring periodic IN endpoints, software must set register bit[n]=1, where n is the TXFIFO assignment. This ensures that the DMA for isochronous or interrupt IN endpoints are prioritized over bulk or control IN endpoints.<br>This register is present only when the core is configured to operate in the device mode. The register size corresponds to the number of Device IN endpoints. |

**usb2otg\_GTXFIFOPRIHST**

Address: Operational Base + offset (0xC618)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | RW   | 0x0         | <p>gtxfifo prihst<br/>Host Tx FIFO priority.</p> <p>This register specifies the relative DMA priority level among the Host TXFIFOs (one per USB bus instance) within the associated speed group (HS/FSLS). Each register bit[n] controls the priority (1: high, 0: low) of TXFIFO[n] within a speed group. When multiple TXFIFOs compete for DMA service at a given time (i.e., multiple TXQs contain TX DMA requests and their corresponding TXFIFOs have space available), the TX DMA arbiter grants access on a packet-basis in the following manner:</p> <ol style="list-style-type: none"> <li>1. Among the FIFOs in the same speed group (HS/FSLS):             <ol style="list-style-type: none"> <li>a. High-priority TXFIFOs are granted access using round-robin arbitration</li> <li>b. Low-priority TXFIFOs are granted access using round-robin arbitration only after the high-priority TXFIFOs have no further processing to do (that is, either the TXQs are empty or the corresponding TXFIFOs are full).</li> </ol> </li> <li>2. The TX DMA arbiter prioritizes the HS/FSLS speed group according to the ratio programmed in the GDMAHLRATIO register. For scatter-gather packets, the arbiter grants successive DMA requests to the same FIFO until the entire packet is completed.</li> </ol> <p>This register is present only when the core is configured to operate in the host mode (includes DRD and OTG modes). The register size corresponds to the number of configured USB bus instances; for example, in the default configuration, there are 2 USB bus instances (1 HS, and 1 FSLS).</p> |

**usb2otg GRXFIFOPRIHST**

Address: Operational Base + offset (0xC61C)

| Bit  | Attr | Reset Value | Description |
|------|------|-------------|-------------|
| 31:3 | RO   | 0x00000000  | reserved    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0        | RW          | 0x0                | <p>grxfifoprihst<br/>Host RXFIFO priority</p> <p>This register specifies the relative DMA priority level among the Host RXFIFOs (one per USB bus instance) within the associated speed group (HS/FSLS). Each register bit[n] controls the priority (1: high, 0: low) of RXFIFO[n] within a speed group. When multiple RXFIFOs compete for DMA service at a given time (i.e., multiple RXQs contain RX DMA requests and their corresponding RXFIFOs have data available), the RX DMA arbiter grants access on a packet-basis in the following manner:</p> <ol style="list-style-type: none"> <li>1. Among the FIFOs in the same speed group (HS/FSLS):             <ol style="list-style-type: none"> <li>a. High-priority RXFIFOs are granted access using round-robin arbitration</li> <li>b. Low-priority RXFIFOs are granted access using round-robin arbitration only after high-priority RXFIFOs have no further processing to do (that is, either the RXQs are empty or the corresponding RXFIFOs do not have the required data).</li> </ol> </li> <li>2. The RX DMA arbiter prioritizes the HS/FSLS speed group according to the ratio programmed in the GDMAHLRATIO register. For scatter-gather packets, the arbiter grants successive DMA requests to the same FIFO until the entire packet is completed.</li> </ol> <p>This register is present only when the core is configured to operate in the host mode (includes DRD and OTG modes). The register size corresponds to the number of configured USB bus instances; for example, in the default configuration, there are 2 USB bus instances (1 HS, and 1 FSLS).</p> |

**usb2otg\_GFIFOPRIDBC**

Address: Operational Base + offset (0xC620)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:2       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                        |
| 1:0        | RW          | 0x0                | <p>gfifopridbc<br/>Host DbC DMA priority.</p> <p>This register specifies the relative priority of the RXFIFOs and TXFIFOs associated with the DbC mode. It overrides the priority assigned in the corresponding indexes of the Host RXFIFO and TXFIFO DMA priority registers, when the DbC mode is enabled.</p> |

**usb2otg\_GDMAHLRATIO**

Address: Operational Base + offset (0xC624)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                      |
|------------|-------------|--------------------|---------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                |
| 21:8       | RW          | 0x0000             | <p>hstrxfifo<br/>Host RXFIFO DMA High-Low Priority.</p> |
| 7:5        | RO          | 0x0                | reserved                                                |
| 4:0        | RW          | 0x00               | <p>hsttxfifo<br/>Host TXFIFO DMA High-Low Priority.</p> |

**usb2otg\_GFLADJ**

Address: Operational Base + offset (0xC630)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RW   | 0x0         | <p>gfladj_refclk_240mhzdecr_pls1<br/> This field indicates that the decrement value that the controller applies for each ref_clk must be <math>GFLADJ\_REFCLK\_240MHZ\_DECR</math> and <math>GFLADJ\_REFCLK\_240MHZ\_DECR + 1</math> alternatively on each ref_clk.</p> <p>Set this bit to a 1 only if <math>GFLADJ\_REFCLK\_LPM\_SEL</math> is set to 1 and the fractional component of 240/ref_frequency is greater than or equal to 0.5.</p> <p>Examples:<br/> If the ref_clk is 24 MHz then<br/> 1. GUCTL.REF_CLK_PERIOD = 41<br/> 2. <math>GFLADJ.GFLADJ\_REFCLK\_240MHZ\_DECR = (240/24) = 10</math><br/> 3. <math>GFLADJ.GFLADJ\_REFCLK\_240MHZDECR\_PLS1 = 0</math></p>                                                                                                                                                                                                                                                                                                                                                                                                 |
| 30:24 | RW   | 0x00        | <p>gfladj_refclk_240mhz_decr<br/> This field indicates the decrement value that the controller applies for each ref_clk in order to derive a frame timer in terms of a 240-MHz clock.</p> <p>This field must be programmed to a non-zero value only if <math>GFLADJ\_REFCLK\_LPM\_SEL</math> is set to 1.</p> <p>The value is derived as follows:<br/> <math>GFLADJ\_REFCLK\_240MHZ\_DECR = 240/\text{ref\_clk\_frequency}</math></p> <p>Examples: If the ref_clk is 24 MHz then<br/> 1. GUCTL.REF_CLK_PERIOD = 41<br/> 2. <math>GFLADJ.GFLADJ\_REFCLK\_240MHZ\_DECR = 240/24 = 10</math></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 23    | RW   | 0x0         | <p>gfladj_refclk_lpm_sel<br/> This bit enables the functionality of running SOF counters on the ref_clk. This bit must not be set to 1 if GCTL.SOFITPSYNC bit is set to 1. Similarly, if <math>GFLADJ\_REFCLK\_LPM\_SEL</math> set to 1, GCTL.SOFITPSYNC must not be set to 1.</p> <p>Note that the ref_clk frequencies supported in this mode are 16/17/19.2/20/24/39.7/40 MHz. The utmi_clk[0] signal of the core must be connected to the FREECLK of the PHY.</p> <p>Note: If you set this bit to 1, the GUSB2PHYCFG.U2_FREECLK_EXISTS bit must be set to 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 22    | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21:8  | RW   | 0x0000      | <p>gfladj_refclk_fladj<br/> This field indicates the frame length adjustment to be applied when SOF counter is running on the ref_clk.</p> <p>SOF interval when <math>GFLADJ.GFLADJ\_REFCLK\_LPM\_SEL</math> is set to 1.</p> <p>This field must be programmed to a non-zero value only if <math>GFLADJ\_REFCLK\_LPM\_SEL</math> is set to 1 or GCTL.SOFITPSYNC is set to 1.</p> <p>The value is derived as follows:<br/> <math>FLADJ\_REF\_CLK\_FLADJ=((125000/\text{ref\_clk\_period\_integer}) - (125000/\text{ref\_clk\_period})) * \text{ref\_clk\_period}</math> where:<br/> 1. The ref_clk_period_integer is the integer value of the ref_clk period got by truncating the decimal (fractional) value that is programmed in the GUCTL.REF_CLK_PERIOD field.<br/> 2. The ref_clk_period is the ref_clk period including the fractional value.</p> <p>Examples: If the ref_clk is 24 MHz then<br/> 1. GUCTL.REF_CLK_PERIOD = 41<br/> 2. <math>GFLADJ.GFLADJ\_REFCLK\_FLADJ = ((125000/41) - (125000/41.6666)) * 41.6666 = 2032</math> (ignoring the fractional value).</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | RW          | 0x0                | <p>gfladj_30mhz_sdbnd_sel<br/>           This field selects whether to use the input signal fladj_30mhz_reg or the GFLADJ.GFLADJ_30MHZ to adjust the frame length for the SOF. When this bit is set to:<br/>           1'b1: the controller uses the register field GFLADJ.GFLADJ_30MHZ value<br/>           1'b0: the controller uses the input signal fladj_30mhz_reg value.</p>                                                                                                            |
| 6          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5:0        | RW          | 0x00               | <p>gfadj_30mhz<br/>           This field indicates the value that is used for frame length adjustment instead of considering from the sideband input signal fladj_30mhz_reg.<br/>           This enables post-silicon frame length adjustment in case the input signal fladj_30mhz_reg is connected to a wrong value or is not valid.<br/>           For details on how to set this value, refer to section 5.2.4, "Frame Length Adjustment Register (FLADJ)," of the xHCI Specification.</p> |

**usb2otg\_DCFG**

Address: Operational Base + offset (0xC700)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23         | RW          | 0x0                | <p>ignstrmpp<br/>           This bit only affects stream-capable bulk endpoints. Not applied.</p>                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 22         | RW          | 0x1                | <p>lpmcap<br/>           LPM Capable. Not applied.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 21:17      | RW          | 0x04               | <p>nump<br/>           Number of Receive Buffers. Not applied.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 16:12      | RW          | 0x00               | <p>intrnum<br/>           Interrupt number.<br/>           Indicates interrupt/EventQ number on which non-endpoint-specific device-related interrupts (see DEVT) are generated.</p>                                                                                                                                                                                                                                                                                                                                         |
| 11:10      | RO          | 0x10               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9:3        | RW          | 0x25               | <p>devaddr<br/>           Device Address.<br/>           The application must perform the following:<br/>           1. Program this field after every SetAddress request.<br/>           2. Reset this field to zero after USB reset.</p>                                                                                                                                                                                                                                                                                   |
| 2:0        | RW          | 0x0                | <p>devspd<br/>           Device Speed.<br/>           Indicates the speed at which the application requires the core to connect, or the maximum speed the application can support.<br/>           However, the actual bus speed is determined only after the chirp sequence is completed, and is based on the speed of the USB host to which the core is connected.<br/>           3'b000: High-speed (USB 2.0 PHY clock is 30 MHz or 60 MHz)<br/>           3'b001: Full-speed (USB 2.0 PHY clock is 30 MHz or 60 MHz)</p> |

**usb2otg\_DCTL**

Address: Operational Base + offset (0xC704)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x1                | <p>run_stop<br/>The software writes 1 to this bit to start the device controller operation.<br/>To stop the device controller operation, the software must remove any active transfers and write 0 to this bit. When the controller is stopped, it sets the DSTS.DevCtrlHlt bit when the core is idle and the lower layer finishes the disconnect process.<br/>The Run/Stop bit must be used in following cases as specified:</p> <ol style="list-style-type: none"> <li>1. After power-on reset and CSR initialization, the software must write 1 to this bit to start the device controller. The controller does not signal connect to the host until this bit is set.</li> <li>2. The software uses this bit to control the device controller to perform a soft disconnect. When the software writes 0 to this bit, the host does not see that the device is connected. The device controller stays in the disconnected state until the software writes 1 to this bit.</li> <li>3. When the USB is in a lower power state and the Two Power Rails configuration is selected, software writes 0 to this bit to indicate that it is going to turn off the Core Power Rail. After the software turns on the Core Power Rail again and re-initializes the device controller, it must set this bit to start the device controller.</li> </ol> <p>Note: The following is the minimum duration under various conditions for which the soft disconnect (SftDiscon) bit must be set for the USB host to detect a device disconnect:<br/>10ms: For high-speed, when the device state is Suspended, Idle, or not Idle/Suspended (performing transactions); For full-speed/low-speed, when the device state is Suspended, Idle, or not Idle/Suspended (performing transactions).<br/>To accommodate clock jitter, it is recommended that the application add extra delay to the specified minimum duration.</p> |

| Bit   | Attr   | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30    | R/W SC | 0x0         | <p>csfrst<br/>Core Soft Reset.<br/>Reset all clock domains as follows:</p> <ol style="list-style-type: none"> <li>1. This bit clears the interrupts and all the CSRs except GSTS, GSNPSID, GPIO, GUID, GUSB2PHYCFGn registers, GUSB3PIPECTLn registers, DCFG, DCTL, DEVREN, and DSTS registers.</li> <li>2. All module state machines (except the SoC Bus Slave Unit) are reset to the IDLE state, and all the TxFIFOs and the Rx FIFO are flushed.</li> <li>3. Any transactions on the SoC bus Master are terminated as soon as possible, after gracefully completing the last data phase of a SoC bus transfer. Any transactions on the USB are terminated immediately.</li> </ol> <p>The application can write this bit at any time to reset the core. This is a self-clearing bit; the core clears this bit after all necessary logic is reset in the core, which may take several clocks depending on the core's current state. Once this bit is cleared, the software must wait at least 3 PHY clocks before accessing the PHY domain (synchronization delay).</p> <p>Typically, software reset is used during software development and also when you dynamically change the PHY selection bits in the USB configuration registers listed above. When you change the PHY, the corresponding clock for the PHY is selected and used in the PHY domain. Once a new clock is selected, the PHY domain must be reset for proper operation.</p> |
| 29    | RO     | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 28:24 | RW     | 0x00        | <p>hirdthres<br/>HIRD Threshold.</p> <p>The core asserts output signals utmi_l1_suspend_n and utmi_sleep_n on the basis of this signal:</p> <p>The core asserts utmi_l1_suspend_n to put the PHY into Deep Low-Power mode in L1 when both of the following are true:</p> <ol style="list-style-type: none"> <li>1. HIRD value is greater than or equal to the value in DCTL.HIRD_Thres[3:0]</li> <li>2. HIRD_Thres[4] is set to 1'b1.</li> </ol> <p>The core asserts utmi_sleep_n on L1 when one of the following is true:</p> <ol style="list-style-type: none"> <li>1. If the HIRD value is less than HIRD_Thres[3:0] or</li> <li>2. HIRD_Thres[4] is set to 1'b0.</li> </ol> <p>Note: This field must be set to '0' during SuperSpeed mode of operation.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:20      | RW          | 0x0                | <p>lpm_nyet_thres<br/>LPM NYET Threshold<br/>Handshake response to LPM token specified by device application.<br/>Response depends on DCFG.LPMCap.</p> <p>DCFG.LPMCap is 1'b0 - The core always responds with Timeout (that is, no response).</p> <p>DCFG.LPMCap is 1'b1 - The core responds with an ACK on successful LPM transaction, which requires that all of the following are satisfied:</p> <ol style="list-style-type: none"> <li>1. There are no PID or CRC5 errors in both the EXT token and the LPM token (if not true, inactivity results in a timeout ERROR).</li> <li>2. No data is pending in the Transmit FIFO and OUT endpoints not in flow controlled state (else NYET).</li> <li>3. The BESL value in the LPM token is less than or equal to LPM_NYET_thres[3:0].</li> </ol> |
| 19         | RW          | 0x0                | <p>keep_connect<br/>When 1, this bit enables the save and restore programming model by preventing the core from disconnecting from the host when DCTL.RunStop is set to 0.<br/>The device core disconnects from the host when DCTL.RunStop is set to 0.<br/>This bit indicates whether to preserve this behavior (0), or if the core must not disconnect when RunStop is set to 0 (1).</p>                                                                                                                                                                                                                                                                                                                                                                                                       |
| 18         | RW          | 0x0                | <p>l1_hibernation_en<br/>When this bit is set along with KeepConnect, the device core generates a Hibernation Request Event if L1 is enabled and the HIRD value in the LPM token is larger than the threshold programmed in DCTL.HIRD_Thres.<br/>The core does not exit the LPM L1 state until software writes Recovery into the DCTL.ULStChngReq field.<br/>This prevents corner cases where the device is entering hibernation at the same time the host is attempting to exit L1.</p>                                                                                                                                                                                                                                                                                                         |
| 17         | RW          | 0x0                | <p>crs<br/>Controller Restore State.<br/>This command is similar to the USBCMD.CRS bit in host mode and initiates the restore process. When software sets this bit to 1, the controller immediately sets DSTS.RSS to 1. When the controller has finished the restore process, it sets DSTS.RSS to 0.<br/>Note: When read, this field always returns 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 16         | RW          | 0x0                | <p>css<br/>Controller Save State.<br/>This command is similar to the USBCMD.CSS bit in host mode and initiates the save process. When software sets this bit to 1, the controller immediately sets DSTS.SSS to 1. When the controller has finished the save process, it sets DSTS.SSS to 0.<br/>Note: When read, this field always returns 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 12         | RW          | 0x0                | initu2ena<br>Not applied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11         | RW          | 0x1                | acceptu2ena<br>Not applied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10         | RW          | 0x0                | initu1ena<br>Not applied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 9          | RW          | 0x1                | acceptu1ena<br>Not applied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:5        | RW          | 0x0                | <p>ulstchngreq<br/>Software writes this field to issue a USB state change request. A change in this field indicates a new request to the core.<br/>If software wants to issue the same request back-to-back, it must write a 0 to this field between the two requests. The result of the state change request is reflected in the USB State in DSTS. These bits are self-cleared on the MAC Layer exiting suspended state.<br/>If software is updating other fields of the DCTL register and not intending to force any link state change, then it must write a 0 to this field.</p> <p>In HS/FS/LS mode:<br/>Value: Requested USB state transition<br/>8: Remote wakeup request<br/>Others: Reserved<br/>The Remote wakeup request must be issued 2us after the device goes into suspend state (DSTS[21:18] is 3 ).<br/>Note: After coming out of hibernation, software must write 8 (Recovery) into this field to confirm exit from the suspended state.</p> |
| 4:1        | RW          | 0x0                | <p>tstctl<br/>Test Control.<br/>4'b000: Test mode disabled<br/>4'b001: Test_J mode<br/>4'b010: Test_K mode<br/>4'b011: Test_SE0_NAK mode<br/>4'b100: Test_Packet mode<br/>4'b101: Test_Force_Enable<br/>Others: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**usb2otg\_DEVEN**

Address: Operational Base + offset (0xC708)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                         |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|
| 31:13      | RO          | 0x00000            | reserved                                                                                                                   |
| 12         | RW          | 0x1                | <p>vendevtstrcvden<br/>Vendor Device Test LMP Received Event.<br/>1'b0: Disable this event<br/>1'b1: Enable this event</p> |
| 11:10      | RO          | 0x0                | reserved                                                                                                                   |
| 9          | RW          | 0x1                | <p>errticerrevten<br/>Erratic Error Event Enable.<br/>1'b0: Disable this event<br/>1'b1: Enable this event</p>             |
| 8          | RO          | 0x0                | reserved                                                                                                                   |
| 7          | RW          | 0x0                | <p>softevten<br/>Start of (u)frame Event Enable.<br/>1'b0: Disable this event<br/>1'b1: Enable this event</p>              |
| 6          | RW          | 0x0                | <p>u3l2l1_susp_en<br/>U3/L2-L1 Suspend Event Enable.<br/>1'b0: Disable this event<br/>1'b1: Enable this event</p>          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | hibernation_req_evt_en<br>Hibernation Request Event Enable.<br>1'b0: Disable this event<br>1'b1: Enable this event |
| 4          | RW          | 0x1                | wkupevten<br>Resume/Remote Wakeup Detected Event Enable.<br>1'b0: Disable this event<br>1'b1: Enable this event    |
| 3          | RW          | 0x1                | ulstcngen<br>USB State Change Event Enable.<br>1'b0: Disable this event<br>1'b1: Enable this event                 |
| 2          | RW          | 0x1                | connectdoneevten<br>Connection Done Event Enable.<br>1'b0: Disable this event<br>1'b1: Enable this event           |
| 1          | RW          | 0x1                | usbrstevten<br>USB Reset Event Enable.<br>1'b0: Disable this event<br>1'b1: Enable this event                      |
| 0          | RW          | 0x1                | disconnevten<br>Disconnect Detected Event Enable.<br>1'b0: Disable this event<br>1'b1: Enable this event           |

**usb2otg DSTS**

Address: Operational Base + offset (0xC70C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 29         | RW          | 0x0                | dcnrd<br>Device Controller Not Ready.<br>The bit indicates that the core is in the process of completing the state transitions after exiting from hibernation.<br>To complete the state transitions, it takes 256 bus clock cycles from the time DCTL[31].Run/Stop is set. During hibernation, if the UTMI/ULPI PHY is in suspended state, then the 256-bus clock cycle delay starts after the PHY exited suspended state. Software must set DCTL[31].Run/Stop to 1 and wait for this bit to be deasserted to zero before processing DSTS.USBLnkSt. |
| 28:26      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 25         | RW          | 0x0                | rss<br>Restore State Status.<br>This bit is similar to the USBSTS.RSS in host mode.<br>When the controller finishes the restore process, it completes the command by setting DSTS.RSS to 0.                                                                                                                                                                                                                                                                                                                                                         |
| 24         | RO          | 0x0                | sss<br>Save State Status.<br>This bit is similar to the USBSTS.SSS in host mode.<br>When the controller has finished the save process, it completes the command by setting DSTS.SSS to 0.                                                                                                                                                                                                                                                                                                                                                           |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23    | RO   | 0x0         | <p>coreidle<br/>Core Idle.</p> <p>The bit indicates that the core finished transferring all RxFIFO data to system memory, writing out all completed descriptors, and all Event Counts are zero.</p> <p>Note: While testing for Reset values, mask out the read value. This bit represents the changing state of the core and does not hold a static value.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 22    | RO   | 0x0         | <p>devctrlhlt<br/>Device Controller Halted.</p> <p>This bit is set to 0 when the Run/Stop bit in the DCTL register is set to 1.</p> <p>The core sets this bit to 1 when, after SW sets Run/Stop to 0, the core is idle and the lower layer finishes the disconnect process. When Halted=1, the core does not generate Device events.</p> <p>Note: The core does not set this bit to 1 if GEVNTCOUNTn has some valid value. Software needs to acknowledge the events that are generated (by writing to GEVNTCOUNTn) while it is waiting for this bit to be set to 1.</p>                                                                                                                                                                                                                                                                                                      |
| 21:18 | RO   | 0x0         | <p>usblnkst<br/>In HS/FS/LS mode:</p> <p>4'h0: On state<br/>4'h2: Sleep (L1) state<br/>4'h3: Suspend (L2) state<br/>4'h4: Disconnected state (Default state)<br/>4'h5: Early Suspend state (valid only when Hibernation is disabled, GCTL[1].GblHibernationEn = 0)<br/>4'he: Reset (valid only when Hibernation is enabled, GCTL[1].GblHibernationEn = 1)<br/>4'hf: Resume (valid only when Hibernation is enabled, GCTL[1].GblHibernationEn = 1)</p> <p>The link state Resume/Reset indicates that the core received a resume or USB reset request from the host while the link was in hibernation. Software must write 8 (Recovery) to the DCTL.ULStChngReq field to acknowledge the resume/reset request.</p> <p>When Hibernation is enabled, GCTL[1].GblHibernationEn = 1, this field USBLnkSt is valid only when DCTL[31].Run/Stop set to 1 and DSTS[29].DCNRD = 0.</p> |
| 17    | RO   | 0x1         | rx_fifo_empty<br>Rx Fifo Empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 16:3  | RO   | 0x3023      | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2:0   | RU   | 0x0         | <p>connectspd<br/>Connected Speed.</p> <p>Indicates the speed at which the DWC_usb3 core has come up after speed detection through a chirp sequence.</p> <p>3'b000: High-speed (PHY clock is running at 30 or 60 MHz)<br/>3'b001: Full-speed (PHY clock is running at 30 or 60 MHz)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**usb2otg\_DGCMMPAR**

Address: Operational Base + offset (0xC710)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | parameter<br>This register indicates the device command parameter. This must be programmed before or along with the device command. The available device commands are listed in DGCMD register. |

**usb2otg\_DGCMD**

Address: Operational Base + offset (0xC714)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15:12      | RO          | 0x0                | cmdstatus<br>Command Status:<br>1'b1: CmdErr: Indicates that the device controller encountered an error while processing the command.<br>1'b0: Indicates command success                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 9          | R/W SC      | 0x0                | cmdact<br>Command Active.<br>The software sets this bit to 1 to enable the device controller to execute the generic command.<br>The device controller sets this bit to 0 after executing the command.                                                                                                                                                                                                                                                                                                                                                                            |
| 8          | RW          | 0x0                | cmdioc<br>Command Interrupt on Complete.<br>When this bit is set, the device controller issues a Generic Command Completion event after executing the command.<br>Note that this interrupt is mapped to DCFG.IntrNum.<br>Note: This field must not set to 1 if the DCTL.RunStop field is 0.                                                                                                                                                                                                                                                                                      |
| 7:0        | RW          | 0x00               | cmdtyp<br>Command Type.<br>Specifies the type of command the software driver is requesting the core to perform.<br>8'h0: Reserved<br>8'h1: Set Endpoint Configuration - 64 or 96-bit Parameter<br>8'h2: Set Endpoint Transfer Resource Configuration - 32-bit Parameter<br>8'h3: Get Endpoint State - No Parameter Needed<br>8'h4: Clear Stall (see Set Stall) - No Parameter Needed<br>8'h5: Start Transfer - 64-bit Parameter<br>8'h6: Update Transfer - No Parameter Needed<br>8'h7: End Transfer - No Parameter Needed<br>8'h8 Start New Configuration - No Parameter Needed |

**usb2otg\_DALEPENA**

Address: Operational Base + offset (0xC720)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000003         | <p>usbactep<br/>USB Active Endpoints.<br/>This field indicates if a USB endpoint is active in the current configuration and interface. It applies to USB IN endpoints 0~15 and OUT endpoints 0~15, with one bit for each of the 32 possible endpoints. Even numbers are for USB OUT endpoints, and odd numbers are for USB IN endpoints, as follows:<br/>Bit[0]: USB EP0-OUT<br/>Bit[1]: USB EP0-IN<br/>Bit[2]: USB EP1-OUT<br/>Bit[3]: USB EP1-IN<br/>...<br/>The entity programming this register must set bits 0 and 1 because they enable control endpoints that map to physical endpoints (resources) after USBReset.<br/>Hardware clears these bits for all endpoints (other than EP0-OUT and EP0-IN) after detecting a USB reset event. After receiving SetConfiguration and SetInterface requests, the application must program endpoint registers accordingly and set these bits.</p> |

**usb2otg DEPnCMDPAR2**

Address: Operational Base + offset (0xC800)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>parameter<br/>This register indicates the physical endpoint command Parameter 2. It must be programmed before issuing the command.</p> |

**usb2otg DEPnCMDPAR1**

Address: Operational Base + offset (0xC804)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0xFF7002E0         | <p>parameter<br/>This register indicates the physical endpoint command Parameter 1. It must be programmed before issuing the command.</p> |

**usb2otg DEPnCMDPAR0**

Address: Operational Base + offset (0xC808)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>parameter<br/>This register indicates the physical endpoint command Parameter 0. It must be programmed before issuing the command.</p> |

**usb2otg DEPnCMD**

Address: Operational Base + offset (0xC80C)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RW          | 0x0000             | <p>commandparam<br/>Command Parameters or Event Parameters when this register is written:<br/>For Start Transfer command: The 16-bit StreamID assigned to this transfer<br/>For Start Transfer command applied to an isochronous endpoint: StartMicroFramNum, Indicates the (micro) frame number to which the first TRB applies.<br/>For Update Transfer, End Transfer, and Start New Configuration commands: [22:16]: Transfer Resource Index (XferRscIdx). The hardware-assigned transfer resource index for the transfer, which was returned in response to the Start Transfer command. The application software-assigned transfer resource index for a Start New Configuration command.<br/>Event Parameters (EventParam), when this register is read.</p> |
| 15:12      | RW          | 0x0                | <p>cmdstatus<br/>Command Completion Status.<br/>The information is in the same format as bits 15:12 of the Endpoint Command Complete event.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11         | RW          | 0x0                | <p>hipri_forcerm<br/>HighPriority: Only valid for Start Transfer command.<br/>ForceRM: Only valid for End Transfer command.<br/>ClearPendIN: Only valid for Clear Stall command. Software sets this bit to clear any pending IN transaction (on that endpoint) stuck at the lower layers when a Clear Stall command is issued.</p>                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10         | RW          | 0x0                | <p>cmdact<br/>Command Active.<br/>Software sets this bit to 1 to enable the device endpoint controller to execute the generic command.<br/>The device controller sets this bit to 0 when the CmdStatus field is valid and the endpoint is ready to accept another command.<br/>This does not imply that all the effects of the previously-issued command have taken place.</p>                                                                                                                                                                                                                                                                                                                                                                                 |
| 9          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 8          | RW          | 0x0                | <p>cmdioc<br/>Command Interrupt on Complete.<br/>When this bit is set, the device controller issues a generic Endpoint Command Complete event after executing the command.<br/>Note that this interrupt is mapped to DEPCFG.IntrNum.<br/>When the DEPCFG command is executed, the command interrupt on completion goes to the interrupt pointed by the DEPCFG.IntrNum in the current command.<br/>Note: This field must not set to 1 if the DCTL.RunStop field is 0.</p>                                                                                                                                                                                                                                                                                       |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | RW   | 0x6         | <p>cmdtyp<br/>Command Type.<br/>Specifies the type of command the software driver is requesting the core to perform.</p> <p>4'h0: Reserved<br/>4'h1: Set Endpoint Configuration - -64 or 96-bit Parameter<br/>4'h2: Set Endpoint Transfer Resource Configuration - 32-bitparameter<br/>4'h3: Get Endpoint State - No Parameter Needed<br/>4'h4: Set Stall - No Parameter Needed<br/>4'h5: Clear Stall (see Set Stall) - No Parameter Needed<br/>4'h6: Start Transfer - 64-bit Parameter<br/>4'h7: Update Transfer - No Parameter Needed<br/>4'h8: End Transfer - No Parameter Needed<br/>4'h9: Start New Configuration - No Parameter Needed</p> |

## 28.5 Interface Description

Table 28-2 USB2.0 PHY Interface Description

| Module Pin | Direction | Pin Name     | Descriptions                                     |
|------------|-----------|--------------|--------------------------------------------------|
| ID         | I/O       | OTG_ID       | ID Pin                                           |
| VBUS18     | I/O       | OTG_VBUS1V8  | VBUS18. It is divided from VBUS on USB connector |
| VCCA18     | I/O       | USB_AVDD_1V8 | 1.8 V power supply                               |
| DP         | I/O       | OTG_DP       | USB differential signal IO, positive end         |
| DM         | I/O       | OTG_DM       | USB differential signal IO, negative end         |
| VBUS18     | I/O       | OTG_EXTR     | USB2.0 PHY Host Port VBUS                        |
| AGND       | I/O       | VSS          | Ground IO for both 3.3V,1.8V and 0.8V            |
| VCCA33     | I/O       | USB_AVDD_3V3 | 3.3 V power supply(only Full speed driver)       |
| VDDA       | I/O       | USB_AVDD_0V8 | 0.8 V power supply                               |

## 28.6 Application Notes

### 28.6.1 Some Settings and Description About USB PHY

Here list some usbotg phy configure register of TOP\_GRF in detail.

- GRF\_USBPHY\_CON0

Table 28-3 GRF\_USBPHY\_CON0 Description

| Bit   | Attr | Reset Value | Description                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RW   | 0x0000      | <p>write_enable<br/>Write enable for lower 16bits, each bit is individual.</p> <p>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         | RW          | 0x1                | usb0tg_data_bus16_8<br>Software configure for OTGPHY data_bus16_8<br>Selects between 8 and 16-bit data transfer.<br>1'b1: 16-bit data path operation enabled, CLK60_30 = 30 MHz.<br>1'b0: 8-bit data path operation enabled, CLK60_30 = 60 MHz.<br>This signal is sampled by USB PHY IP macro cell only when RESET becomes low.<br>Default is 16-bit model and not suggest to configure this bit. |
| 14         | RW          | 0x0                | usb0tg_pll_en<br>Software configure for OTGPHY pll_en<br>PLL enable signal, internal PLL start to work when this signal is set to high, otherwise PLL is disabled and PHY IP stop working.<br>This bit must be set to high before usb function.                                                                                                                                                   |
| 13         | RW          | 0x0                | usb0tg_dischrgvbus<br>Software configure for OTGPHY dischrgvbus<br>Discharge VBUS18. The signal enables discharging VBUS18.<br>1'b0: do not discharge VBUS18 through a resistor<br>1'b1: discharge VBUS18 through a resistor (this has to be active for at least 50ms)                                                                                                                            |
| 12         | RW          | 0x0                | usb0tg_chrgvbus<br>Software configure for OTGPHY chrgvbus<br>Charge VBUS18. The signal enables charging VBUS18.<br>1'b0: do not charge VBUS18 through a resistor<br>1'b1: charge VBUS18 through a resistor (this has to be active for at least 30ms)                                                                                                                                              |
| 11         | RW          | 0x1                | usb0tg_idpulup<br>Software configure for OTGPHY idpulup<br>Enable ID pin sample. Signal that enables the sampling of the analog ID line.<br>1'b0: Sampling of ID pin is disabled (IDDIG force to low).<br>1'b1: Sampling of ID pin is enabled.                                                                                                                                                    |
| 10         | RW          | 0x1                | usb0tg_utmi_iddig<br>Software configure for OTGPHY utmi_iddig<br>Plug Indicator. Indicates whether the connected plug is a mini-A or<br>mini-B. This is only valid when ID_PULLUP is set to 1b. It must be valid within 20ms after ID_PULLUP is set to 1b.<br>1'b0: connected plug is a mini-A<br>1'b1: connected plug is a mini-B<br>In default iddig is controlled by hardware.                 |
| 9          | RW          | 0x0                | usb0tg_utmi_iddig_sel<br>IDDIG selection.<br>1'b0: USBPHY output<br>1'b1: Software output, USBPHY_CON0[10]                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RW          | 0x0                | <p>usbotg_dmpulldown<br/>Software configure for OTGPHY dmpulldown<br/>DM Pulldown. This signal enables the 15k Ohm Pull-down resistor on the DM line.</p> <p>1'b0: Pull-down resistor not connected to DM<br/>1'b1: Pull-down resistor connected to DM<br/>In default this is controlled by hardware.</p>                                                                                                   |
| 7          | RW          | 0x0                | <p>usbotg_dppulldown<br/>Software configure for OTGPHY dppulldown<br/>DP Pulldown. This signal enables the 15k Ohm pull-down resistor on the DP line.</p> <p>1'b0: Pull-down resistor not connected to DP<br/>1'b1: Pull-down resistor connected to DP<br/>In default this is controlled by hardware.</p>                                                                                                   |
| 6          | RW          | 0x1                | <p>usbotg_termselect<br/>Software configure for OTGPHY termselect<br/>Termination Select. This signal selects between the FS and HS terminations:</p> <p>1'b0: HS termination enabled<br/>1'b1: FS termination enabled<br/>In default this is controlled by hardware.</p>                                                                                                                                   |
| 5:4        | RW          | 0x1                | <p>usbotg_xcvrselect<br/>Software configure for OTGPHY xcvrselect<br/>Transceiver Select.</p> <p>2'b00: HS Transceiver enabled<br/>2'b01: FS Transceiver enabled<br/>2'b10: LS Transceiver enabled<br/>2'b11: Reserved<br/>In default this is controlled by hardware.</p>                                                                                                                                   |
| 3:2        | RW          | 0x0                | <p>usbotg_opmode<br/>Software configure for OTGPHY opmode<br/>Operational Mode. These signals select between various operational modes:</p> <p>2'b00: Normal operation<br/>2'b01: Non-driving. Transmitter buffer is in high impedance and pull-up/down resistors are disconnected<br/>2'b10: Disable bit stuffing and NRZI encoding<br/>2'b11: Reserved<br/>In default this is controlled by hardware.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x1                | <p>usb0tg_suspend_n<br/>Software configure for OTGPHY suspend_n<br/>Active low, asynchronous. When enabled, drive IP into suspend mode and consume minimal current from power supply.<br/>1'b0: IP in suspend mode, only those circuit that serve for resume function is still active<br/>1'b1: IP in normal operation<br/>In default this is controlled by hardware.</p> |
| 0          | RW          | 0x0                | <p>otgphy_input_sel<br/>OTGPHY input selection.<br/>1'b0: Hardware input<br/>1'b1: Software input</p>                                                                                                                                                                                                                                                                     |

- GRF\_USBPHY\_CON1

Table 28-4 GRF\_USBPHY\_CON1 Description

| <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 16bits, each bit is individual.<br/>1'b0: Write access disable<br/>1'b1: Write access enable</p>                                                                                                                                                                                                                                     |
| 15         | RW          | 0x0                | <p>usb0tg_chg_RST<br/>Software configure for OTGPHY chg_RST<br/>Charge detector reset signal, active high, asynchronous.<br/>1'b0: charge detector is normal operation<br/>1'b1: charge detector is reset to initial</p>                                                                                                                                                        |
| 14         | RW          | 0x0                | <p>usb0tg_chg_en<br/>Software configure for OTGPHY chg_en<br/>Charge detector enable signal.<br/>1'b0: charging detect is off, IP is configured as SDP in HOST application or is configured as standard device in DEVICE application<br/>1'b1: charging detect is on, IP is configured as CDP in HOST application or is configured as portable device in DEVICE application</p> |
| 13         | RW          | 0x1                | <p>usbhost_suspendm_byps<br/>Software configure for HOSTPHY suspendm_byps<br/>OTG_SUSPENDM linked control bypass signal.<br/>1'b0: OTG_SUSPENDM is controlled by IDDIG(default)<br/>1'b1: OTG_SUSPENDM is controlled by SOC<br/>Please refer to USB2HOST section.</p>                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | <p>usbotg_suspendm_byps<br/>Software configure for OTGPHY suspendm_byps<br/>OTG_SUSPENDM linked control bypass signal.<br/>1'b0: OTG_SUSPENDM is controlled by IDDIG(default)<br/>1'b1: OTG_SUSPENDM is controlled by SOC<br/>Please refer to the description in GRF_USBPHY_CON1.<br/>usbotg_suspendm in this section.</p>                                                                                                                                                                                                                   |
| 11         | RW          | 0x0                | <p>usbotg_txbitstuff_enable<br/>Software configure for OTGPHY txbitstuff_enable<br/>TX BITSTUFF ENABLE. Indicates if the data on the<br/>DATA_OUT[15:0]lines need to be bit stuffed or not.<br/>1'b0: Bit stuffing is disabled<br/>1'b1: Bit stuffing is enabled<br/>This signal is only used when OP_MODE[1:0] is set to 11b.</p>                                                                                                                                                                                                           |
| 10         | RW          | 0x0                | <p>usbotg_suspendm<br/>Software configure for OTGPHY suspend<br/>This signal is used for VBUS negotiation in OTG application and<br/>HOST disconnect in HOST application, in DEVICE mode this signal<br/>should be tie to 0. In OTG/HOST application this signal should be<br/>connected to 1.<br/>In HOST application, IDDIG is not valid, OTG_SUSPENDM must<br/>be set to 1 and OTG_SUSPENDM_BYPS must set to 1.<br/>In DEVICE application, IDDIG is not valid, OTG_SUSPENDM must<br/>be set to 0 and OTG_SUSPENDM_BYPS must set to 1.</p> |
| 9          | RW          | 0x0                | <p>usbotg_fs_se0<br/>Software configure for OTGPHY fs_se0</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8          | RW          | 0x0                | <p>usbotg_fs_data<br/>Software configure for OTGPHY fs_data</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7          | RW          | 0x1                | <p>usbotg_fs_oe<br/>Software configure for OTGPHY fs_oe</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6          | RW          | 0x0                | <p>usbotg_fs_xver_own<br/>Software configure for OTGPHY fs_xver_own</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5:3        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2          | RW          | 0x0                | <p>usbotg_suspend_n_1<br/>Software configure for OTGPHY suspend_n<br/>This is backups of USBPHY_CON0[1]</p>                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | RW   | 0x0         | usbotg_suspend_n_sel<br>usbotg_suspend_n selection.<br>2'b00: ~usbotg_utmi_suspend_com_n &<br>~usbotg_utmi_l1_suspend_com_n<br>2'b10: ~usbotg_utmi_suspend_com_n &<br>~usbotg_utmi_l1_suspend_com_n<br>2'b11: ~usbotg_uspend_n & ~usbotg_utmi_l1_suspend_n<br>2'b01: USBPHY_CON1[2]<br>In default USBPHY_CON0[0]=0, then usbotg_suspend_n will control by this field. |

## 28.6.2 OTG Reset Sequence

In USB function mode, the recommended reset sequence is in figure1-2. 'RST' is the reset signal of USB controller and 'CLK' is the main clock of USB controller. At first, 'RST' is set to 1 and USB controller starts to work; secondly, USB controller outputs 'SUSPENDM'. 'RESET' is the reset of the usb phy. Both 'RST' and 'RESET' are controlled by CRU model.

'SUSPENDM' is set to 1 firstly to enable PLL, PLL starts to work and frequency starts locking, 'RESET' is set to 0 to enable clock lock detector, and 'CLK60\_30' is valid when frequency is stable. PLL lock time(Tlock) is about 500us including the time of bandgap building, PLL locking and so on, Tlock also includes the PVT range.

'CLK\_480' is controlled by 'PLL\_EN', and 'CLK\_480' is not valid when 'PLL\_EN' is 0. Because 'PLL\_EN' is the reset signal of delay control cell, so there must be a rise edge of 'PLL\_EN' to make delay control cell to work correctly. Tdelay is the time of 'PLL\_EN' rise edge to 'CLK\_480' transmitting 480MHz clock, the value is greater than 200us and less than 500us.



Fig. 28-2 USB2.0 OTG reset sequence

## 28.6.3 BchPage Application

There are three steps in charge detector sequence including data contact detection, primary detection and secondary detection. Data contact detection is judging whether DEVICE and HOST are connected or not, primary detection is judging whether the charger is connected

or not, secondary detection is judging whether the charger is DCP or CDP. In DEVICE/HOST application, when 'CHG\_EN' is set to 1, 'CHG\_RST' is set to 0 to start charge detection. This two signal can be control by GRF\_USBPHY\_CON1. During the detection, 'RESET' must be set to 1, the PHY function is disable before 'PHY\_CONNECT' changes to 1. Tdelay is greater than 1ms.



Fig. 28-3 USB2.0 OTG charge sequence

Table 1-5 and 1-6 shows the description about charge model.

Table 28-5 Charge Description in device model

| Host Port | CHG_VALID     | PHY_CONNECT   | Description                   |
|-----------|---------------|---------------|-------------------------------|
| DCP       | 1             | 0             | Support charge, not connected |
| CDP       | 1             | 1             | Support charge, connected     |
| SDP       | 0             | 1             | Not support charge, connected |
| ACA       | Not supported | Not supported | Not supported                 |

Table 错误!文档中没有指定样式的文字。-1 Charge Description in host model

| Host Port | Device Port        | CHG_VALID | PHY_CONNECT |
|-----------|--------------------|-----------|-------------|
| DCP       | support charge     | 1         | 0           |
| DCP       | not support charge | 0         | 0           |
| CDP       | support charge     | 1         | 1           |
| CDP       | not support charge | 0         | 1           |
| SDP       | -                  | 0         | 1           |

In device application, DCP, CDP and SDP can be detected and ACA is not supported. In host application, host can be configured as DCP, CDP and SDP.

## 28.6.4 OTG Programming Model

When detect ID change event (see TOP GRF) or VBUS change event (see TOP GRF) after disconnect, it means a USB2 OTG A device or B device may connect, then check status of ID(see TOP GRF). If ID==0, it will work as A device, then follow host programming flow; if ID==1, it will work as B device, then it follow device programming flow.

Note: USB2.0 OTG doesn't support host/device mode swapping through HNP and RSP.

1.1.1

## Chapter 29 USB2.0 Host

### 29.1 Overview

USB2.0 host controller supports fully USB2.0 functions with one EHCI host controller and one OHCI host controller, and each host controller has one USB port. OHCI host controller only supports full-speed and low-speed mode and is used for full-speed devices and low-speed devices. EHCI only supports high-speed mode and is used for high-speed devices. OHCI host controller and EHCI host controller shares the same USB port, EHCI host controller will auto select the owner (OHCI or EHCI) of this USB port depending on the speed mode of attached devices, when selecting OHCI as owner, OHCI host controller will serve for the attached device; when selecting EHCI as owner, EHCI host controller will serve for the attached device.

USB2.0 Host Controller supports the following features:

- Compatible Specifications
    - Universal Serial Bus Specification, Revision 2.0
    - Enhanced Host Controller Interface Specification (EHCI), Revision 1.0
    - Open Host Controller Interface Specification (OHCI), Revision 1.0a
- Support High-speed (480Mbps), Full-speed (12Mbps) and Low-speed (1.5Mbps)

### 29.2 Block Diagram

USB2.0 Host Controller comprises with:

- EHCI Host Controller: Perform High-speed transactions
- OHCI Host Controller: Perform full/low-speed transactions
- Port Routing Control: Select EHCI Host Controller or OHCI Host Controller



Fig. 29-1 USB2.0 Host Controller Block Diagram

### 29.3 Function Description

#### 29.3.1 EHCI Host Controller

It performs descriptors and data read or write from or to system memory and packs or unpack USB transactions from or to UTMI+ interface defined in EHCI specification for high-speed data transmission.

#### 29.3.2 OHCI Host Controller

It performs descriptors and data read/write from/to system memory and packs or un-pack USB transactions from or to UTMI+ interface defined in OHCI specification for full-speed or low-speed data transmission.

### 29.3.3 Port Routing Control

As part of logic in the EHCI host controller, it is used to auto-select EHCI or OHCI host controller to serve the attached device depending on the speed of the attached device.

## 29.4 Register Description

### 29.4.1 Internal Address Mapping

Slave address can be divided into different length for different usage, which is shown as follows.

Table 29-1 USB2.0 Host Controller Address Mapping

| Base Address[16] | Device | Address Length | Offset Address Range |
|------------------|--------|----------------|----------------------|
| 1'b0             | EHCI   | 64K BYTE       | 0x00000 ~ 0xfffff    |
| 1'b1             | OHCI   | 64K BYTE       | 0x10000 ~ 0x1fffff   |

EHCI and OHCI register definitions, please refer to Enhanced Host Controller Interface Specification (EHCI), Revision 1.0 and Open Host Controller Interface Specification (OHCI), Revision 1.0a.

## 29.5 Interface Description

Table 29-2 USB2.0 PHY Interface Description

| Module Pin | Direction | Pin Name      | Descriptions                                                                                 |
|------------|-----------|---------------|----------------------------------------------------------------------------------------------|
| DP         | I/O       | HOST_DP       | USB differential signal IO, positive end                                                     |
| DM         | I/O       | HOST_DM       | USB differential signal IO, negative end                                                     |
| VCCA18     | I/O       | HOST_AVDD_1V8 | 1.8V power supply                                                                            |
| RREF       | I/O       | HOST_EXTR     | External 200ohm Bias Resistance, this is the 200ohm external resistance pin for termination. |
| AGND       | I/O       | VSS           | Ground IO for both 3.3V, 1.8V and 0.8V                                                       |
| ACCA33     | I/O       | USB_AVDD3V3   | 3.3 V power supply(only Full speed driver)                                                   |
| VDDA       | I/O       | USB_AVDD_0V8  | 0.8 V power supply                                                                           |

## 29.6 Application Notes

### 29.6.1 Some Settings and Description About USB PHY

Here list some usbhost phy configure register of TOP\_GRF in detail.

- GRF\_USBPHY\_CON2

Table 29-3 GRF\_USBPHY\_CON2 Description

| 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         | RW          | 0x0                | <p>usbhost_id_pull_up<br/>Software configure for HOSTPHY id_pull_up<br/>Enable ID pin sample. Signal that enables the sampling of the analog ID line.<br/>1'b0: Sampling of ID pin is disabled (IDDIG force to low).<br/>1'b1: Sampling of ID pin is enabled.</p>                                                                                                                                                                                                                                                                   |
| 14         | RW          | 0x0                | <p>usbhost_dischrgvbus<br/>Software configure for HOSTPHY dischrgvbus<br/>Discharge VBUS18. The signal enables discharging VBUS18.<br/>1'b0: do not discharge VBUS18 through a resistor<br/>1'b1: discharge VBUS18 through a resistor (this has to be active for at least 50ms)</p>                                                                                                                                                                                                                                                 |
| 13         | RW          | 0x0                | <p>usbhost_chrgvbus<br/>Software configure for HOSTPHY chrgvbus<br/>Charge VBUS18. The signal enables charging VBUS18.<br/>1'b0: do not charge VBUS18 through a resistor<br/>1'b1: charge VBUS18 through a resistor (this has to be active for at least 30ms)</p>                                                                                                                                                                                                                                                                   |
| 12         | RW          | 0x0                | <p>usbhost_txbitstuff_enable<br/>Software configure for HOSTPHY txbitstuff_enable<br/>TX BITSTUFF ENABLE. Indicates if the data on the DATA_OUT[15:0]lines need to be bit stuffed or not.<br/>1'b0: Bit stuffing is disabled<br/>1'b1: Bit stuffing is enabled<br/>This signal is only used when OP_MODE[1:0] is set to 11b.</p>                                                                                                                                                                                                    |
| 11         | RW          | 0x1                | <p>usbhost_otg_suspenddm<br/>Software configure for HOSTPHY suspend<br/>This signal is used for VBUS negotiation in OTG application and HOST disconnect in HOST application, in DEVICE mode this signal should be tie to 0. In OTG/HOST application this signal should be connected to 1.<br/>In HOST application, IDDIG is not valid, OTG_SUSPENDDM must be set to 1 and OTG_SUSPENDDM_BYPS must set to 1.<br/>In DEVICE application, IDDIG is not valid, OTG_SUSPENDDM must be set to 0 and OTG_SUSPENDDM_BYPS must set to 1.</p> |
| 10         | RW          | 0x1                | <p>usbhost_data_bus16_8<br/>Software configure for HOSTPHY data_bus16_8<br/>Selects between 8 and 16-bit data transfer.<br/>1'b1: 16-bit data path operation enabled, CLK60_30 = 30 MHz.<br/>1'b0: 8-bit data path operation enabled, CLK60_30 = 60 MHz.<br/>This signal is sampled by USB PHY IP macro cell only when RESET becomes low.<br/>Default is 16-bit model and not suggest to configure this bit.</p>                                                                                                                    |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | RW          | 0x0                | usbhost_pll_en<br>Software configure for HOSTPHY pll_en<br>PLL enable signal, internal PLL start to work when this signal is set to high, otherwise PLL is disabled and PHY IP stop working.<br>This bit must be set to high before usb function.                                                                                                                                            |
| 8          | RW          | 0x1                | usbhost_chg_RST<br>Software configure for HOSTPHY chg_RST<br>Charge detector reset signal, active high, asynchronous.<br>1'b0: charge detector is normal operation<br>1'b1: charge detector is reset to initial                                                                                                                                                                              |
| 7          | RW          | 0x0                | usbhost_chg_en<br>Software configure for HOSTPHY chg_en<br>Charge detector enable signal.<br>1'b0: charging detect is off, IP is configured as SDP in HOST application or is configured as standard device in DEVICE application<br>1'b1: charging detect is on, IP is configured as CDP in HOST application or is configured as portable device in DEVICE application                       |
| 6          | RW          | 0x1                | usbhost_termselect<br>Software configure for HOSTPHY termselect<br>Termination Select. This signal selects between the FS and HS terminations:<br>1'b0: HS termination enabled<br>1'b1: FS termination enabled<br>In default this is controlled by hardware.                                                                                                                                 |
| 5:4        | RW          | 0x1                | usbhost_xcvrselect<br>Software configure for HOSTPHY xcvrselect<br>Transceiver Select.<br>2'b00: HS Transceiver enabled<br>2'b01: FS Transceiver enabled<br>2'b10: LS Transceiver enabled<br>2'b11: Reserved<br>In default this is controlled by hardware.                                                                                                                                   |
| 3:2        | RW          | 0x0                | usbhost_opmode<br>Software configure for HOSTPHY opmode<br>Operational Mode. These signals select between various operational modes:<br>2'b00: Normal operation<br>2'b01: Non-driving. Transmitter buffer is in high impedance and pull-up/down resistors are disconnected<br>2'b10: Disable bit stuffing and NRZI encoding<br>2'b11: Reserved<br>In default this is controlled by hardware. |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                     |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | RW   | 0x0         | usbhost_suspend_n<br>Software configure for HOSTPHY suspend_n<br>Active low, asynchronous. When enabled, drive IP into suspend mode and consume minimal current from power supply.<br>1'b0: IP in suspend mode, only those circuit that serve for resume function is still active<br>1'b1: IP in normal operation<br>In default this is controlled by hardware. |
| 0   | RW   | 0x0         | hostphy_input_sel<br>HOSTPHY input selection.<br>1'b0: Hardware input<br>1'b1: Software input                                                                                                                                                                                                                                                                   |

## 29.6.2 USB Host Reset Sequence

In USB function mode, the recommended reset sequence is in figure1-2. 'RST' is the reset signal of USB controller and 'CLK' is the main clock of USB controller. At first, 'RST' is set to 1 and USB controller starts to work; secondly, USB controller outputs 'SUSPENDM'. 'RESET' is the reset of the usb phy. Both 'RST' and 'RESET' are controlled by CRU model.

'SUSPENDM' is set to 1 firstly to enable PLL, PLL starts to work and frequency starts locking, 'RESET' is set to 0 to enable clock lock detector, and 'CLK60\_30' is valid when frequency is stable. PLL lock time(Tlock) is about 500us including the time of bandgap building, PLL locking and so on, Tlock also includes the PVT range.

'CLK\_480' is controlled by 'PLL\_EN', and 'CLK\_480' is not valid when 'PLL\_EN' is 0. Because 'PLL\_EN' is the reset signal of delay control cell, so there must be a rise edge of 'PLL\_EN' to make delay control cell to work correctly. Tdelay is the time of 'PLL\_EN' rise edge to 'CLK\_480' transmitting 480MHz clock, the value is greater than 200us and less than 500us.



Fig. 29-2 USB2.0 Host reset sequence

## 29.6.3 Host Charge Detect Sequence

There are three steps in charge detector sequence including data contact detection, primary detection and secondary detection. Data contact detection is judging DEVICE are connected

or not, primary detection is judging whether the charger is connected or not, secondary detection is judging whether the charger is DCP or CDP.

When 'CHG\_EN' is set to 1, 'CHG\_RST' is set to 0 to start charge detection. This two signal can be control by GRF\_USBPHY\_CON2. During the detection, 'RESET' must be set to 1, the PHY function is disable before 'PHY\_CONNECT' changes to 1. Tdelay is greater than 1ms.



Fig. 29-3 USB2.0 Host charge sequence

Table 1-4 and the description about charge model. Host can be configured as DCP, CDP and SDP.

Table 29-4 Charge Description in host model

| Host Port | Device Port        | CHG_VALID | PHY_CONNECT |
|-----------|--------------------|-----------|-------------|
| DCP       | support charge     | 1         | 0           |
| DCP       | not support charge | 0         | 0           |
| CDP       | support charge     | 1         | 1           |
| CDP       | not support charge | 0         | 1           |
| SDP       | -                  | 0         | 1           |

## 29.6.4 Program Flow

Please refer to Enhanced Host Controller Interface Specification (EHCI), Revision 1.0 and Open Host Controller Interface Specification (OHCI), Revision 1.0a.

## Chapter 30 Gigabit Media Access Controller (GMAC)

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

#### 30.1.1 MAC Features

##### 30.1.1.1 MAC Tx and Rx Common Features

- Supports 10/100/1000-Mbps data transfer rates with the RGMII interfaces
- Supports 10/100-Mbps data transfer rates with the RMII interfaces
- Half-duplex operation:
- CSMA/CD Protocol support
- Flow control using backpressure 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
- Standard IEEE 802.3az-2010 for Energy Efficient Ethernet in Reduced Gigabit Media Independent Interface (RGMII) PHYs
- 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)
- Support Ethernet packet timestamping as described in IEEE 1588-2002 and IEEE 1588-2008 (64-bit timestamps given in the Tx or Rx status of PTP packet). Both one-step and two-step timestamping is supported in TX direction
- Media clock generation and recovery
- MDIO (Clause 22 and Clause 45) master interface for PHY device configuration and management

##### 30.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)
- Frame Preemption for MAC Tx

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

### 30.1.2 MTL Features

#### 30.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)

### **30.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

### **30.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
- 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

### **30.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
- 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

## 30.2 Block Diagram



Fig. 30-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 supports the PHY interfaces of reduced GMII (RGMII) and 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. 30-2 GMAC in SOC

GMAC Supports 10/100/1000-Mbps data transfer rates with the RGMII interfaces and Supports 10/100-Mbps data transfer rates with the RMII interfaces.

## 30.3 Function Description

### 30.3.1 Frame Structure

Data frames transmitted shall have the frame format shown in Fig.1-3.

<inter-frame><preamble><sfd><data><efd>

Fig. 30-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.

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

#### 30.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. 30-4 RMII Transmission Bit Ordering

### 30.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. 30-5 Start of MII and RMII Transmission in 100-Mbps Mode



Fig. 30-6 End of MII and RMII Transmission in 100-Mbps Mode



Fig. 30-7 Start of MII and RMII Transmission in 10-Mbps Mode



Fig. 30-8 End of MII and RMII Transmission in 10-Mbps Mode

### 30.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. 30-9 RMII Receive Bit Ordering

### 30.3.1.5 RGMII Interface

The Reduced Gigabit Media Independent Interface (RGMII) specification reduces the pin count of the interconnection between the GMAC 10/100/1000 controller and the PHY for GMII and MII interfaces. To achieve this, the data path and control signals are reduced and multiplexed together with both the edges of the transmission and receive clocks. For gigabit operation the clocks operate at 125 MHz; for 10/100 operation, the clock rates are 2.5 MHz/25 MHz.

In the GMAC 10/100/1000 controller, the RGMII module is instantiated between the GMAC core's GMII and the PHY to translate the control and data signals between the GMII and RGMII protocols.

The RGMII block has the following characteristics:

- Supports 10-Mbps, 100-Mbps, and 1000-Mbps operation rates
- For the RGMII block, no extra clock is required because both the edges of the incoming clocks are used
- The RGMII block extracts the in-band (link speed, duplex mode and link status) status signals from the PHY and provides them to the GMAC core logic for link detection

### 30.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 30-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<br/>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. <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 30-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           | 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<br/>Where Z is the tri-state level</li> </ul> |
| DATA/ADDRESS | Any 16-bit value: <ul style="list-style-type: none"> <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.

### **30.3.3 Power Management and Energy Efficient Ethernet**

The GMAC supports the following techniques to save power.

- Magic Packet
- Remote Wakeup
- Energy Efficient Ethernet

The Magic Packet and Remove Wakeup techniques are used to save power in the host system when it is idle (Sleep mode) and has to be woken up only at the reception of specific packets from the Ethernet network. In the Sleep mode, the power to the host logic along with majority of the GMAC (except the MAC receiver logic), can be shut down. On receiving the specific packets from the network, the MAC provides the trigger to restore the power to the host system and come back to normal state.

The Energy Efficient Ethernet (EEE) mode is compliant with the IEEE 802.3az-2010 standard. It is primarily targeted to save power in the Ethernet port when there is no traffic on the line. In this mode, the host indicates to the far-end that it does not have any packets to transmit for near future and puts the transmitter port (MAC Controller, PCS and PHY layers) into low-power mode. Similarly, the Receiver port can also be put into low-power mode when the far-end host indicates that it does not have any traffic to transfer. This allows significant saving of power in the Ethernet port (mainly in the PHY) with intermittent and bursty traffic profile. The triggering of entry and exit out of the EEE mode is controlled by the MAC and is supported within the GMAC.

Simultaneous operation of the EEE mode along with any or both the other power saving modes is also supported in GMAC.

### **30.3.4 IEEE 1588 Timestamp Support**

The IEEE 1588 defines a Precision Time Protocol (PTP) which enables precise synchronization of time in measurement and control systems. This protocol enables heterogeneous systems that include clocks of varying inherent precision, resolution, and stability to synchronize. The protocol supports system-wide synchronization accuracy in the sub-microsecond range with minimal network and local clock computing resources.

The GMAC supports the IEEE 1588-2002 (version 1) and IEEE 1588-2008 (version 2). The IEEE 1588-2002 supports PTP transported over UDP/IP and IEEE 1588-2008 supports PTP transported over Ethernet. The GMAC provides programmable support for both standards.

The controller supports the following features:

- Provides an option to take snapshot of all packets or only PTP type packets
- Provides an option to take snapshot of only event messages
- Provides an option to take the snapshot based on the clock type: ordinary, boundary, end-to-end transparent, and peer-to-peer transparent
- Provides an option to select the node to be a master or slave for ordinary and boundary clock
- Identifies the PTP message type, version, and PTP payload in packets sent directly over Ethernet and sends the status
- Provides an option to measure sub-second time in digital or binary format

### **30.3.5 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.

### **30.3.6 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.

## 30.4 Register Description

### 30.4.1 Registers Summary

| Name                              | Offset | Size | Reset Value | Description                                                                                                                                  |
|-----------------------------------|--------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC MAC Configuration</u>     | 0x0000 | W    | 0x00000000  | The MAC Configuration Register establishes the operating mode of the MAC                                                                     |
| <u>GMAC MAC Ext Configuration</u> | 0x0004 | W    | 0x00000000  | The MAC Extended Configuration Register establishes the operating mode of the MAC                                                            |
| <u>GMAC MAC Packet Filter</u>     | 0x0008 | W    | 0x00000000  | The MAC Packet Filter register contains the filter controls for receiving packets                                                            |
| <u>GMAC MAC Watchdog Timeout</u>  | 0x000c | W    | 0x00000000  | The Watchdog Timeout register controls the watchdog timeout for received packets                                                             |
| <u>GMAC MAC Hash Table Reg0</u>   | 0x0010 | W    | 0x00000000  | The Hash Table Register 0 contains the first 32 bits of the hash table                                                                       |
| <u>GMAC MAC Hash Table Reg1</u>   | 0x0014 | W    | 0x00000000  | The Hash Table Register 1 contains the second 32 bits of the hash table                                                                      |
| <u>GMAC MAC VLAN Tag</u>          | 0x0050 | W    | 0x00000000  | The VLAN Tag register identifies the IEEE 802.1Q VLAN type packets                                                                           |
| <u>GMAC MAC Q0 Tx Flow Ctrl</u>   | 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 |
| <u>GMAC MAC Rx Flow Ctrl</u>      | 0x0090 | W    | 0x00000000  | The Receive Flow Control register controls the pausing of MAC Transmit based on the received Pause packet                                    |
| <u>GMAC MAC Interrupt Status</u>  | 0x00b0 | W    | 0x00000000  | The Interrupt Status register contains the status of interrupts                                                                              |

| <b>Name</b>                          | <b>Offse t</b> | <b>Siz e</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                        |
|--------------------------------------|----------------|--------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC MAC Interrupt Enable</u>     | 0x00b4         | W            | 0x00000000         | The Interrupt Enable register contains the masks for generating the interrupts                                                                                                                                                                                            |
| <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 (wkuppkfilter_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 LPI Control Status</u>   | 0x00d0         | W            | 0x00000000         | The LPI Control and Status Register controls the LPI functions and provides the LPI interrupt status. The status bits are cleared when this register is read                                                                                                              |
| <u>GMAC MAC LPI Timers Control</u>   | 0x00d4         | W            | 0x03e80000         | The LPI Timers Control register controls the timeout values in the LPI states.                                                                                                                                                                                            |
| <u>GMAC MAC LPI Entry Timer</u>      | 0x00d8         | W            | 0x00000000         | This register controls the Tx LPI entry timer                                                                                                                                                                                                                             |
| <u>GMAC MAC 1US Tic Counter</u>      | 0x00dc         | W            | 0x00000063         | This register controls the generation of the Reference time (1 microsecond tic)                                                                                                                                                                                           |
| <u>GMAC MAC PHYIF Control Status</u> | 0x00f8         | W            | 0x00000000         | PHY Interface Control and Status Register                                                                                                                                                                                                                                 |
| <u>GMAC MAC Version</u>              | 0x0110         | W            | 0x00003051         | The version register identifies the version of the DWC_ether_qos                                                                                                                                                                                                          |

| <b>Name</b>                       | <b>Offse t</b> | <b>Siz e</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                  |
|-----------------------------------|----------------|--------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| <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            | 0x060171e7         | This register indicates the presence of first set of the optional features or functions                                             |
| <u>GMAC MAC HW Feature1</u>       | 0x0120         | W            | 0x010c01c8         | 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 |
| <u>GMAC MAC CSR SW Ctrl</u>       | 0x0230         | W            | 0x00000000         | This register contains SW programmable controls for changing the CSR access response and status bits clearing                       |
| <u>GMAC MAC Address0_High</u>     | 0x0300         | W            | 0x8000ffff         | The MAC Address0 High register holds the upper 16 bits of the first 6-byte MAC address of the station                               |
| <u>GMAC MAC Address0_Low</u>      | 0x0304         | W            | 0xffffffff         | The MAC Address0 Low register holds the lower 32 bits of the 6-byte first MAC address of the station                                |
| <u>GMAC MMC Control</u>           | 0x0700         | W            | 0x00000000         | This register establishes the operating mode of MMC                                                                                 |
| <u>GMAC MMC Rx Interrupt</u>      | 0x0704         | W            | 0x00000000         | Maintains the interrupts generated from all Receive statistics counters                                                             |
| <u>GMAC MMC Tx Interrupt</u>      | 0x0708         | W            | 0x00000000         | Maintains the interrupts generated from all Transmit statistics counters                                                            |
| <u>GMAC MMC Rx Interrupt Mask</u> | 0x070c         | W            | 0x00000000         | This register maintains the masks for interrupts generated from all Receive statistics counters                                     |
| <u>GMAC MMC Tx Interrupt Mask</u> | 0x0710         | W            | 0x00000000         | This register maintains the masks for interrupts generated from all Transmit statistics counters                                    |

| <b>Name</b>                            | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                             |
|----------------------------------------|---------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC Tx Octet Count Good Bad</u>    | 0x0714        | W           | 0x00000000         | This register provides the number of bytes transmitted by the DWC_ether_qos, exclusive of preamble and retried bytes, in good and bad packets                                  |
| <u>GMAC Tx Packet Count Good Bad</u>   | 0x0718        | W           | 0x00000000         | This register provides the number of good and bad packets, exclusive of retried packets                                                                                        |
| <u>GMAC Tx Underflow Error Packets</u> | 0x0748        | W           | 0x00000000         | This register provides the number of packets aborted because of packets underflow error                                                                                        |
| <u>GMAC Tx Carrier Error Packets</u>   | 0x0760        | W           | 0x00000000         | This register provides the number of packets aborted because of carrier sense error (no carrier or loss of carrier)                                                            |
| <u>GMAC Tx Octet Count Good</u>        | 0x0764        | W           | 0x00000000         | This register provides the number of bytes exclusive of preamble, only in good packets                                                                                         |
| <u>GMAC Tx Packet Count Good</u>       | 0x0768        | W           | 0x00000000         | This register provides the number of good packets transmitted by DWC_ether_qos                                                                                                 |
| <u>GMAC Rx Packets Count Good Bad</u>  | 0x0780        | W           | 0x00000000         | This register provides the number of good and bad packets received by DWC_ether_qos                                                                                            |
| <u>GMAC Rx Octet Count Good Bad</u>    | 0x0784        | W           | 0x00000000         | This register provides the number of bytes received by DWC_ether_qos, 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 DWC_ether_qos, 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 DWC_ether_qos with CRC error                                                                                          |
| <u>GMAC Rx Length Error Packets</u>    | 0x07c8        | W           | 0x00000000         | This register provides the number of packets received by DWC_ether_qos with length error (Length Type field not equal to packet size), for all packets with valid length field |
| <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                                                                           |

| <b>Name</b>                             | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                             |
|-----------------------------------------|---------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| <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 DWC_ether_qos 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 DWC_ether_qos 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 DWC_ether_qos                                                             |
| <u>GMAC RxIPv6 Header Error Packets</u> | 0x0828        | W           | 0x00000000         | This register provides the number of IPv6 datagrams received by DWC_ether_qos 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 DWC_ether_qos whose UDP payload has a checksum error                        |
| <u>GMAC RxTCP Error Packets</u>         | 0x083c        | W           | 0x00000000         | This register provides the number of good IP datagrams received by DWC_ether_qos 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 DWC_ether_qos 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 DWC_ether_qos 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 DWC_ether_qos 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 DWC_ether_qos in a UDP segment that had checksum errors                                 |

| <b>Name</b>                          | <b>Offse t</b> | <b>Siz e</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                       |
|--------------------------------------|----------------|--------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC RxTCP Error Octets</u>       | 0x087c         | W            | 0x00000000         | This register provides the number of bytes received by DWC_ether_qos 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 DWC_ether_qos in a good ICMP segment                                                                              |
| <u>GMAC MAC Timestamp Control</u>    | 0x0b00         | W            | 0x00002000         | This register controls the operation of the System Time generator and processing of PTP packets for timestamping in the Receiver                                         |
| <u>GMAC MAC Sub Second Increment</u> | 0x0b04         | W            | 0x00000000         | Specifies the value to be added to the internal system time register every cycle of clk_ptp_ref_i clock                                                                  |
| <u>GMAC MAC System Time Secs</u>     | 0x0b08         | W            | 0x00000000         | The System Time Nanoseconds register, along with System Time Seconds register, indicates the current value of the system time maintained by the MAC                      |
| <u>GMAC MAC System Time NS</u>       | 0x0b0c         | W            | 0x00000000         | The System Time Nanoseconds register, along with System Time Seconds register, indicates the current value of the system time maintained by the MAC                      |
| <u>GMAC MAC Sys Time Secs Update</u> | 0x0b10         | W            | 0x00000000         | The System Time Seconds Update register, along with the System Time Nanoseconds Update register, initializes or updates the system time maintained by the MAC            |
| <u>GMAC MAC Sys Time NS Update</u>   | 0x0b14         | W            | 0x00000000         | MAC System Time Nanoseconds Update register                                                                                                                              |
| <u>GMAC MAC Timestamp Addend</u>     | 0x0b18         | W            | 0x00000000         | Timestamp Addend register. This register value is used only when the system time is configured for Fine Update mode (TSCFUPDT bit in the MAC_Timestamp_Control register) |
| <u>GMAC MAC Timestamp Status</u>     | 0x0b20         | W            | 0x00000000         | Timestamp Status register. All bits except Bits[27:25] gets cleared when the application reads this register                                                             |
| <u>GMAC MAC Tx TS Status NS</u>      | 0x0b30         | W            | 0x00000000         | This register contains the nanosecond part of timestamp captured for Transmit packets when Tx status is disabled                                                         |

| <b>Name</b>                         | <b>Offset</b> | <b>Size</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                            |
|-------------------------------------|---------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>GMAC MAC Tx TS Status Secs</u>   | 0x0b34        | W           | 0x00000000         | The register contains the higher 32 bits of the timestamp (in seconds) captured when a PTP packet is transmitted                                              |
| <u>GMAC MAC Auxiliary Control</u>   | 0x0b40        | W           | 0x00000000         | The Auxiliary Timestamp Control register controls the Auxiliary Timestamp snapshot                                                                            |
| <u>GMAC MAC Auxiliary TS NS</u>     | 0x0b48        | W           | 0x00000000         | The Auxiliary Timestamp Nanoseconds register, along with MAC_Auxiliary_Timestamp_Seconds, gives the 64-bit timestamp stored as auxiliary snapshot             |
| <u>GMAC MAC Auxiliary TS Secs</u>   | 0x0b4c        | W           | 0x00000000         | The Auxiliary Timestamp - Seconds register contains the lower 32 bits of the Seconds field of the auxiliary timestamp register                                |
| <u>GMAC MAC TS Ingress Corr NS</u>  | 0x0b58        | W           | 0x00000000         | This register contains the correction value in nanoseconds to be used with the captured timestamp value in the ingress path                                   |
| <u>GMAC MAC TS Egress Corr NS</u>   | 0x0b5c        | W           | 0x00000000         | This register contains the correction value in nanoseconds to be used with the captured timestamp value in the egress path                                    |
| <u>GMAC MAC TS Ingress Latency</u>  | 0x0b68        | W           | 0x00000000         | This register holds the Ingress MAC latency                                                                                                                   |
| <u>GMAC MAC TS Egress Latency</u>   | 0x0b6c        | W           | 0x00000000         | This register holds the Egress MAC latency                                                                                                                    |
| <u>GMAC MAC PPS Control</u>         | 0x0b70        | W           | 0x00000000         | PPS Control register                                                                                                                                          |
| <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           | 0x00000018         | 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           | 0x003f0008         | The Queue 0 Transmit Operation Mode register establishes the Transmit queue operating modes and commands                                                      |

| Name                              | Offset | Size | Reset Value | Description                                                                                                                                                                                   |
|-----------------------------------|--------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GMAC MTL TxQ0 Underflow           | 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                  |
| GMAC MTL TxQ0 Debug               | 0x0d08 | W    | 0x00000000  | The Queue 0 Transmit Debug register gives the debug status of various blocks related to the Transmit queue                                                                                    |
| GMAC MTL Q0 Interrupt Ctrl Status | 0x0d2c | W    | 0x00000000  | This register contains the interrupt enable and status bits for the queue 0 interrupts                                                                                                        |
| GMAC MTL RxQ0 Operation Mode      | 0x0d30 | W    | 0x07f00000  | The Queue 0 Receive Operation Mode register establishes the Receive queue operating modes and command                                                                                         |
| GMAC MTL RxQ0 Miss Pkt Ovf Cnt    | 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 |
| GMAC MTL RxQ0 Debug               | 0x0d38 | W    | 0x00000010  | The Queue 0 Receive Debug register gives the debug status of various blocks related to the Receive queue                                                                                      |
| GMAC DMA Mode                     | 0x1000 | W    | 0x00000001  | The Bus Mode register establishes the bus operating modes for the DMA                                                                                                                         |
| GMAC DMA SysBus Mode              | 0x1004 | W    | 0x01010000  | The System Bus mode register controls the behavior of the AHB or AXI master                                                                                                                   |
| GMAC DMA Interrupt Status         | 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                   |
| GMAC DMA Debug Status0            | 0x100c | W    | 0x00000000  | The Debug Status 0 register gives the Receive and Transmit process status for DMA Channel 0-Channel 2 for debugging purpose                                                                   |
| GMAC AXI LPI Entry Interval       | 0x1040 | W    | 0x00000000  | This register is used to control the AXI LPI entry interval                                                                                                                                   |

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

### 30.4.2 Detail Registers Description

#### GMAC MAC Configuration

Address: Operational Base + offset (0x0000)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>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.</p> <p>This bit is available only when the Enable IPv4 ARP Offload is selected.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: ARP Offload is disabled</li> <li>1'b1: ARP Offload is enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 30:28      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 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:</p> <ul style="list-style-type: none"> <li>1'b0: IP header/payload checksum checking is disabled</li> <li>1'b1: IP header/payload checksum checking is enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                           |
| 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:</p> <ul style="list-style-type: none"> <li>3'b000: 96 bit times IPG</li> <li>3'b001: 88 bit times IPG</li> <li>3'b010: 80 bit times IPG</li> <li>3'b011: 72 bit times IPG</li> <li>3'b100: 64 bit times IPG</li> <li>3'b101: 56 bit times IPG</li> <li>3'b110: 48 bit times IPG</li> <li>3'b111: 40 bit times IPG</li> </ul> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:</p> <p>1'b0: Giant Packet Size Limit Control is disabled<br/>1'b1: Giant Packet Size Limit Control is enabled</p> |
| 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.</p> <p>Note: When the JE bit is set, setting this bit has no effect on the giant packet status.</p> <p>Values:</p> <p>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.</p> <p>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:</p> <p>1'b0: CRC stripping for Type packets is disabled<br/>1'b1: CRC stripping for Type packets is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.</p> <p>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:</p> <p>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:</p> <p>1'b0: Watchdog is enabled<br/>1'b1: Watchdog is disabled</p>                                                                                                                                                                                                                                                                                                                         |
| 18         | RW          | 0x0                | <p>BE<br/>Packet Burst Enable<br/>When this bit is set, the MAC allows packet bursting during transmission in the GMII half-duplex mode.</p> <p>Values:</p> <p>1'b0: Packet Burst is disabled<br/>1'b1: Packet Burst is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 17         | RW          | 0x0                | <p>JD<br/>Jabber Disable<br/>When this bit is set, the MAC disables the jabber timer on the transmitter. The MAC can transfer packets of up to 16,383 bytes. When this bit is reset, if the application sends more than 2,048 bytes of data (10,240 if JE is set high) during transmission, the MAC does not send rest of the bytes in that packet.</p> <p>Values:</p> <p>1'b0: Jabber is enabled<br/>1'b1: Jabber is disabled</p>                                                                                                                                                                                                                                                                                                                           |
| 16         | RW          | 0x0                | <p>JE<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.</p> <p>Values:</p> <p>1'b0: Jumbo packet is disabled<br/>1'b1: Jumbo packet is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | <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.</p> <p>Values:<br/>1'b0: For 1000 or 2500 Mbps operations<br/>1'b1: For 10 or 100 Mbps operations</p> |
| 14         | RW          | 0x0                | <p><b>FES</b><br/>Speed<br/>This bit selects the speed mode. The mac_speed_o[0] signal reflects the value of this bit.</p> <p>Values:<br/>1'b0: 10 Mbps when PS bit is 1 and 1 Gbps when PS bit is 0<br/>1'b1: 100 Mbps when PS bit is 1 and 2.5 Gbps when PS bit is 0</p>                                                                                                                                                                                                                                         |
| 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.</p> <p>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.</p> <p>Values:<br/>1'b0: Loopback is disabled<br/>1'b1: Loopback is enabled</p>                                                                                                                                                                     |
| 11         | RW          | 0x0                | <p><b>ECRSFD</b><br/>Enable Carrier Sense Before Transmission in Full-Duplex Mode<br/>When this bit is set, the MAC transmitter checks the CRS signal before packet transmission in the full-duplex mode. The MAC starts the transmission only when the CRS signal is low. When this bit is reset, the MAC transmitter ignores the status of the CRS signal.</p> <p>Values:<br/>1'b0: ECRSFD is disabled<br/>1'b1: ECRSFD is enabled</p>                                                                           |
| 10         | RW          | 0x0                | <p><b>DO</b><br/>Disable Receive Own<br/>When this bit is set, the MAC disables the reception of packets when the gmii_txen_o is asserted in the half-duplex mode. When this bit is reset, the MAC receives all packets given by the PHY. This bit is not applicable in the full-duplex mode.</p> <p>Values:<br/>1'b0: Enable Receive Own<br/>1'b1: Disable Receive Own</p>                                                                                                                                        |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | RW   | 0x0         | <p>DCRS<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.</p> <p>When this bit is reset, the MAC transmitter generates errors because of Carrier Sense. The MAC can even abort the transmission.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Enable Carrier Sense During Transmission</li> <li>1'b1: Disable Carrier Sense During Transmission</li> </ul>                                           |
| 8   | RW   | 0x0         | <p>DR<br/>Disable Retry<br/>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<br/>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> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. 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> |
| 3:2 | RW   | 0x0         | <p>PRELEN<br/>Preamble Length for Transmit packets</p> <p>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   | RW   | 0x0         | <p>TE<br/>Transmitter Enable</p> <p>When this bit is set, the Tx state machine of the MAC is enabled for transmission on the GMII or MII interface. When this bit is reset, the MAC Tx state machine is disabled after it completes the transmission of the current packet. The Tx state machine does not transmit any more packets.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Transmitter is disabled</li> <li>1'b1: Transmitter is enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0   | RW   | 0x0         | <p>RE<br/>Receiver Enable</p> <p>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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.<br/>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> <p>8'h00 - 104 bit times<br/>8'h01 - 112 bit times<br/>8'h02 - 120 bit times<br/>-----<br/>8'hFF - 2144 bit times</p>                                                                                                                                                                                                                                                                                                                                                  |
| 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:<br/>1'b0: Extended Inter-Packet Gap is disabled<br/>1'b1: Extended Inter-Packet Gap is enabled</p> |
| 23:19      | RO          | 0x00               | 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:<br/>1'b0: Unicast Slow Protocol Packet Detection is disabled<br/>1'b1: Unicast Slow Protocol Packet Detection is enabled</p>                                                                                                                             |
| 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:<br/>1'b0: Slow Protocol Detection is disabled<br/>1'b1: Slow Protocol Detection is enabled</p>                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.<br/>Values:<br/>1'b0: CRC Checking is enabled<br/>1'b1: CRC Checking is disabled</p>                                                                                                                                                                                                                                                                                                                   |
| 15:14      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13:0       | RW          | 0x0000             | <p>GPSL<br/>Giant Packet Size Limit<br/>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:17      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                          |
| 16         | RW          | 0x0                | <p>VTFE<br/>VLAN Tag Filter Enable<br/>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.<br/>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<br/>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.<br/>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><b>PCF</b><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><b>DBF</b><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><b>PM</b><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><b>DAIF</b><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><b>HMC</b><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>                                                                                                     |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RW          | 0x0                | <p>HUC<br/>Hash Unicast</p> <p>When this bit is set, the MAC performs the destination address filtering of unicast packets according to the hash table. When this bit is reset, the MAC performs a perfect destination address filtering for unicast 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 Unicast is disabled</li> <li>1'b1: Hash Unicast is enabled</li> </ul> |
| 0          | RW          | 0x0                | <p>PR<br/>Promiscuous Mode</p> <p>When this bit is set, the Address Filtering module passes all incoming packets irrespective of the destination or source address. The SA or DA Filter Fails status bits of the Rx Status Word are always cleared when PR is set.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Promiscuous Mode is disabled</li> <li>1'b1: Promiscuous Mode is enabled</li> </ul>                                                                  |

**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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 8          | RW          | 0x0                | <p>PWE<br/>Programmable Watchdog Enable</p> <p>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:</p> <ul style="list-style-type: none"> <li>1'b0: Programmable Watchdog is disabled</li> <li>1'b1: Programmable Watchdog is enabled</li> </ul> |
| 7:4        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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<br/>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<br/>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<br/>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.<br/>Values:<br/>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 Q0 Tx Flow Ctrl**

Address: Operational Base + offset (0x0070)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 <code>sbd_flowctrl_i</code> or <code>mti_flowctrl_i</code>).<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> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4 | RW   | 0x0         | <p>PLT<br/>Pause Low Threshold<br/>This field configures the threshold of the Pause timer at which the input flow control signal mti_flowctrl_i (or sbd_flowctrl_i) is checked for automatic retransmission of the Pause packet. The threshold values should be always less than the Pause Time configured in Bits[31:16]. For example, if PT = 100H (256 slot times), and PLT = 001, a second Pause packet is automatically transmitted if the mti_flowctrl_i signal is asserted at 228 (256-28) slot times after the first Pause packet is transmitted.</p> <p>The following list provides the threshold values for different values. The slot time is defined as the time taken to transmit 512 bits (64 bytes) on the GMII or MII interface. This (approximate) computation is based on the packet size (64, 1518, 2000, 9018, 16384, or 32768) + 2 Pause Packet Size + IPG in Slot Times.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>3'b000: Pause Time minus 4 Slot Times (PT -4 slot times)</li> <li>3'b001: Pause Time minus 28 Slot Times (PT -28 slot times)</li> <li>3'b010: Pause Time minus 36 Slot Times (PT -36 slot times)</li> <li>3'b011: Pause Time minus 144 Slot Times (PT -144 slot times)</li> <li>3'b100: Pause Time minus 256 Slot Times (PT -256 slot times)</li> <li>3'b101: Pause Time minus 512 Slot Times (PT -512 slot times)</li> <li>3'b110: Reserved</li> </ul> |
| 3:2 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 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:</p> <ul style="list-style-type: none"> <li>1'b0: Transmit Flow Control is disabled</li> <li>1'b1: Transmit Flow Control is enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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><b>Full-Duplex Mode:</b><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><b>Half-Duplex Mode:</b><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><b>Values:</b><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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 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><b>Values:</b><br/>1'b0: Unicast Pause Packet Detect disabled<br/>1'b1: Unicast Pause Packet Detect enabled</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>RFE<br/>Receive Flow Control Enable</p> <p>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:</p> <ul style="list-style-type: none"> <li>1'b0: Receive Flow Control is disabled</li> <li>1'b1: Receive Flow Control is enabled</li> </ul> |

**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</p> <p>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:</p> <ul style="list-style-type: none"> <li>1'b0: MDIO Interrupt status not active</li> <li>1'b1: MDIO Interrupt status active</li> </ul> |
| 17:15      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14         | RO          | 0x0                | <p>RXSTSIS<br/>Receive Status Interrupt</p> <p>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> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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         | <p><b>TSIS</b><br/>Timestamp Interrupt Status<br/>If the Timestamp feature is enabled, this bit is set when any of the following conditions is true:</p> <ol style="list-style-type: none"> <li>1. The system time value is equal to or exceeds the value specified in the Target Time High and Low registers.</li> <li>2. There is an overflow in the Seconds register.</li> <li>3. The Target Time Error occurred, that is, programmed target time already elapsed.</li> </ol> <p>If the Auxiliary Snapshot feature is enabled, this bit is set when the auxiliary snapshot trigger is asserted. In configurations other than EQOS_CORE, when drop transmit status is enabled in MTL, this bit is set when the captured transmit timestamp is updated in the MAC_Tx_Timestamp_Status_Nanoseconds and Mac_TxTimestamp_Status_Seconds registers. When PTP offload feature is enabled, this bit is set when the captured transmit timestamp is updated in the MAC_Tx_Timestamp_Status_Nanoseconds and MAC_Tx_Timestamp_Status_Seconds registers, for PTO generated Delay Request and Pdelay request packets. 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_Timestamp_Status register.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Timestamp Interrupt status not active</li> <li>1'b1: Timestamp Interrupt status active</li> </ul> |
| 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>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10         | RO          | 0x0                | <p><b>MMCTXIS</b><br/> <b>MMC Transmit Interrupt Status</b><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:<br/> 1'b0: MMC Transmit Interrupt status not active<br/> 1'b1: MMC Transmit Interrupt status active</p>                                                                                                                                                                                                                                              |
| 9          | RO          | 0x0                | <p><b>MMCRXIS</b><br/> <b>MMC Receive Interrupt Status</b><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.</p> <p>Values:<br/> 1'b0: MMC Receive Interrupt status not active<br/> 1'b1: MMC Receive Interrupt status active</p>                                                                                                                                                                                                                                                  |
| 8          | RO          | 0x0                | <p><b>MMCIS</b><br/> <b>MMC Interrupt Status</b><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.</p> <p>Values:<br/> 1'b0: MMC Interrupt status not active<br/> 1'b1: MMC Interrupt status active</p>                                                                                                                                                                                                                                                                                                                           |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5          | RO          | 0x0                | <p><b>LPIIS</b><br/> <b>LPI Interrupt Status</b><br/> When the Energy Efficient Ethernet feature is enabled, this bit is set for any LPI state entry or exit in the MAC Transmitter or Receiver. This bit is cleared when the corresponding interrupt source bit of MAC_LPI_Control_Status register is read (or corresponding interrupt source bit of MAC_LPI_Control_Status register is written to 1 when RCWE bit of MAC_CSR_SW_Ctrl register is set).</p> <p>Values:<br/> 1'b0: LPI Interrupt status not active<br/> 1'b1: LPI Interrupt status active</p>                                                                                                                                      |
| 4          | RO          | 0x0                | <p><b>PMTIS</b><br/> <b>PMT Interrupt Status</b><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).</p> <p>This bit is valid only when you select the Enable Power Management option.</p> <p>Values:<br/> 1'b0: PMT Interrupt status not active<br/> 1'b1: PMT Interrupt status active</p> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:1 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0   | RO   | 0x0         | <p>RGSMMIIS<br/>RGMII or SMII Interrupt Status<br/>This bit is set because of any change in value of the Link Status of RGMII or SMII interface (LNKSTS bit in MAC_PHYIF_Control_Status register). This bit is cleared when the MAC_PHYIF_Control_Status register is read (or LNKSTS bit of MAC_PHYIF_Control_Status register is written to 1 when RCWE bit of MAC_CSR_SW_Ctrl register is set). This bit is valid only when you select the optional RGMII or SMII PHY interface.<br/>Values:<br/>1'b0: RGMII or SMII Interrupt Status is not active<br/>1'b1: RGMII or SMII Interrupt Status is active</p> |

**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 MDIOS 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                                                                                                                                                                                                                                                                                                                |
| 14    | RW   | 0x0         | <p>RXSTSIE<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.<br/>Values:<br/>1'b0: Receive Status Interrupt is disabled<br/>1'b1: Receive Status Interrupt is enabled</p>      |
| 13    | RW   | 0x0         | <p>TXSTSIE<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.<br/>Values:<br/>1'b0: Timestamp Status Interrupt is disabled<br/>1'b1: Timestamp Status Interrupt is enabled</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | RW          | 0x0                | <p>TSIE<br/>Timestamp Interrupt Enable<br/>When this bit is set, it enables the assertion of the interrupt signal because of the setting of TSIS bit in MAC_Interrupt_Status register.<br/>Values:<br/>1'b0: Timestamp Interrupt is disabled<br/>1'b1: Timestamp Interrupt is enabled</p>                     |
| 11:6       | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                      |
| 5          | RW          | 0x0                | <p>LPIIE<br/>LPI Interrupt Enable<br/>When this bit is set, it enables the assertion of the interrupt signal because of the setting of LPIIS bit in MAC_Interrupt_Status register.<br/>Values:<br/>1'b0: LPI Interrupt is disabled<br/>1'b1: LPI Interrupt is enabled</p>                                     |
| 4          | RW          | 0x0                | <p>PMTIE<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.<br/>Values:<br/>1'b0: PMT Interrupt is disabled<br/>1'b1: PMT Interrupt is enabled</p>                                     |
| 3          | RW          | 0x0                | <p>PHYIE<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.<br/>Values:<br/>1'b0: PHY Interrupt is disabled<br/>1'b1: PHY Interrupt is enabled</p>                                     |
| 2:1        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                      |
| 0          | RW          | 0x0                | <p>RGSMIIIE<br/>RGMII or SMII Interrupt Enable<br/>When this bit is set, it enables the assertion of the interrupt signal because of the setting of RGSMIIIS bit in MAC_Interrupt_Status register.<br/>Values:<br/>1'b0: RGMII or SMII Interrupt is disabled<br/>1'b1: RGMII or SMII Interrupt is enabled</p> |

**GMAC MAC Rx Tx Status**

Address: Operational Base + offset (0x00b8)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8          | RO          | 0x0                | <p>RWT<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.</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> <p>1'b0: No receive watchdog timeout<br/>1'b1: Receive watchdog timed out</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5          | RO          | 0x0                | <p>EXCOL<br/>Excessive Collisions<br/>When the DTXSTS bit is set in the MTL_Operation_Mode register, this bit indicates that the transmission 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 the first collision and the packet transmission is aborted.</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> <p>1'b0: No collision<br/>1'b1: Excessive collision is sensed</p>         |
| 4          | RO          | 0x0                | <p>LCOL<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> <p>1'b0: No collision<br/>1'b1: Late collision is sensed</p>               |
| 3          | RO          | 0x0                | <p>EXDEF<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> <p>1'b0: No Excessive deferral<br/>1'b1: Excessive deferral</p>                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | RO          | 0x0                | <p>LCARR<br/>Loss of Carrier</p> <p>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> <p>1'b0: Carrier is present<br/>1'b1: Loss of carrier</p>                                    |
| 1          | RO          | 0x0                | <p>NCARR<br/>No Carrier</p> <p>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> <p>1'b0: Carrier is present<br/>1'b1: No carrier</p>                                                                                                                                                                                                       |
| 0          | RO          | 0x0                | <p>TJT<br/>Transmit Jabber Timeout</p> <p>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> <p>1'b0: No Transmit Jabber Timeout<br/>1'b1: Transmit Jabber Timeout occur</p> |

**GMAC MAC PMT Control Status**

Address: Operational Base + offset (0x00c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>RWKFILTRST<br/>Remote Wake-Up Packet Filter Register Pointer Reset</p> <p>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> <p>1'b0: Remote Wake-Up Packet Filter Register Pointer is not Reset<br/>1'b1: Remote Wake-Up Packet Filter Register Pointer is Reset</p> |
| 30:29      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28:24      | RO          | 0x00               | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 23:11      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 10         | RW          | 0x0                | RWKPFE<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.<br>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.<br>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br>Values:<br>1'b0: Remote Wake-up Packet Forwarding is disabled<br>1'b1: Remote Wake-up Packet Forwarding is enabled |
| 9          | RW          | 0x0                | 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.<br>Values:<br>1'b0: Global unicast is disabled<br>1'b1: Global unicast is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 8:7        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6          | RO          | 0x0                | 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.<br>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.<br>Values:<br>1'b0: Remote wake-up packet is received<br>1'b1: Remote wake-up packet is received                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:</p> <p>1'b0: No Magic packet is received<br/>1'b1: Magic packet is received</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4:3 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2   | RW   | 0x0         | <p>RWKPKTEN<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.</p> <p>Values:</p> <p>1'b0: Remote wake-up packet is disabled<br/>1'b1: Remote wake-up packet is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1   | RW   | 0x0         | <p>MGKPKTEN<br/>Magic Packet Enable<br/>When this bit is set, a power management event is generated when the MAC receives a magic packet.</p> <p>Values:</p> <p>1'b0: Magic Packet is disabled<br/>1'b1: Magic Packet is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0   | RW   | 0x0         | <p>PWRDWN<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.</p> <p>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.</p> <p>Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:</p> <p>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_Previous bit setting have complementary programming, then a frame may never pass the AND chained filter. For example, if Filter 2 And_Previous 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> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p><b>WKUPFRMFTR</b><br/> <b>RWK Packet Filter</b><br/> This field contains the various controls of RWK Packet filter. When the Remote Wakeup Filters are to be programmed, the entire set of wkuppkfilter_reg registers must be written. The wkuppkfilter_reg register is programmed by sequentially writing the eight, sixteen or thirty-two register values in MAC_RWK_Packet_Filter register for wkuppkfilter_reg0, wkuppkfilter_reg1, ..., wkuppkfilter_reg31 respectively. The wkuppkfilter_reg register is read in a similar way.</p> <p>The MAC updates the wkuppkfilter_reg register current pointer value in RWKPTR field of MAC_PMT_Control_Status register. The Remote Wakeup Filters are arranged in blocks of 4 filters each and each such block have eight 32-bit wide registers, viz. wkuppkfilter_reg0-7, wkuppkfilter_reg8-15, wkuppkfilter_reg16-23 and wkuppkfilter_reg24-31. The fields of Remote Wakeup Filter are described as follows:</p> <p><b>Filter i Command:</b> The 4-bit filter i command controls the filter i 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. 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>3. 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. The details are provided below: <ul style="list-style-type: none"> <li>(1) The And_Previous bit setting is applicable within a set of 4 filters.</li> <li>(2) Setting of And_Previous bit of filter that is not enabled has no effect, that is setting And_Previous bit of lowest number filter in the set of 4 filters has no effect. For example, setting of And_Previous bit of Filter 0 has no effect.</li> <li>(3) If And_Previous bit is set for filter to form AND chained filter, the AND chain breaks at the point any filter is not enabled. For example: If Filter 2 And_Previous bit is set (bit 1 in Filter 2 command is set) but Filter 1 is not enabled (bit 0 in Filter 1 command is reset), then only Filter 2 result is considered. If Filter 2 And_Previous bit is set (bit 1 in Filter 2 command is set), Filter 3 And_Previous bit is set (bit 1 in Filter 3 command is set), but Filter 1 is not enabled (bit 0 in Filter 1 command is reset), then only Filter 2 result ANDed with Filter 3 result is considered. If Filter 2 And_Previous bit is set (bit 1 in Filter 2 command is set), Filter 3 And_Previous bit is set (bit 1 in Filter 3 command is set), but Filter 2 is not enabled (bit 0 in Filter 2 command is reset), then since setting of Filter 2 And_Previous bit has no effect only Filter 1 result ORed with Filter 3 result is considered.</li> </ul> </li> </ol> |

**GMAC RWK Filter0 Byte Mask**

Address: Operational Base + offset (0x10c0)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | Filter0_Byt_Mask<br>Filter0 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 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_Byt_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_Byt_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_Byt_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               | Filter3_Offset<br>Filter3 Offset<br>This filter offset defines the offset (within the packet) from which the filter examines the packets.<br>1. This 8-bit pattern-offset is the offset for the filter first byte to be examined.<br>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.<br>3. The offset value 0 refers to the first byte of the packet. |
| 23:16      | RW          | 0x00               | Filter2_Offset<br>Filter2 Offset<br>This filter offset defines the offset (within the packet) from which the filter examines the packets.<br>1. This 8-bit pattern-offset is the offset for the filter first byte to be examined.<br>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.<br>3. The offset value 0 refers to the first byte of the packet. |
| 15:8       | RW          | 0x00               | Filter1_Offset<br>Filter1 Offset<br>This filter offset defines the offset (within the packet) from which the filter examines the packets.<br>1. This 8-bit pattern-offset is the offset for the filter first byte to be examined.<br>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.<br>3. The offset value 0 refers to the first byte of the packet. |
| 7:0        | RW          | 0x00               | Filter0_Offset<br>Filter0 Offset<br>This filter offset defines the offset (within the packet) from which the filter examines the packets.<br>1. This 8-bit pattern-offset is the offset for the filter first byte to be examined.<br>2. The minimum allowed offset is 12, which refers to the 13th byte of the packet.<br>3. The offset value 0 refers to the first byte of the packet. |

**GMAC RWK Filter Command**

Address: Operational Base + offset (0x10dc)

| <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:24      | RW          | 0x0                | <p>Filter3_Command<br/>Filter3 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_Prev) 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_Prev bit set.</li> <li>5. Bit 0 is the enable for filter. If Bit 0 is not set, filter is disabled.</li> </ol> |
| 23:20      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 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_Prev) 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_Prev 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3:0        | RW          | 0x0                | <p>Filter0_Command<br/>Filter0 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> |

**GMAC MAC LPI Control Status**

Address: Operational Base + offset (0x00d0)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21  | RW   | 0x0         | <p>LPITCSE<br/>LPI Tx Clock Stop Enable<br/>When this bit is set, the MAC asserts sbd_tx_clk_gating_ctrl_o signal high after it enters Tx LPI mode to indicate that the Tx clock to MAC can be stopped.<br/>When this bit is reset, the MAC does not assert sbd_tx_clk_gating_ctrl_o signal high after it enters Tx LPI mode. If RGMII Interface is selected, the Tx clock is required for transmitting the LPI pattern. The Tx Clock cannot be gated and so the LPITCSE bit cannot be programmed.</p> <p>Values:<br/>1'b0: LPI Tx Clock Stop is disabled<br/>1'b1: LPI Tx Clock Stop is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 20  | RW   | 0x0         | <p>LPIATE<br/>LPI Timer Enable<br/>This bit controls the automatic entry of the MAC Transmitter into and exit out of the LPI state. When LPIATE, LPITXA and LPIEN bits are set, the MAC Transmitter enters LPI state only when the complete MAC TX data path is IDLE for a period indicated by the MAC_LPI_Entry_Timer register. After entering LPI state, if the data path becomes non-IDLE (due to a new packet being accepted for transmission), the Transmitter exits LPI state but does not clear LPIEN bit. This enables the re-entry into LPI state when it is IDLE again. When LPIATE is 0, the LPI Auto timer is disabled and MAC Transmitter enters LPI state based on the settings of LPITXA and LPIEN bit descriptions.</p> <p>Values:<br/>1'b0: LPI Timer is disabled<br/>1'b1: LPI Timer is enabled</p>                                                                                                                                                                                                                                                        |
| 19  | RW   | 0x0         | <p>LPITXA<br/>LPI Tx Automate<br/>This bit controls the behavior of the MAC when it is entering or coming out of the LPI mode on the Transmit side. This bit is not functional in the EQOS-CORE configurations in which the Tx clock gating is done during the LPI mode.<br/>If the LPITXA and LPIEN bits are set to 1, the MAC enters the LPI mode only after all outstanding packets (in the core) and pending packets (in the application interface) have been transmitted. The MAC comes out of the LPI mode when the application sends any packet for transmission or the application issues a Tx FIFO Flush command. In addition, the MAC automatically clears the LPIEN bit when it exits the LPI state. If Tx FIFO Flush is set in the FTQ bit of MTL_TxQ0_Operation_Mode register, when the MAC is in the LPI mode, it exits the LPI mode. When this bit is 0, the LPIEN bit directly controls behavior of the MAC when it is entering or coming out of the LPI mode.</p> <p>Values:<br/>1'b0: LPI Tx Automate is disabled<br/>1'b1: LPI Tx Automate is enabled</p> |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18    | RW   | 0x0         | <p>PLSEN<br/>PHY Link Status Enable<br/>This bit enables the link status received on the RGMII, SGMII, or SMII Receive paths to be used for activating the LPI LS TIMER. When this bit is set, the MAC uses the link-status bits of the MAC_PHYIF_Control_Status register and the PLS bit for the LPI LS Timer trigger. When this bit is reset, the MAC ignores the link-status bits of the MAC_PHYIF_Control_Status register and takes only the PLS bit.</p> <p>Values:<br/>1'b0: PHY Link Status is disabled<br/>1'b1: PHY Link Status is enabled</p> |
| 17    | RW   | 0x0         | <p>PLS<br/>PHY Link Status<br/>This bit indicates the link status of the PHY. The MAC Transmitter asserts the LPI pattern only when the link status is up (OKAY) at least for the time indicated by the LPI LS TIMER. When this bit is set, the link is considered to be okay (UP) and when this bit is reset, the link is considered to be down.</p> <p>Values:<br/>1'b0: link is down<br/>1'b1: link is okay (UP)</p>                                                                                                                                 |
| 16    | RW   | 0x0         | <p>LPIEN<br/>LPI Enable<br/>When this bit is set, it instructs the MAC Transmitter to enter the LPI state. When this bit is reset, it instructs the MAC to exit the LPI state and resume normal transmission.<br/>This bit is cleared when the LPITXA bit is set and the MAC exits the LPI state because of the arrival of a new packet for transmission.</p> <p>Values:<br/>1'b0: LPI state is disabled<br/>1'b1: LPI state is enabled</p>                                                                                                             |
| 15:10 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9     | RO   | 0x0         | <p>RLPIST<br/>Receive LPI State<br/>When this bit is set, it indicates that the MAC is receiving the LPI pattern on the GMII or MII interface.</p> <p>Values:<br/>1'b0: Receive LPI state not detected<br/>1'b1: Receive LPI state detected</p>                                                                                                                                                                                                                                                                                                         |
| 8     | RO   | 0x0         | <p>TLPIST<br/>Transmit LPI State<br/>When this bit is set, it indicates that the MAC is transmitting the LPI pattern on the GMII or MII interface.</p> <p>Values:<br/>1'b0: Transmit LPI state not detected<br/>1'b1: Transmit LPI state detected</p>                                                                                                                                                                                                                                                                                                   |
| 7:4   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | <p>RLPIEX<br/>Receive LPI Exit<br/>When this bit is set, it indicates that the MAC Receiver has stopped receiving the LPI pattern on the GMII or MII interface, exited the LPI state, and resumed the normal reception. This bit is cleared by a read into this register (or this bit is written to 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set).<br/>Note: This bit may not be set if the MAC stops receiving the LPI pattern for a very short duration, such as, less than three clock cycles of CSR clock.</p> <p>Values:</p> <p>1'b0: Receive LPI exit not detected<br/>1'b1: Receive LPI exit detected</p> |
| 2          | RO          | 0x0                | <p>RLPIEN<br/>Receive LPI Entry<br/>When this bit is set, it indicates that the MAC Receiver has received an LPI pattern and entered the LPI state. This bit is cleared by a read into this register (or this bit is written to 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set).<br/>Note: This bit may not be set if the MAC stops receiving the LPI pattern for a very short duration, such as, less than three clock cycles of CSR clock.</p> <p>Values:</p> <p>1'b0: Receive LPI entry not detected<br/>1'b1: Receive LPI entry detected</p>                                                                   |
| 1          | RO          | 0x0                | <p>TLPPIEX<br/>Transmit LPI Exit<br/>When this bit is set, it indicates that the MAC transmitter exited the LPI state after the application cleared the LPIEN bit and the LPI TW Timer has expired. This bit is cleared by a read into this register (or this bit is written to 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set).</p> <p>Values:</p> <p>1'b0: Transmit LPI exit not detected<br/>1'b1: Transmit LPI exit detected</p>                                                                                                                                                                               |
| 0          | RO          | 0x0                | <p>TLPPIEN<br/>Transmit LPI Entry<br/>When this bit is set, it indicates that the MAC Transmitter has entered the LPI state because of the setting of the LPIEN bit. This bit is cleared by a read into this register (or this bit is written to 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set).</p> <p>Values:</p> <p>1'b0: Transmit LPI entry not detected<br/>1'b1: Transmit LPI entry detected</p>                                                                                                                                                                                                            |

**GMAC MAC LPI Timers Control**

Address: Operational Base + offset (0x00d4)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:16      | RW          | 0x3e8              | LST<br>LPI LS Timer<br>This field specifies the minimum time (in milliseconds) for which the link status from the PHY should be up (OKAY) before the LPI pattern can be transmitted to the PHY. The MAC does not transmit the LPI pattern even when the LPIEN bit is set unless the LPI LS Timer reaches the programmed terminal count. The default value of the LPI LS Timer is 1000 (1 sec) as defined in the IEEE standard. |
| 15:0       | RW          | 0x0000             | TWT<br>LPI TW Timer<br>This field specifies the minimum time (in microseconds) for which the MAC waits after it stops transmitting the LPI pattern to the PHY and before it resumes the normal transmission. The TLPTEX status bit is set after the expiry of this timer.                                                                                                                                                      |

**GMAC MAC LPI Entry Timer**

Address: Operational Base + offset (0x00d8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                 |
| 19:3       | RW          | 0x00000            | LPIET<br>LPI Entry Timer<br>This field specifies the time in microseconds the MAC waits to enter LPI mode, after it has transmitted all the frames. This field is valid and used only when LPITE and LPITXA are set to 1. Bits [2:0] are read-only so that the granularity of this timer is in steps of 8 micro-seconds. |

**GMAC MAC 1US Tic Counter**

Address: Operational Base + offset (0x00dc)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | reserved                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11:0       | RW          | 0x063              | TIC_1US_CNTR<br>1US TIC Counter<br>The application must program this counter so that the number of clock cycles of CSR clock is 1us. (Subtract 1 from the value before programming). For example if the CSR clock is 100MHz then this field needs to be programmed to value 100 - 1 = 99 (which is 0x63). This is required to generate the 1US events that are used to update some of the EEE related counters. |

**GMAC MAC PHYIF Control Status**

Address: Operational Base + offset (0x00f8)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                 |
| 19         | RO          | 0x0                | LNKSTS<br>Link Status<br>This bit indicates whether the link is up (1'b1) or down (1'b0).<br>Values:<br>1'b0: Link down<br>1'b1: Link up |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:17      | RO          | 0x0                | <p>LNKSPEED<br/>Link Speed<br/>This bit indicates the current speed of the link. Bit 2 is reserved when the MAC is configured for the SMII PHY interface.</p> <p>Values:<br/>2'b00: 2.5 MHz<br/>2'b01: 25 MHz<br/>2'b10: 125 MHz<br/>2'b11: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16         | RO          | 0x0                | <p>LNKMOD<br/>Link Mode<br/>This bit indicates the current mode of operation of the link.</p> <p>Values:<br/>1'b0: Half-duplex mode<br/>1'b1: Full-duplex mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15:2       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1          | RW          | 0x0                | <p>LUD<br/>Link Up or Down<br/>This bit indicates whether the link is up or down during transmission of configuration in the RGMII, SGMII, or SMII interface.</p> <p>Values:<br/>1'b0: Link down<br/>1'b1: Link up</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0          | RW          | 0x0                | <p>TC<br/>Transmit Configuration in RGMII, SGMII, or SMII<br/>When set, this bit enables the transmission of duplex mode, link speed, and link up or down information to the PHY in the RGMII, SMII, or SGMII port. When this bit is reset, no such information is driven to the PHY. The details of this feature are provided in the following sections:</p> <ol style="list-style-type: none"> <li>1. "Reduced Gigabit Media Independent Interface"</li> <li>2. "Serial Media Independent Interface"</li> <li>3. "Serial Gigabit Media Independent Interface"</li> </ol> <p>Values:<br/>1'b0: Disable Transmit Configuration in RGMII, SGMII, or SMII<br/>1'b1: Enable Transmit Configuration in RGMII, SGMII, or SMII</p> |

**GMAC MAC Version**

Address: Operational Base + offset (0x0110)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                               |
|------------|-------------|--------------------|------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                         |
| 15:8       | RW          | 0x30               | USERVER<br>User-defined Version (configured with coreConsultant) |
| 7:0        | RW          | 0x51               | SNPSVER<br>Synopsys-defined Version                              |

**GMAC MAC Debug**

Address: Operational Base + offset (0x0114)

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

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18:17      | RO          | 0x0                | 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 |
| 16         | RO          | 0x0                | 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                                                   |
| 15:3       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                               |
| 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                | RPESTS<br>MAC GMII or MII Receive Protocol Engine Status<br>When this bit is set, it indicates that the MAC GMII or MII receive protocol engine is actively receiving data, and it is not in the Idle state.<br>Values:<br>1'b0: MAC GMII or MII Receive Protocol Engine Status not detected<br>1'b1: MAC GMII or MII Receive Protocol Engine Status detected                                                          |

**GMAC\_MAC\_HW\_Feature0**

Address: Operational Base + offset (0x011c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28      | RO          | 0x0                | 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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27         | RO          | 0x0                | <p><b>SAVLANINS</b><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</p> |
| 26:25      | RO          | 0x3                | <p><b>TSSTSSEL</b><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</p>            |
| 24         | RO          | 0x0                | <p><b>MACADR64SEL</b><br/> MAC Addresses 64-127 Selected<br/> This bit is set to 1 when the Enable Additional 64 MAC Address Registers (64-127) option is selected.<br/> Values:<br/> 1'b0: MAC Addresses 64-127 Select option is not selected<br/> 1'b1: MAC Addresses 64-127 Select option is selected</p>                |
| 23         | RO          | 0x0                | <p><b>MACADR32SEL</b><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</p>                    |
| 22:18      | RO          | 0x00               | <p><b>ADDMACADRSEL</b><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.</p>                                                                                                                                          |
| 17         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                    |
| 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         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                    |
| 14         | RO          | 0x1                | <p><b>TXCOESEL</b><br/> Transmit Checksum Offload Enabled<br/> This bit is set to 1 when the Enable Transmit TCP/IP Checksum Insertion option is selected.<br/> Values:<br/> 1'b0: Transmit Checksum Offload Enable option is not selected<br/> 1'b1: Transmit Checksum Offload Enable option is selected</p>               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RO          | 0x1                | <p>EEESEL<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          | 0x1                | <p>TSSEL<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          | 0x0                | <p>ARPOFFSEL<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>MMCSEL<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>MGKSEL<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>RWKSEL<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>  |
| 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>                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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>PCSSEL<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          | 0x1                | <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          | 0x1                | <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>MISEL<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                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:24      | RO          | 0x1                | <p><b>HASHTBLSZ</b><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><b>POUOST</b><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><b>RAVSEL</b><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><b>AVSEL</b><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><b>DBGMEMA</b><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>                                                                  |
| 18         | RO          | 0x1                | <p><b>TSOEN</b><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          | 0x0                | <p><b>SPHEN</b><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>                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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          | 0x0                | <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                | <p>ADVTHWORD<br/>IEEE 1588 High Word Register Enable<br/>This bit is set to 1 when the Add IEEE 1588 Higher Word Register option is selected.<br/>Values:<br/>1'b0: IEEE 1588 High Word Register option is not selected<br/>1'b1: IEEE 1588 High Word Register option is selected</p>                                                                                                                                                                                                                                    |
| 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>                                                                                                                                                                                                                                                                   |
| 10:6       | RO          | 0x07               | <p>TXFIFOSIZE<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/>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: Reserved</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RO          | 0x0                | <p>SPRAM<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          | 0x08               | <p>RXFIFOSIZE<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                                                                                                                                                                                                                                                                                                            |
| 30:28      | RO          | 0x1                | <p>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</p> |
| 27         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                            |
| 26:24      | RO          | 0x0                | <p>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</p>                                                       |
| 23:22      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                            |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21:18      | RO          | 0x0                | <p><b>TXCHCNT</b><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</p> |
| 17:16      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15:12      | RO          | 0x0                | <p><b>RXCHCNT</b><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</p>   |
| 11:10      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 9:6        | RO          | 0x0                | <p><b>TXQCN</b><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><b>RXQCN</b><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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 21:20      | RO          | 0x0                | <p>ESTWID<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>ESTDEP<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>                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16         | RO          | 0x0                | <p>ESTSEL<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>FRPES<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>FRPBS<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         | RO          | 0x0                | <p>FRPSEL<br/>Flexible Receive Parser Selected<br/>This bit is set to 1 when the Enable Flexible Programmable Receive Parser option is selected.<br/>Values:<br/>1'b0: Flexible Receive Parser feature is not selected<br/>1'b1: Flexible Receive Parser feature is selected</p>                                             |
| 9          | RO          | 0x0                | <p>PDUPSEL<br/>Broadcast/Multicast Packet Duplication<br/>This bit is set to 1 when the Broadcast/Multicast Packet Duplication feature is selected.<br/>Values:<br/>1'b0: Broadcast/Multicast Packet Duplication feature is not selected<br/>1'b1: Broadcast/Multicast Packet Duplication feature is selected</p>            |
| 8:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                     |
| 5          | RO          | 0x0                | <p>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</p>                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | <p>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</p>                                                 |
| 3          | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2:0        | RO          | 0x0                | <p>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</p> |

**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                | <p>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</p>                                                                                                                                                                                                                                                                                                                                                                                                |
| 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.<br/>Values:<br/>1'b0: Back to Back transactions disabled<br/>1'b1: Back to Back transactions enabled</p> |

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 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:<br/>         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.<br/>         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:<br/>         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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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>                                                                                                                                                            |
| 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>                                                                                                                                                                                                      |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>GB<br/>GMII Busy</p> <p>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.</p> <p>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.</p> <p>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.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: GMII Busy is disabled</li> <li>1'b1: GMII Busy is enabled</li> </ul> |

**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                                                                                                                                                                                                                                |
| 16         | RW          | 0x0                | <p>RA<br/>Register Address</p> <p>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.</p>                                                                   |
| 15:0       | RW          | 0x0000             | <p>GD<br/>GMII Data</p> <p>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.</p> |

**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                | <p>RCWE<br/>Register Clear on Write 1 Enable</p> <p>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.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Register Clear on Write 1 is disabled</li> <li>1'b1: Register Clear on Write 1 is enabled</li> </ul> |

**GMAC MAC Address0 High**

Address: Operational Base + offset (0x0300)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x1                | <p>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</p>                                                                                                      |
| 30:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                        |
| 15:0       | RW          | 0xffff             | <p>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.</p> |

**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         | <p>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.</p> |

**GMAC MMC Control**

Address: Operational Base + offset (0x0700)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:9       | RO          | 0x0000000          | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 8          | RW          | 0x0                | <p>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</p> |
| 7:6        | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0x0         | <p>CNTPRSTLVL<br/>Full-Half Preset<br/>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 0xFFFF.<br/>Values:<br/>1'b0: Full-Half Preset is disabled<br/>1'b1: Full-Half Preset is enabled</p> |
| 4   | RW   | 0x0         | <p>CNTPRST<br/>Counters Preset<br/>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.<br/>Values:<br/>1'b0: Counters Preset is disabled<br/>1'b1: Counters Preset is enabled</p>                                                                                                                                                                                                                                                      |
| 3   | RW   | 0x0         | <p>CNTFREEZ<br/>MMC Counter Freeze<br/>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.<br/>Values:<br/>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<br/>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.<br/>Values:<br/>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<br/>When this bit is set, the counter does not roll over to zero after reaching the maximum value.<br/>Values:<br/>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.<br/>Access restriction applies. Self-cleared. Setting 0 clears. Setting 1 sets.<br/>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.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/>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: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.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.<br/>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                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5          | RO          | 0x0                | <p>RXCRCERPIIS<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.<br/>Values:<br/>1'b0: MMC Receive CRC Error Packet Counter Interrupt Status not detecte<br/>1'b1: MMC Receive CRC Error Packet Counter Interrupt Status detected</p>               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | RO          | 0x0                | <p>RXMCGPIS<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>RXGOCTIS<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>RXGBOCTIS<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>RXGBPktIS<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:22      | RO          | 0x000              | reserved           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.</p> <p>Values:</p> <p>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.</p> <p>Values:</p> <p>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.</p> <p>Values:</p> <p>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                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 13         | RO          | 0x0                | <p><b>TXUFLOWERPIS</b><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:</p> <p>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                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | <p><b>TXGBPktIS</b><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><b>TXGBoctIS</b><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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                          |
| 21         | RW          | 0x0                | <p><b>RXFOVPIM</b><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                                                                                                                                                                                                                                                                                                                                                                                          |
| 18         | RW          | 0x0                | <p><b>RXLNERPIM</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.</p> <p>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:6       | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RW          | 0x0                | <p><b>RXCRCERPM</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>                                        |
| 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:22      | RO          | 0x000              | reserved           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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>                                         |
| 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>                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>TXGBOCTIM<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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>TXOCTGB<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         | <p>TXPKTGB<br/>Tx Packet Count Good Bad<br/>This field indicates the number of good and bad packets transmitted, exclusive of retried packets.</p> |

**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         | <p>TXUNDRLW<br/>Tx Underflow Error Packets<br/>This field indicates the number of packets aborted because of packets underflow error.</p> |

**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         | <p>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).</p> |

**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         | <p>TXOCTG<br/>Tx Octet Count Good<br/>This field indicates the number of bytes transmitted, exclusive of preamble, only in good packets.</p> |

**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 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 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                | RXICMPEROIM<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.<br>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                        |
| 28         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                 |
| 27         | RW          | 0x0                | RXTCPEROIM<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.<br>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                             |
| 26         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                 |
| 25         | RW          | 0x0                | RXUDPEROIM<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.<br>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                             |
| 24:23      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                 |
| 22         | RW          | 0x0                | RXIPV6HEROIM<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.<br>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 |
| 21:18      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.<br/>           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>  |
| 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> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | RW   | 0x0         | <p>RXIPV6GPI<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                                                                                                                                                                                                                                                                                                                                                                                                |
| 1   | RW   | 0x0         | <p>RXIPV4HERPIM<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.<br/>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>RXIPV4GPI<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.<br/>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)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 29    | RO   | 0x0         | <p>RXICMPEROIS<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.<br/>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                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:</p> <p>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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 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:</p> <p>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:</p> <p>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:</p> <p>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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | RO          | 0x0                | <p><b>RXICMPERPIS</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:</p> <ul style="list-style-type: none"> <li>1'b0: MMC Receive ICMP Error Packet Counter Interrupt Status not detected</li> <li>1'b1: MMC Receive ICMP Error Packet Counter Interrupt Status detected</li> </ul>                          |
| 12         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 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:</p> <ul style="list-style-type: none"> <li>1'b0: MMC Receive TCP Error Packet Counter Interrupt Status not detected</li> <li>1'b1: MMC Receive TCP Error Packet Counter Interrupt Status detected</li> </ul>                               |
| 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:</p> <ul style="list-style-type: none"> <li>1'b0: MMC Receive UDP Error Packet Counter Interrupt Status not detected</li> <li>1'b1: MMC Receive UDP Error Packet Counter Interrupt Status detected</li> </ul>                               |
| 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:</p> <ul style="list-style-type: none"> <li>1'b0: MMC Receive IPV6 Header Error Packet Counter Interrupt Status not detected</li> <li>1'b1: MMC Receive IPV6 Header Error Packet Counter Interrupt Status detected</li> </ul> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | RO          | 0x0                | <p>RXIPV6GPIS<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                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 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         | RXIPV6GDPKT<br>RxIPv6 Good Packets<br>This field indicates the number of good IPv6 datagrams received with the TCP, UDP, or ICMP payload. |

**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         | RXIPV6HDRERRPkt<br>RxIPv6 Header Error Packets<br>This field indicates the number of IPv6 datagrams received with header (length or version mismatch) errors. |

**GMAC RxUDP Error Packets**

Address: Operational Base + offset (0x0834)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | RXUDPPERRPKT<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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                          |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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         | RXTCPERROCT<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         | RXICMPERROCT<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 MAC Timestamp Control**

Address: Operational Base + offset (0x0b00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 28         | RW          | 0x0                | AV8021ASMen<br>AV 802.1AS Mode Enable<br>When this bit is set, the MAC processes only untagged PTP over Ethernet packets for providing PTP status and capturing timestamp snapshots, that is, IEEE 802.1AS mode of operation.<br>When PTP offload feature is enabled, for the purpose of PTP offload, the transport specific field in the PTP header is generated and checked based on the value of this bit.<br>Values:<br>1'b0: AV 802.1AS Mode is disabled<br>1'b1: AV 802.1AS Mode is enabled |
| 27:25      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24         | RW          | 0x0                | <p><b>TXTSSTSM</b><br/>Transmit Timestamp Status Mode<br/>When this bit is set, the MAC overwrites the earlier transmit timestamp status even if it is not read by the software. The MAC indicates this by setting the TXTSSMIS bit of the MAC_Tx_Timestamp_Status_Nanoseconds register. When this bit is reset, the MAC ignores the timestamp status of current packet if the timestamp status of previous packet is not read by the software. The MAC indicates this by setting the TXTSSMIS bit of the MAC_Tx_Timestamp_Status_Nanoseconds register.</p> <p>Values:<br/>1'b0: Transmit Timestamp Status Mode is disabled<br/>1'b1: Transmit Timestamp Status Mode is enabled</p>                                                                                                                                                                                                     |
| 23:21      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 20         | RW          | 0x0                | <p><b>ESTI</b><br/>External System Time Input<br/>When this bit is set, the MAC uses the external 64-bit reference System Time input for the following:</p> <ol style="list-style-type: none"> <li>1. To take the timestamp provided as status</li> <li>2. To insert the timestamp in transmit PTP packets when One-step Timestamp or Timestamp Offload feature is enabled.</li> </ol> <p>When this bit is reset, the MAC uses the internal reference System Time.</p> <p>Values:<br/>1'b0: External System Time Input is disabled<br/>1'b1: External System Time Input is enabled</p>                                                                                                                                                                                                                                                                                                  |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 18         | RW          | 0x0                | <p><b>TSENMACADDR</b><br/>Enable MAC Address for PTP Packet Filtering<br/>When this bit is set, the DA MAC address (that matches any MAC Address register) is used to filter the PTP packets when PTP is directly sent over Ethernet.</p> <p>When this bit is set, received PTP packets with DA containing a special multicast or unicast address that matches the one programmed in MAC address registers are considered for processing as indicated below, when PTP is directly sent over Ethernet.</p> <p>For normal time stamping operation, MAC address registers 0 to 31 is considered for unicast destination address matching.<br/>For PTP offload, only MAC address register 0 is considered for unicast destination address matching.</p> <p>Values:<br/>1'b0: MAC Address for PTP Packet Filtering is disabled<br/>1'b1: MAC Address for PTP Packet Filtering is enabled</p> |
| 17:16      | RW          | 0x0                | <p><b>SNAPTPSEL</b><br/>Select PTP packets for Taking Snapshots<br/>These bits, along with Bits 15 and 14, decide the set of PTP packet types for which snapshot needs to be taken. The encoding is given in Timestamp Snapshot Dependency on Register Bits Table.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | RW          | 0x0                | <p><b>TSMSTRENA</b><br/> Enable Snapshot for Messages Relevant to Master<br/> When this bit is set, the snapshot is taken only for the messages that are relevant to the master node. Otherwise, the snapshot is taken for the messages relevant to the slave node.</p> <p>Values:<br/> 1'b0: Snapshot for Messages Relevant to Master is disabled<br/> 1'b1: Snapshot for Messages Relevant to Master is enabled</p>                                                                                                                                                       |
| 14         | RW          | 0x0                | <p><b>TSEVNTEA</b><br/> Enable Timestamp Snapshot for Event Messages<br/> When this bit is set, the timestamp snapshot is taken only for event messages (SYNC, Delay_Req, Pdelay_Req, or Pdelay_Resp). When this bit is reset, the snapshot is taken for all messages except Announce, Management, and Signaling. For more information about the timestamp snapshots, see Timestamp Snapshot Dependency on Register Bits Table.</p> <p>Values:<br/> 1'b0: Timestamp Snapshot for Event Messages is disabled<br/> 1'b1: Timestamp Snapshot for Event Messages is enabled</p> |
| 13         | RW          | 0x1                | <p><b>TSIPV4ENA</b><br/> Enable Processing of PTP Packets Sent over IPv4-UDP<br/> When this bit is set, the MAC receiver processes the PTP packets encapsulated in IPv4-UDP packets. When this bit is reset, the MAC ignores the PTP transported over IPv4-UDP packets. This bit is set by default.</p> <p>Values:<br/> 1'b0: Processing of PTP Packets Sent over IPv4-UDP is disabled<br/> 1'b1: Processing of PTP Packets Sent over IPv4-UDP is enabled</p>                                                                                                               |
| 12         | RW          | 0x0                | <p><b>TSIPV6ENA</b><br/> Enable Processing of PTP Packets Sent over IPv6-UDP<br/> When this bit is set, the MAC receiver processes the PTP packets encapsulated in IPv6-UDP packets. When this bit is clear, the MAC ignores the PTP transported over IPv6-UDP packets.</p> <p>Values:<br/> 1'b0: Processing of PTP Packets Sent over IPv6-UDP is disabled<br/> 1'b1: Processing of PTP Packets Sent over IPv6-UDP is enabled</p>                                                                                                                                           |
| 11         | RW          | 0x0                | <p><b>TSIPENA</b><br/> Enable Processing of PTP over Ethernet Packets<br/> When this bit is set, the MAC receiver processes the PTP packets encapsulated directly in the Ethernet packets. When this bit is reset, the MAC ignores the PTP over Ethernet packets.</p> <p>Values:<br/> 1'b0: Processing of PTP over Ethernet Packets is disabled<br/> 1'b1: Processing of PTP over Ethernet Packets is enabled</p>                                                                                                                                                           |
| 10         | RW          | 0x0                | <p><b>TSVER2ENA</b><br/> Enable PTP Packet Processing for Version 2 Format<br/> When this bit is set, the IEEE 1588 version 2 format is used to process the PTP packets. When this bit is reset, the IEEE 1588 version 1 format is used to process the PTP packets. The IEEE 1588 formats are described in 'PTP Processing and Control'.</p> <p>Values:<br/> 1'b0: PTP Packet Processing for Version 2 Format is disabled<br/> 1'b1: PTP Packet Processing for Version 2 Format is enabled</p>                                                                              |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | RW   | 0x0         | <p>TSCTRLSSR</p> <p>Timestamp Digital or Binary Rollover Control</p> <p>When this bit is set, the Timestamp Low register rolls over after 0x3B9A_C9FF value (that is, 1 nanosecond accuracy) and increments the timestamp (High) seconds. When this bit is reset, the rollover value of sub-second register is 0x7FFF_FFFF. The sub-second increment must be programmed correctly depending on the PTP reference clock frequency and the value of this bit.</p> <p>Values:</p> <p>1'b0: Timestamp Digital or Binary Rollover Control is disabled<br/>1'b1: Timestamp Digital or Binary Rollover Control is enabled</p> |
| 8   | RW   | 0x0         | <p>TSENALL</p> <p>Enable Timestamp for All Packets</p> <p>When this bit is set, the timestamp snapshot is enabled for all packets received by the MAC.</p> <p>Values:</p> <p>1'b0: Timestamp for All Packets disabled<br/>1'b1: Timestamp for All Packets enabled</p>                                                                                                                                                                                                                                                                                                                                                  |
| 7:6 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5   | RW   | 0x0         | <p>TSADDREG</p> <p>Update Addend Register</p> <p>When this bit is set, the content of the Timestamp Addend register is updated in the PTP block for fine correction. This bit is cleared when the update is complete. This bit should be zero before it is set.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:</p> <p>1'b0: Addend Register is not updated<br/>1'b1: Addend Register is updated</p>                                                                                                                                                          |
| 4   | RW   | 0x0         | <p>TSTRIG</p> <p>Enable Timestamp Interrupt Trigger</p> <p>When this bit is set, the timestamp interrupt is generated when the System Time becomes greater than the value written in the Target Time register. This bit is reset after the Timestamp Trigger Interrupt is generated.</p> <p>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.</p> <p>Values:</p> <p>1'b0: Timestamp Interrupt Trigger is not enabled<br/>1'b1: Timestamp Interrupt Trigger is enabled</p>                                                                                                             |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | RW          | 0x0                | <p>TSUPDT<br/>Update Timestamp<br/>When this bit is set, the system time is updated (added or subtracted) with the value specified in MAC_System_Time_Seconds_Update and MAC_System_Time_Nanoseconds_Update registers. This bit should be zero before updating it. This bit is reset when the update is complete in hardware. The Timestamp Higher Word register (if enabled during core configuration) is not updated. When Media Clock Generation and Recovery is configured (DWC_EQOS_FLEXI_PPS_OUT_EN) and enabled MAC_Presn_Time_Updt should also be updated before setting this field.</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: Timestamp is not updated</li> <li>1'b1: Timestamp is updated</li> </ul>                    |
| 2          | RW          | 0x0                | <p>TSINIT<br/>Initialize Timestamp<br/>When this bit is set, the system time is initialized (overwritten) with the value specified in the MAC_System_Time_Seconds_Update and MAC_System_Time_Nanoseconds_Update registers. This bit should be zero before it is updated. This bit is reset when the initialization is complete. The Timestamp Higher Word register (if enabled during core configuration) can only be initialized. When Media Clock Generation and Recovery is configured (DWC_EQOS_FLEXI_PPS_OUT_EN) and enabled MAC_Presn_Time_Updt should also be updated before setting this field.</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: Timestamp is not initialized</li> <li>1'b1: Timestamp is initialized</li> </ul> |
| 1          | RW          | 0x0                | <p>TSCFUPDT<br/>Fine or Coarse Timestamp Update<br/>When this bit is set, the Fine method is used to update system timestamp. When this bit is reset, Coarse method is used to update the system timestamp.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Coarse method is used to update system timestamp</li> <li>1'b1: Fine method is used to update system timestamp</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0          | RW          | 0x0                | <p>TSENA<br/>Enable Timestamp<br/>When this bit is set, the timestamp is added for Transmit and Receive packets. When disabled, timestamp is not added for transmit and receive packets and the Timestamp Generator is also suspended. You need to initialize the Timestamp (system time) after enabling this mode. On the Receive side, the MAC processes the 1588 packets only if this bit is set.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Timestamp is disabled</li> <li>1'b1: Timestamp is enabled</li> </ul>                                                                                                                                                                                                                                                                                                         |

**GMAC MAC Sub Second Increment**

Address: Operational Base + offset (0x0b04)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | RO   | 0x00        | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 23:16 | RW   | 0x00        | SSINC<br>Sub-second Increment Value<br>The value programmed in this field is accumulated every clock cycle (of clk_ptp_i) with the contents of the sub-second register. For example, when the PTP clock is 50 MHz (period is 20 ns), you should program 20 (0x14) when the System Time Nanoseconds register has an accuracy of 1 ns [Bit 9 (TSCTRLSSR) is set in MAC_Timestamp_Control]. When TSCTRLSSR is clear, the Nanoseconds register has a resolution of ~0.465 ns. In this case, you should program a value of 43 (0x2B) which is derived by 20 ns/0.465. |

**GMAC MAC System Time Secs**

Address: Operational Base + offset (0x0b08)

| Bit  | Attr | Reset Value | Description                                                                                                                         |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | TSS<br>Timestamp Second<br>The value in this field indicates the current value in seconds of the System Time maintained by the MAC. |

**GMAC MAC System Time NS**

Address: Operational Base + offset (0x0b0c)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                |
|------|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                   |
| 30:0 | RW   | 0x00000000  | TSSS<br>Timestamp Sub Seconds<br>The value in this field has the sub-second representation of time, with an accuracy of 0.46 ns. When Bit 9 is set in MAC_Timestamp_Control, each bit represents 1 ns. The maximum value is 0x3B9A_C9FF after which it rolls-over to zero. |

**GMAC MAC Sys Time Secs Update**

Address: Operational Base + offset (0x0b10)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | TSS<br>Timestamp Seconds<br>The value in this field is the seconds part of the update. When ADDSUB is reset, this field must be programmed with the seconds part of the update value.<br>When ADDSUB is set, this field must be programmed with the complement of the seconds part of the update value. For example, if 2.000000001 seconds need to be subtracted from the system time, the TSS field in the MAC_Timestamp_Seconds_Update register must be 0xFFFF_FFFE (that is, $2^{32} - 2$ ). |

**GMAC MAC Sys Time NS Update**

Address: Operational Base + offset (0x0b14)

| Bit  | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | RW   | 0x0         | <p>ADDSUB<br/>Add or Subtract Time<br/>When this bit is set, the time value is subtracted with the contents of the update register. When this bit is reset, the time value is added with the contents of the update register.<br/>Values:<br/>1'b0: Add time<br/>1'b1: Subtract time</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 30:0 | RW   | 0x00000000  | <p>TSSS<br/>Timestamp Sub Seconds<br/>The value in this field is the sub-seconds part of the update. When ADDSUB is reset, this field must be programmed with the sub-seconds part of the update value, with an accuracy based on the TSCTRLSSR bit of the MAC_Timestamp_Control register. When ADDSUB is set, this field must be programmed with the complement of the sub-seconds part of the update value as described below.<br/>When TSCTRLSSR bit in MAC_Timestamp_Control is set, the programmed value must be <math>10^9 - &lt;\text{sub-second value}&gt;</math>. When TSCTRLSSR bit in MAC_Timestamp_Control is reset, the programmed value must be <math>2^{31} - &lt;\text{sub-second_value}&gt;</math>. When the TSCTRLSSR bit is reset in the MAC_Timestamp_Control register, each bit represents an accuracy of 0.46 ns. When the TSCTRLSSR bit is set in the MAC_Timestamp_Control register, each bit represents 1 ns and the programmed value should not exceed 0x3B9A_C9FF.<br/>For example, if 2.000000001 seconds need to be subtracted from the system time, then the TSSS field in the MAC_Timestamp_Nanoseconds_Update register must be 0x7FFF_FFFF (that is, <math>2^{31} - 1</math>), when TSCTRLSSR bit in MAC_Timestamp_Control is reset and 0x3B9A_C9FF (that is, <math>10^9 - 1</math>), when TSCTRLSSR bit in MAC_Timestamp_Control is set.</p> |

**GMAC MAC Timestamp Addend**

Address: Operational Base + offset (0x0b18)

| Bit  | Attr | Reset Value | Description                                                                                                                                                       |
|------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RW   | 0x00000000  | <p>TSAR<br/>Timestamp Addend Register<br/>This field indicates the 32-bit time value to be added to the Accumulator register to achieve time synchronization.</p> |

**GMAC MAC Timestamp Status**

Address: Operational Base + offset (0x0b20)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | RO   | 0x0         | reserved                                                                                                                                                                                                                                                                                                                                                                                                              |
| 29:25 | RO   | 0x00        | <p>ATNS<br/>Number of Auxiliary Timestamp Snapshots<br/>This field indicates the number of Snapshots available in the FIFO. A value equal to the selected depth of FIFO (4, 8, or 16) indicates that the Auxiliary Snapshot FIFO is full. These bits are cleared (to 00000) when the Auxiliary snapshot FIFO clear bit is set. This bit is valid only if the Add IEEE 1588 Auxiliary Snapshot option is selected.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24         | RO          | 0x0                | <p>ATSSM<br/>Auxiliary Timestamp Snapshot Trigger Missed<br/>This bit is set when the Auxiliary timestamp snapshot FIFO is full and external trigger was set. This indicates that the latest snapshot is not stored in the FIFO. This bit is valid only if the Add IEEE 1588 Auxiliary Snapshot option is selected.</p> <p>Values:</p> <p>1'b0: Auxiliary Timestamp Snapshot Trigger Missed status not detected<br/>1'b1: Auxiliary Timestamp Snapshot Trigger Missed status detected</p>                                                                                                                                                                                                                                                                                                                                                                                                  |
| 23:16      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15         | RO          | 0x0                | <p>TXTSSIS<br/>Tx Timestamp Status Interrupt Status<br/>In non-EQOS_CORE configurations when drop transmit status is enabled in MTL, this bit is set when the captured transmit timestamp is updated in the MAC_Tx_Timestamp_Status_Nanoseconds and MAC_Tx_Timestamp_Status_Seconds registers. When PTP offload feature is enabled, this bit is set when the captured transmit timestamp is updated in the MAC_Tx_Timestamp_Status_Nanoseconds and MAC_Tx_Timestamp_Status_Seconds registers, for PTO generated Delay Request and Pdelay request packets. This bit is cleared when the MAC_Tx_Timestamp_Status_Seconds register is read (or write to MAC_Tx_Timestamp_Status_Seconds register when RCWE bit of MAC_CSR_SW_Ctrl register is set).</p> <p>Values:</p> <p>1'b0: Tx Timestamp Status Interrupt status not detected<br/>1'b1: Tx Timestamp Status Interrupt status detected</p> |
| 14:4       | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3          | RO          | 0x0                | <p>TSTRGTERRO<br/>Timestamp Target Time Error<br/>This bit is set when the latest target time programmed in the MAC_PPS0_Target_Time_Seconds and MAC_PPS0_Target_Time_Nanoseconds registers elapses. This bit is cleared when the application reads this bit.</p> <p>Access restriction applies. Clears on read (or this bit is written to 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:</p> <p>1'b0: Timestamp Target Time Error status not detected<br/>1'b1: Timestamp Target Time Error status detected</p>                                                                                                                                                                                                                                                                                                                     |
| 2          | RO          | 0x0                | <p>AUXTSTRIG<br/>Auxiliary Timestamp Trigger Snapshot<br/>This bit is set high when the auxiliary snapshot is written to the FIFO. This bit is valid only if the Add IEEE 1588 Auxiliary Snapshot option is selected.</p> <p>Access restriction applies. Clears on read (or this bit is written to 1 when RCWE bit in MAC_CSR_SW_Ctrl register is set). Self-set to 1 on internal event.</p> <p>Values:</p> <p>1'b0: Auxiliary Timestamp Trigger Snapshot status not detected<br/>1'b1: Auxiliary Timestamp Trigger Snapshot status detected</p>                                                                                                                                                                                                                                                                                                                                           |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | RO          | 0x0                | <p>TSTARTT0<br/>Timestamp Target Time Reached<br/>When set, this bit indicates that the value of system time is greater than or equal to the value specified in the MAC_PPS0_Target_Time_Seconds and MAC_PPS0_Target_Time_Nanoseconds registers.<br/>Access restriction applies. Clears on read (or this bit is written to 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: Timestamp Target Time Reached status not detected<br/>1'b1: Timestamp Target Time Reached status detected</p> |
| 0          | RO          | 0x0                | <p>TSSOVF<br/>Timestamp Seconds Overflow<br/>When this bit is set, it indicates that the seconds value of the timestamp (when supporting version 2 format) has overflowed beyond 32'hFFFF_FFFF.<br/>Access restriction applies. Clears on read (or this bit is written to 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: Timestamp Seconds Overflow status not detected<br/>1'b1: Timestamp Seconds Overflow status detected</p>                                                        |

**GMAC MAC Tx TS Status NS**

Address: Operational Base + offset (0x0b30)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | <p>TXTSSMIS<br/>Transmit Timestamp Status Missed<br/>When this bit is set, it indicates one of the following:<br/>1. The timestamp of the current packet is ignored if TXTSSTSM bit of the MAC_Timestamp_Control register is reset.<br/>2. The timestamp of the previous packet is overwritten with timestamp of the current packet if TXTSSTSM bit of the MAC_Timestamp_Control register is set.<br/>Access restriction applies. Clears on read. Self-set to 1 on internal event.</p> <p>Values:<br/>1'b0: Transmit Timestamp Status Missed status not detected<br/>1'b1: Transmit Timestamp Status Missed status detected</p> |
| 30:0       | RO          | 0x00000000         | <p>TXTSSLO<br/>Transmit Timestamp Status Low<br/>This field contains the 31 bits of the Nanoseconds field of the Transmit packet's captured timestamp.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

**GMAC MAC Tx TS Status Secs**

Address: Operational Base + offset (0x0b34)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RO          | 0x00000000         | <p>TXTSSHI<br/>Transmit Timestamp Status High<br/>This field contains the lower 32 bits of the Seconds field of Transmit packet's captured timestamp.</p> |

**GMAC MAC Auxiliary Control**

Address: Operational Base + offset (0x0b40)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1       | RO          | 0x00000000         | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0          | RW          | 0x0                | <p>ATSF<br/>Auxiliary Snapshot FIFO Clear<br/>When set, this bit resets the pointers of the Auxiliary Snapshot FIFO. This bit is cleared when the pointers are reset and the FIFO is empty. When this bit is high, the auxiliary snapshots are stored in the FIFO.</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: Auxiliary Snapshot FIFO Clear is disabled</li> <li>1'b1: Auxiliary Snapshot FIFO Clear is enabled</li> </ul> |

**GMAC MAC Auxiliary TS NS**

Address: Operational Base + offset (0x0b48)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                    |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------|
| 31         | RO          | 0x0                | reserved                                                                                                              |
| 30:0       | RO          | 0x00000000         | <p>AUXTSLO<br/>Auxiliary Timestamp<br/>Contains the lower 31 bits (nanoseconds field) of the auxiliary timestamp.</p> |

**GMAC MAC Auxiliary TS Secs**

Address: Operational Base + offset (0x0b4c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                     |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>AUXTSHI<br/>Auxiliary Timestamp<br/>Contains the lower 32 bits of the Seconds field of the auxiliary timestamp.</p> |

**GMAC MAC TS Ingress Corr NS**

Address: Operational Base + offset (0x0b58)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                      |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>TSIC<br/>Timestamp Ingress Correction<br/>This field contains the ingress path correction value as defined by the Ingress Correction expression.</p> |

**GMAC MAC TS Egress Corr NS**

Address: Operational Base + offset (0x0b5c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0       | RW          | 0x00000000         | <p>TSEC<br/>Timestamp Egress Correction<br/>This field contains the nanoseconds part of the egress path correction value as defined by the Egress Correction expression.</p> |

**GMAC MAC TS Ingress Latency**

Address: Operational Base + offset (0x0b68)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                             |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                                                                                                                                       |
| 23:16      | RO          | 0x00               | <p>ITLNS<br/>Ingress Timestamp Latency, in sub-nanoseconds<br/>This register holds the average latency in sub-nanoseconds between the input ports (phy_rxd_i) of MAC and the actual point (GMII/MII) where the ingress timestamp is taken.</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                            |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8       | RO          | 0x00               | ITLSNS<br>Ingress Timestamp Latency, in nanoseconds<br>This register holds the average latency in nanoseconds between the input ports (phy_rx_i) of MAC and the actual point (GMII/MII) where the ingress timestamp is taken. |

**GMAC MAC TS Egress Latency**

Address: Operational Base + offset (0x0b6c)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                       |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24      | RO          | 0x00               | reserved                                                                                                                                                                                                                                 |
| 23:16      | RO          | 0x00               | ETLNS<br>Egress Timestamp Latency, in nanoseconds<br>This register holds the average latency in nanoseconds between the actual point (GMII/MII) where the egress timestamp is taken and the output ports (phy_tx_o) of the MAC.          |
| 15:8       | RO          | 0x00               | ETLSNS<br>Egress Timestamp Latency, in sub-nanoseconds<br>This register holds the average latency in sub-nanoseconds between the actual point (GMII/MII) where the egress timestamp is taken and the output ports (phy_tx_o) of the MAC. |

**GMAC MAC PPS Control**

Address: Operational Base + offset (0x0b70)

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

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | RW   | 0x0         | <p>PPSCTRL_PPSCMD(cont.)</p> <p>Flexible PPS Output (ptp_pps_o[0]) Control</p> <p>Programming these bits with a non-zero value instructs the MAC to initiate an event. When the command is transferred or synchronized to the PTP clock domain, these bits get cleared automatically. The software should ensure that these bits are programmed only when they are 'all-zero'. The following list describes the values of PPSCMD0:</p> <ul style="list-style-type: none"> <li>4'b0000: No Command</li> <li>4'b0001: START Single Pulse</li> <li>This command generates single pulse rising at the start point defined in MAC_PPS0_Target_Time_Seconds and MAC_PPS0_Target_Time_Nanoseconds register and of a duration defined in the PPS0 Width Register.</li> <li>4'b0010: START Pulse Train</li> <li>This command generates the train of pulses rising at the start point defined in the Target Time Registers and of a duration defined in the PPS0 Width Register and repeated at interval defined in the PPS Interval Register. By default, the PPS pulse train is free-running unless stopped by the 'Stop Pulse train at time' or 'Stop Pulse Train immediately' commands.</li> <li>4'b0011: Cancel START</li> <li>This command cancels the START Single Pulse and START Pulse Train commands if the system time has not crossed the programmed start time.</li> <li>4'b0100: STOP Pulse train at time</li> <li>This command stops the train of pulses initiated by the START Pulse Train command (PPSCMD = 0010) after the time programmed in the Target Time registers elapses.</li> <li>4'b0101: STOP Pulse Train immediately</li> <li>This command immediately stops the train of pulses initiated by the START Pulse Train command (PPSCMD = 0010).</li> <li>4'b0110: Cancel STOP Pulse train</li> <li>This command cancels the STOP pulse train at time command if the programmed stop time has not elapsed. The PPS pulse train becomes free-running on the successful execution of this command.</li> <li>4'b0111-4'b1111: Reserved</li> </ul> |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | RW   | 0x0         | <p>PPSCTRL_PPSCMD<br/>PPS Output Frequency Control<br/>This field controls the frequency of the PPS0 output (ptp_pps_o[0]) signal. The default value of PPSCTRL is 0000, and the PPS output is 1 pulse (of width clk_ptp_i) every second. For other values of PPSCTRL, the PPS output becomes a generated clock of following frequencies:</p> <ul style="list-style-type: none"> <li>4'b0001: The binary rollover is 2 Hz, and the digital rollover is 1 Hz.</li> <li>4'b0010: The binary rollover is 4 Hz, and the digital rollover is 2 Hz.</li> <li>4'b0011: The binary rollover is 8 Hz, and the digital rollover is 4 Hz.</li> <li>4'b0100: The binary rollover is 16 Hz, and the digital rollover is 8 Hz.</li> <li>...</li> <li>4'b1111: The binary rollover is 32.768 KHz and the digital rollover is 16.384 KHz.</li> </ul> <p>Note:<br/>In the binary rollover mode, the PPS output (ptp_pps_o) has a duty cycle of 50 percent with these frequencies. In the digital rollover mode, the PPS output frequency is an average number. The actual clock is of different frequency that gets synchronized every second. For example:</p> <ol style="list-style-type: none"> <li>1. When PPSCTRL = 0001, the PPS (1 Hz) has a low period of 537 ms and a high period of 463 ms.</li> <li>2. When PPSCTRL = 0010, the PPS (2 Hz) is a sequence of One clock of 50 percent duty cycle and 537 ms period Second clock of 463 ms period (268 ms low and 195 ms high).</li> <li>3. When PPSCTRL = 0011, the PPS (4 Hz) is a sequence of Three clocks of 50 percent duty cycle and 268 ms period Fourth clock of 195 ms period (134 ms low and 61 ms high).</li> </ol> <p>This behavior is because of the non-linear toggling of bits in the digital rollover mode in the MAC_System_Time_Nanoseconds register.</p> |

**GMAC MTL DBG CTL**

Address: Operational Base + offset (0x0c08)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                             |
|-------|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                |
| 15    | RW   | 0x0         | <p>STSIE<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>PKTIE<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> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12      | RW          | 0x0                | <p>FIFOSEL<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>FIFOWREN<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>FIFORDEN<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>RSTSEL<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> |
| 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 FDBGGEN 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:5 | RW   | 0x0         | <p><b>PKTSTATE</b><br/> Encoded Packet State<br/> This field is used to write the control information to the Tx FIFO or Rx 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>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><b>BYTEEN</b><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.</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>                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1   | RW   | 0x0         | <p><b>DBGMOD</b><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:</p> <ol style="list-style-type: none"> <li>1. Read and Write access to Tx FIFO, TSO FIFO, and Rx FIFO</li> <li>2. Read access is allowed to Tx Status FIFO.</li> </ol> <p>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:</p> <ol style="list-style-type: none"> <li>1. Write access to the Tx FIFO</li> <li>2. Read access to the Rx FIFO and Tx Status FIFO</li> </ol> <p>Values:<br/> 1'b0: Debug Mode Access to FIFO is disabled<br/> 1'b1: Debug Mode Access to FIFO is enabled</p> |
| 0   | RW   | 0x0         | <p><b>FDBGEN</b><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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16      | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15         | RO          | 0x0                | <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.<br/>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.<br/>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          | 0x3                | <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.<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>                         |

| 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> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:1       | RO          | 0x0000             | reserved                                                                                                                                                                                                                                                                                                                                                                     |
| 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:<br/>1'b0: Queue 0 Interrupt status not detected<br/>1'b1: Queue 0 Interrupt status detected</p> |

**GMAC MTL TxQ0 Operation Mode**

Address: Operational Base + offset (0x0d00)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 21:16      | RW          | 0x3f               | <p>TQS<br/>Transmit Queue Size<br/>This field indicates the size of the allocated Transmit queues in blocks of 256 bytes. The TQS field is read-write only if the number of Tx Queues more than one, the reset value is 0x0 and indicates size of 256 bytes. When the number of Tx Queues is one, the field is read-only and the configured TX FIFO size in blocks of 256 bytes is reflected in the reset value. The width of this field depends on the Tx memory size selected in your configuration. For example, if the memory size is 2048, the width of this field is 3 bits:</p> $\text{LOG2}(2048/256) = \text{LOG2}(8) = 3 \text{ bits.}$ |
| 15:7       | RO          | 0x000              | 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:<br/>3'b000: 32 bytes<br/>3'b001: 64 bytes<br/>3'b010: 96 bytes<br/>3'b011: 128 bytes<br/>3'b100: 192 bytes<br/>3'b101: 256 bytes<br/>3'b110: 384 bytes<br/>3'b111: 512 bytes</p>                                                                                                  |
| 3:2        | RW          | 0x2                | <p>TXQEN<br/>Transmit Queue Enable<br/>This field is used to enable/disable the transmit queue 0.<br/>2'b00: Not enabled<br/>2'b01: Reserved<br/>2'b10: Enabled<br/>2'b11: Reserved<br/>This field is Read Only in Single Queue configurations and Read Write in Multiple Queue configurations.</p>                                                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:<br/>1'b0: Transmit Store and Forward is disabled<br/>1'b1: Transmit Store and Forward is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 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:<br/>1'b0: Flush Transmit Queue is disabled<br/>1'b1: Flush Transmit Queue is enabled</p> |

**GMAC MTL TxQ0 Underflow**

Address: Operational Base + offset (0x0d04)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:12      | RO          | 0x00000            | 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:<br/>1'b0: Overflow not detected for Underflow Packet Counter<br/>1'b1: Overflow detected for Underflow Packet Counter</p> |
| 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)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:23      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                           |
| 22:20      | RO          | 0x0                | 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.                                                                    |
| 19         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                           |
| 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 |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | <p><b>TXQPAUSED</b><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:</p> <ol style="list-style-type: none"> <li>1. Reception of the PFC packet for the priorities assigned to the Tx Queue when PFC is enabled</li> <li>2. Reception of 802.3x Pause packet when PFC is disabled</li> </ol> <p>Values:<br/>1'b0: Transmit Queue in Pause status is not detected<br/>1'b1: Transmit Queue in Pause status is detected</p> |

**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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 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.</p> <p>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.</p> <p>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.</p> <p>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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x0                | <p>TXUNFIS<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.</p> <p>Access restriction applies. Self-set to 1 on internal event. Setting 1 clears. Setting 0 has no effect.</p> <p>Values:</p> <ul style="list-style-type: none"> <li>1'b0: Transmit Queue Underflow Interrupt Status not detected</li> <li>1'b1: Transmit Queue Underflow Interrupt Status detected</li> </ul> |

**GMAC MTL RxQ0 Operation Mode**

Address: Operational Base + offset (0x0d30)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 26:20      | RW          | 0x7f               | <p>RQS<br/>Receive Queue Size<br/>This field indicates the size of the allocated Receive queues in blocks of 256 bytes. The RQS field is read-write only if the number of Rx Queues more than one, the reset value is 0x0 and indicates size of 256 bytes. When the number of Rx Queues is one, the field is read-only and the configured RX FIFO size in blocks of 256 bytes is reflected in the reset value. The width of this field depends on the Rx memory size selected in your configuration. For example, if the memory size is 2048, the width of this field is 3 bits:<br/> <math>\text{LOG2}(2048/256) = \text{LOG2}(8) = 3</math> bits.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 19:14      | RW          | 0x00               | <p>RFD<br/>Threshold for Deactivating Flow Control (in half-duplex and full-duplex modes)<br/>These bits control the threshold (fill-level of Rx queue) at which the flow control is de-asserted after activation:<br/>           0: Full minus 1 KB, that is, FULL 1 KB<br/>           1: Full minus 1.5 KB, that is, FULL 1.5 KB<br/>           2: Full minus 2 KB, that is, FULL 2 KB<br/>           3: Full minus 2.5 KB, that is, FULL 2.5 KB<br/>           ...<br/>           62: Full minus 32 KB, that is, FULL 32 KB<br/>           63: Full minus 32.5 KB, that is, FULL 32.5 KB<br/>           The de-assertion is effective only after flow control is asserted.<br/>           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> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:8       | RW          | 0x00               | <p><b>RFA</b><br/>           Threshold for Activating Flow Control (in half-duplex and full-duplex)<br/>           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><b>EHFC</b><br/>           Enable Hardware Flow Control<br/>           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.<br/>           Values:<br/>           1'b0: Hardware Flow Control is disabled<br/>           1'b1: Hardware Flow Control is enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6          | RW          | 0x0                | <p><b>DIS_TCP_EF</b><br/>           Disable Dropping of TCP/IP Checksum Error Packets<br/>           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.<br/>           Values:<br/>           1'b0: Dropping of TCP/IP Checksum Error Packets is enabled<br/>           1'b1: Dropping of TCP/IP Checksum Error Packets is disabled</p>                                                                                                                                                                                                                                                                           |
| 5          | RW          | 0x0                | <p><b>RSF</b><br/>           Receive Queue Store and Forward<br/>           When this bit is set, the DWC_ether_qos 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.<br/>           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><b>FEP</b><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.<br/>           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.<br/>           Values:<br/>           1'b0: Forward Error Packets is disabled<br/>           1'b1: Forward Error Packets is enabled</p> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 27         | RO          | 0x0                | <p>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.</p> <p>Values:<br/>1'b0: Missed Packet Counter overflow not detected<br/>1'b1: Missed Packet Counter overflow detected</p>                                                                                                                                                                                                                                        |
| 26:16      | RO          | 0x000              | <p>MISPKTCNT<br/>Missed Packet Counter<br/>This field indicates the number of packets missed by the DWC_ether_qos 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.</p> |
| 15:12      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | RO          | 0x0                | <p>OVFCNTOVF<br/>Overflow Counter Overflow Bit<br/>When set, this bit indicates that the Rx Queue Overflow Packet Counter field crossed the maximum limit.</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 Counter overflow not detected</li> <li>1'b1: Overflow Counter overflow detected</li> </ul>                    |
| 10:0       | RO          | 0x000              | <p>OVFPKTCNT<br/>Overflow Packet Counter<br/>This field indicates the number of packets discarded by the DWC_ether_qos because of Receive queue overflow. This counter is incremented each time the DWC_ether_qos discards an incoming packet because of overflow. This counter is reset 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 RxQ0 Debug**

Address: Operational Base + offset (0x0d38)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:20      | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                  |
| 19:16      | RO          | 0x0                | <p>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.</p>                                                                                                              |
| 15:6       | RO          | 0x000              | reserved                                                                                                                                                                                                                                                                                                                                                  |
| 5:4        | RO          | 0x1                | <p>RXQSTS<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>RRCSTS<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>RWCSTS<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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17:16      | RW          | 0x0                | <p>INTM<br/>Interrupt Mode<br/>This field defines the interrupt mode of DWC_ether_qos. 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RW          | 0x1                | <p>SWR<br/>Software Reset<br/>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 DWC_ether_qos clock domains. Before reprogramming any DWC_ether_qos 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.<br/>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.<br/>Access restriction applies. Setting 1 sets. Self-cleared. Setting 0 has no effect.<br/>Values:<br/>1'b0: Software Reset is disabled<br/>1'b1: Software Reset is enabled</p> |

**GMAC DMA SysBus Mode**

Address: Operational Base + offset (0x1004)

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | RW          | 0x0                | <p>EN_LPI<br/>Enable Low Power Interface (LPI)<br/>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.<br/>When set to 0, this bit disables the LPI mode and always denies the LPI request from the AXI System Clock controller.<br/>Values:<br/>1'b0: Low Power Interface (LPI) is disabled<br/>1'b1: Low Power Interface (LPI) is enabled</p>                                    |
| 30         | RW          | 0x0                | <p>LPI_XIT_PKT<br/>Unlock on Magic Packet or Remote Wake-Up Packet<br/>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.<br/>Values:<br/>1'b0: Unlock on Magic Packet or Remote Wake-Up Packet is disabled<br/>1'b1: Unlock on Magic Packet or Remote Wake-Up Packet is enabled</p> |
| 29:26      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:24      | RW          | 0x1                | <p>WR_OSR_LMT<br/>AXI Maximum Write Outstanding Request Limit<br/>This value limits the maximum outstanding request on the AXI write interface. Maximum outstanding requests = WR_OSR_LMT + 1</p> <p>Note:</p> <ol style="list-style-type: none"> <li>1. Bit 26 is reserved if DWC_ETHER_QOS_AXI_MAX-_WR_REQ = 4</li> <li>2. Bit 27 is reserved if DWC_ETHER_QOS_AXI_MAX-_WR_REQ!= 16</li> </ol>                   |
| 23:19      | RO          | 0x00               | reserved                                                                                                                                                                                                                                                                                                                                                                                                           |
| 18:16      | RW          | 0x1                | <p>RD_OSR_LMT<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>Note:</p> <ol style="list-style-type: none"> <li>1. Bit 18 is reserved if parameter DWC_ETHER_QOS_AXI_-MAX_RD_REQ = 4</li> <li>2. Bit 19 is reserved if parameter DWC_ETHER_QOS_AXI_-MAX_RD_REQ!= 16</li> </ol> |
| 15:13      | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                           |
| 12         | RW          | 0x0                | <p>AAL<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>Values:</p> <p>1'b0: Address-Aligned Beats is disabled<br/>1'b1: Address-Aligned Beats is enabled</p>                                                                                                                                  |
| 11         | RO          | 0x0                | reserved                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10         | RW          | 0x0                | <p>AALE<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 DWC_ether_qos for number of system clock cycles programmed in the LPIEI field of AXI_LPI_Entry_Interval register.</p> <p>Values:</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>BLEN16<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.<br/>When the FB bit is set to 0, setting this bit has no effect.</p> <p>Values:</p> <p>1'b0: No effect<br/>1'b1: AXI Burst Length 16</p>                                                                                                      |

| Bit | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | RW   | 0x0         | BLEN8<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.<br>Values:<br>1'b0: No effect<br>1'b1: AXI Burst Length 8                                                                                                                                                                                                                                                                                         |
| 1   | RW   | 0x0         | 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.<br>Values:<br>1'b0: No effect<br>1'b1: AXI Burst Length 4                                                                                                                                                                                                                                                                                         |
| 0   | RW   | 0x0         | 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.<br>1. Burst transfers of fixed burst lengths as indicated by the BLEN256, BLEN128, BLEN64, BLEN32, BLEN16, BLEN8, or BLEN4 field<br>2. Burst transfers of length 1<br>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].<br>Values:<br>1'b0: Fixed Burst Length is disabled<br>1'b1: Fixed Burst Length is enabled |

**GMAC DMA Interrupt Status**

Address: Operational Base + offset (0x1008)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                           |
|-------|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                              |
| 17    | RO   | 0x0         | 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.<br>Values:<br>1'b0: MAC Interrupt Status not detected<br>1'b1: MAC Interrupt Status detected |
| 16    | RO   | 0x0         | 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.<br>Values:<br>1'b0: MTL Interrupt Status not detected<br>1'b1: MTL Interrupt Status detected |
| 15:1  | RO   | 0x0000      | reserved                                                                                                                                                                                                                                                                                                                              |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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:</p> <ul style="list-style-type: none"> <li>1'b0: DMA Channel 0 Interrupt Status not detected</li> <li>1'b1: DMA Channel 0 Interrupt Status detected</li> </ul> |

**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>                                                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | RO          | 0x0                | <p>AXWHSTS<br/>AXI Master Write Channel or AHB Master Status</p> <p>EQOS-AXI Configuration:<br/>When high, this bit indicates that the write channel of the AXI master is active, and it is transferring data.</p> <p>EQOS-AHB Configuration:<br/>When high, this bit indicates that the AHB master FSMs are in the non-idle state.</p> <p>Values:<br/>1'b0: AXI Master Write Channel or AHB Master Status not detected<br/>1'b1: AXI Master Write Channel or AHB Master Status detected</p> |

**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                | <p>LPIEI<br/>LPI Entry Interval</p> <p>Contains the number of system clock cycles, multiplied by 64, to wait for an activity in the DWC_ether_qos to enter into the AXI low power state. 0 indicates 64 clock cycles.</p> |

**30.5 Interface Description**

Table 30-3 EQOS Interface M0

| <b>Module Pin</b>    | <b>Direction</b> | <b>Pad Name</b>                                                                     | <b>IOMUX Setting</b>                  |
|----------------------|------------------|-------------------------------------------------------------------------------------|---------------------------------------|
| RMII/RGMII interface |                  |                                                                                     |                                       |
| mac_clk_m0           | I/O              | CIF_D12_M0/RGMII_CLK_M0/PDM_CLK0_M1/SPI1_CLK_M0/GPIO3_C0_d                          | GRF_GPIO3C_IOMUX_SEL_L[3:0]=3'b0010   |
| mac_txen_m0          | O                | CIF_D9_M0/RGMII_TXEN_M0/I2S0_SDO3_SD11_M1/SPI1_CS0n_M0/GPIO3_B5_d                   | GRF_GPIO3B_IOMUX_SEL_H[7:4]=3'b0010   |
| mac_txd3_m0          | O                | CIF_D6_M0/RGMII_TXD3_M0/I2S0_LRCK_RX_M1/UART4_RTSN_M0/GPIO3_B2_d                    | GRF_GPIO3B_IOMUX_SEL_L[11:8]=3'b0010  |
| mac_txd2_m0          | O                | CIF_D5_M0/RGMII_TXD2_M0/I2S0_SCLK_RX_M1/UART5_CTSN_M0/I2C5_SDA_M1/GPIO3_B1_d        | GRF_GPIO3B_IOMUX_SEL_L[7:4]=3'b0010   |
| mac_txd1_m0          | O                | CIF_D8_M0/RGMII_TXD1_M0/I2S0_SDO2_SD12_M1/SPI1_CS1n_M0/GPIO3_B4_d                   | GRF_GPIO3B_IOMUX_SEL_H[3:0]=3'b0010   |
| mac_txd0_m0          | O                | CIF_D7_M0/RGMII_TXD0_M0/I2S0_SDO1_SD13_M1/UART4_CTSN_M0/GPIO3_B3_d                  | GRF_GPIO3B_IOMUX_SEL_L[15:12]=3'b0010 |
| mac_txclk_m0         | O                | CIF_CLKOUT_M0/RGMII_TXCLK_M0/UART3_TX_M0/GPIO3_C6_d                                 | GRF_GPIO3C_IOMUX_SEL_H[11:8]=3'b0010  |
| mac_rxdv_m0          | I                | CIF_D13_M0/RGMII_RXDV_M0/PDM_SDI0_M1/GPIO3_C1_d                                     | GRF_GPIO3C_IOMUX_SEL_L[7:4]=3'b0010   |
| mac_rxer_m0          | I                | CIF_D14_M0/RGMII_RXER_M0/PDM_SDI1_M1/GPIO3_C2_d                                     | GRF_GPIO3C_IOMUX_SEL_L[11:8]=3'b0010  |
| mac_rxd3_m0          | I                | CIF_D4_M0/RGMII_RXD3_M0/I2S0_MCLK_M1/UART5_RTSN_M0/I2C5_SCL_M1/GPIO3_B0_d           | GRF_GPIO3B_IOMUX_SEL_L[3:0]=3'b0010   |
| mac_rxd2_m0          | I                | CIF_D3_M0/RGMII_RXD2_M0/I2S0_SDI0_M1/UART5_RX_M0/CAN_TXD_M1/PWM11_I_R_M0/GPIO3_A7_d | GRF_GPIO3A_IOMUX_SEL_H[15:12]=3'b0010 |
| mac_rxd1_m0          | I                | CIF_D11_M0/RGMII_RXD1_M0/PDM_SDI3_M1/SPI1_MISO_M0/GPIO3_B7_d                        | GRF_GPIO3B_IOMUX_SEL_H[15:12]=3'b0010 |
| mac_rxd0_m0          | I                | CIF_D10_M0/RGMII_RXD0_M0/PDM_SDI2_M1/SPI1_MOSI_M0/GPIO3_B6_d                        | GRF_GPIO3B_IOMUX_SEL_H[11:8]=3'b0010  |

|                      |     |                                                                                   |                                       |
|----------------------|-----|-----------------------------------------------------------------------------------|---------------------------------------|
| mac_rxclk_m0         | I   | CIF_HSYNC_M0/RGMII_RXCLK_M0/UART3_RX_M0/GPIO3_C7_d                                | GRF_GPIO3C_IOMUX_SEL_H[15:12]=3'b0010 |
| mac_crs_m0           | I   | CIF_D1_M0/RGMII_CRS_M0/I2S0_LRCK_TX_M1/UART4_RX_M0/I2C3_SDA_M0/PWM9_M0/GPIO3_A5_d | GRF_GPIO3A_IOMUX_SEL_H[7:4]=3'b0010   |
| mac_col_m0           | I   | CIF_D2_M0/RGMII_COL_M0/I2S0_SDO0_M1/UART5_TX_M0/CAN_RXD_M1/PWM10_M0/GPIO3_A6_d    | GRF_GPIO3A_IOMUX_SEL_H[11:8]=3'b0010  |
| Management interface |     |                                                                                   |                                       |
| mac_mdio_m0          | I/O | CIF_D15_M0/RGMII_MDIO_M0/PDM_CLK1_M1/GPIO3_C3_d                                   | GRF_GPIO3C_IOMUX_SEL_L[15:12]=3'b0010 |
| mac_mdc_m0           | O   | CIF_VSYNC_M0/RGMII_MDC_M0/UART3_RTSN_M0/GPIO3_C4_d                                | GRF_GPIO3C_IOMUX_SEL_H[3:0]=3'b0010   |

Table 30-4 EQOS Interface M1

| Module Pin           | Direction | Pad Name                                                            | IOMUX Setting                         |
|----------------------|-----------|---------------------------------------------------------------------|---------------------------------------|
| RMII/RGMII interface |           |                                                                     |                                       |
| mac_clk_m1           | I/O       | LCDC_D11/RGMII_CLK_M1/CIF_D7_M1 /GPIO2_B7_d                         | GRF_GPIO2B_IOMUX_SEL_H[15:12]=3'b0010 |
| mac_txen_m1          | O         | LCDC_D18/RGMII_TXEN_M1/CIF_D14_M1/GPIO2_C6_d                        | GRF_GPIO2C_IOMUX_SEL_H[11:8]=3'b0010  |
| mac_txd3_m1          | O         | LCDC_D0/RGMII_TXD3_M1/CIF_D0_M1/UART4_RTSN_M1/GPIO2_A4_d            | GRF_GPIO2A_IOMUX_SEL_H[3:0]=3'b0010   |
| mac_txd2_m1          | O         | LCDC_D21/RGMII_TXD2_M1/CIF_CLKOUT_M1/I2S1_SCLK_M2/GPIO2_D1_d        | GRF_GPIO2D_IOMUX_SEL_L[7:4]=3'b0010   |
| mac_txd1_m1          | O         | LCDC_D16/RGMII_TXD1_M1/CIF_D12_M1/GPIO2_C4_d                        | GRF_GPIO2C_IOMUX_SEL_H[3:0]=3'b0010   |
| mac_txd0_m1          | O         | LCDC_D15/RGMII_TXD0_M1/CIF_D11_M1/GPIO2_C3_d                        | GRF_GPIO2C_IOMUX_SEL_L[15:12]=3'b0010 |
| mac_txclk_m1         | O         | LCDC_D22/RGMII_TXCLK_M1/CIF_CLKIN_M1/I2S1_LRCK_M2/GPIO2_D2_d        | GRF_GPIO2D_IOMUX_SEL_L[11:8]=3'b0010  |
| mac_rxdv_m1          | I         | LCDC_D8/RGMII_RXDV_M1/CIF_D4_M1/GPIO2_B4_d                          | GRF_GPIO2B_IOMUX_SEL_H[3:0]=3'b0010   |
| mac_rxer_m1          | I         | LCDC_D12/RGMII_RXER_M1/CIF_D8_M1/GPIO2_C0_d                         | GRF_GPIO2C_IOMUX_SEL_L[3:0]=3'b0010   |
| mac_rxd3_m1          | I         | LCDC_D20/RGMII_RXD3_M1/CIF_VSYNC_M1/I2S1_SDO_M2/GPIO2_D0_d          | GRF_GPIO2D_IOMUX_SEL_L[3:0]=3'b0010   |
| mac_rxd2_m1          | I         | LCDC_D19/RGMII_RXD2_M1/CIF_D15_M1/I2S1_MCLK_M2/GPIO2_C7_d           | GRF_GPIO2C_IOMUX_SEL_H[15:12]=3'b0010 |
| mac_rxd1_m1          | I         | LCDC_D10/RGMII_RXD1_M1/CIF_D6_M1/GPIO2_B6_d                         | GRF_GPIO2A_IOMUX_SEL_H[11:8]=3'b0010  |
| mac_rxd0_m1          | I         | LCDC_D9/RGMII_RXD0_M1/CIF_D5_M1/GPIO2_B5_d                          | GRF_GPIO2A_IOMUX_SEL_H[7:4]=3'b0010   |
| mac_rxclk_m1         | I         | LCDC_D23/RGMII_RXCLK_M1/CIF_HSYNC_M1/I2S1_SDI_M2/GPIO2_D3_d         | GRF_GPIO2D_IOMUX_SEL_L[15:12]=3'b0010 |
| mac_crs_m1           | I         | LCDC_D1/RGMII_CRS_M1/CIF_D1_M1/UART4_CTSN_M1/I2C5_SCL_M0/GPIO2_A5_d | GRF_GPIO2A_IOMUX_SEL_H[7:4]=3'b0010   |
| mac_col_m1           | I         | LCDC_D2/RGMII_COL_M1/CIF_D2_M1/PWM5_M1/UART4_TX_M1/GPIO2_A6_d       | GRF_GPIO2A_IOMUX_SEL_H[11:8]=3'b0010  |
| Management interface |           |                                                                     |                                       |
| mac_mdio_m1          | I/O       | LCDC_D13/RGMII_MDIO_M1/CIF_D9_M1/GPIO2_C1_d                         | GRF_GPIO2C_IOMUX_SEL_L[7:4]=3'b0010   |
| mac_mdc_m1           | O         | LCDC_D14/RGMII_MDC_M1/CIF_D10_M1/GPIO2_C2_d                         | GRF_GPIO2C_IOMUX_SEL_L[11:8]=3'b0010  |

## 30.6 Application Note

### 30.6.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. 30-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.

### **30.6.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.

#### **30.6.3 Transmit Normal Descriptor (Read Format)**

Table 30-5 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 30-6 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 30-7 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 TDES3[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 this packet. |

| Bit   | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. 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 30-8 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.<br/> 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<br/>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.<br/>This field is valid only for the first descriptor.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 18    | TSE     | <p>TCP Segmentation Enable<br/>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<br/>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.<br/>This field is valid only for the first descriptor.</p> |
| 15    | TPL     | <p>Reserved or TCP Payload Length<br/>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<br/>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:<br/> <math display="block">\text{Ethernet Header Length} + \text{TCP /IP Header Length} - \text{Preamble Length} - \text{SFD Length} + \text{Ethernet Payload Length}</math> 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. |

### 30.6.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 30-9 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 30-10 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 30-11 TDES2 Normal Descriptor (Write-Back Format)

| Bit  | Name | Description |
|------|------|-------------|
| 31:0 | Rsvd | Reserved    |

Table 30-12 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    | CTX  | 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 | Rsvd | Reserved                                                                                                                                                                                                                                                          |
| 23    | DE   | Descriptor Error                                                                                                                                                                                                                                                  |

| Bit   | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      | <p>When this bit is set, it indicates that the descriptor content is incorrect. The DMA sets this bit during write-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 | Rsvd | 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.</p> <p>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           <ul style="list-style-type: none"> <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> </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></p> <p>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></p> <p>This bit indicates that the carrier sense signal from the PHY was not asserted during transmission.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9   | LC   | <p><b>Late Collision</b></p> <p>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></p> <p>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></p> <p>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></p> <p>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></p> <p>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. |

### 30.6.5 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 30-13 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 30-14 TDES1 Context Descriptor

| Bit  | Name | Description                                                                                                                                                                                                                                                                                                      |
|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | TTSU | 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 30-15 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 | Rsvd | 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                                                                                               |

| Bit | Name | Description                                                                                                                                                                                                                         |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | 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 30-16 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 | Rsvd   | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 25:24 | Rsvd   | 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-back while closing the context descriptor.<br>Descriptor Errors can be: <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> 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.<br>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. |
| 22:20 | Rsvd   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 19:18 | IVTIR  | 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.<br>The following list describes the values of these bits: <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></ul>                                                                                                                                                                                                                                                                                                                                                                                   |

| Bit  | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       | <ul style="list-style-type: none"> <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   | VLT   | <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>                                                                                                                                                                                                                                                                                                                        |

### 30.6.6 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".

### 30.6.7 Receive Normal Descriptors(Read Format)

Table 30-17 TDES0 Normal Descriptor(Read Format)

| Bit  | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | BUF1AP | <p>Header or Buffer 1 Address Pointer<br/>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> |

| Bit | Name | Description                                                                                                                                                                                         |
|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | 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. |

Table 30-18 TDES1 Normal Descriptor(Read Format)

| Bit  | Name               | Description                                                                                                                                     |
|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 30-19 TDES2 Normal Descriptor(Read Format)

| Bit  | Name               | Description                                                                                                                                     |
|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 30-20 TDES3 Normal Descriptor(Read 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    | 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 | Rsvd  | 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  | Rsvd  | Reserved                                                                                                                                                                                                                                                                                                                                                                                            |

### 30.6.8 Receive Normal Descriptors(Write-Back Format)

Table 30-21 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                                                                                                                                                                                             |

| Bit | Name | Description                                                                                    |
|-----|------|------------------------------------------------------------------------------------------------|
|     |      | This field contains the Outer VLAN tag of the received packet if the RS0V bit of RDES3 is set. |

Table 30-22 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.<br>The context descriptor is written in the next descriptor just after the last normal descriptor for a packet.                                                                 |
| 13    | PV   | PTP Version<br>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.<br>This bit is available only when you select the Timestamp feature. Otherwise, this bit is reserved.                                                                                                                                            |
| 12    | PFT  | PTP Packet Type<br>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.                                                                                                                                                                                                                             |
| 11:8  | PMT  | PTP Message Type<br>These bits are encoded to give the type of the message received:<br><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> </ul> |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | <ul style="list-style-type: none"> <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 | <p>IPV4 Header Present</p> <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</p> <p>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</p>                                                                                              |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | Enable Receive TCP/IP Checksum Check feature.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 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 30-23 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> <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].</p> <p>Note: This status is not available when Flexible RX Parser is enabled.</p>                    |
| 27    | L3FM   | <p>Layer 3 Filter Match<br/> 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>                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Bit   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | <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].</p> <p>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.</p> <p>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.</p> <p>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 DWC_EQOS_ERVFE is not enabled.</p> <p>If DWC_EQOS_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      | <p>Inner VLAN Tag Filter Status (ITS)</p> <p>This bit is valid only when DWC_EQOS_ERVFE is enabled.</p> <p>This bit is valid only for Double VLAN Tagged frames, when Double VLAN Processing is enabled.</p> <p>For more information, see the Filter Status topic.</p>                                                                                                                                                                                                                                                           |
| 13:11 | Rsvd     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10    | ARPNR    | <p>ARP Reply Not Generated</p> <p>When this bit is set, it indicates that the MAC did not generate the ARP Reply for received ARP Request packet.</p> <p>This bit is set when the MAC is busy transmitting ARP reply</p>                                                                                                                                                                                                                                                                                                         |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | <p>to earlier ARP request (only one ARP request is processed at a time).</p> <p>This bit is reserved when the Enable IPv4 ARP Offload option is not selected.</p>                                                                                                                                                                                                                                                                                                                                                                                 |
| 9:0 | HL   | <p>L3/L4 Header Length</p> <p>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).</p> <p>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.</p> <p>This field is valid when the Enable Split Header Feature option is selected.</p> |

Table 30-24 TDES3 Normal Descriptor(Write-Back Format)

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | OWN  | <p>Own Bit</p> <p>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:</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</p> <p>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.</p> <p>When CTXT and FD bits are used together, {CTXT, FD}</p> <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> <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  | FD   | <p>First Descriptor</p> <p>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.</p> <p>See the CTXT bit description for details of using the CTXT bit and FD bit together.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 28  | LD   | <p>Last Descriptor</p> <p>When this bit is set, it indicates that the buffers to which this descriptor is pointing are the last buffers of the packet.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 27  | RS2V | <p>Receive Status RDES2 Valid</p> <p>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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bit   | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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 (rxid!= 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: <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   | Error Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |      | <p>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</p> <p>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> |

### 30.6.9 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 30-25 TDES0 Context Descriptor

| Bit  | Name | Description                                                                                                                                                                                                                                                                    |
|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RSTL | <p>Receive Packet Timestamp Low</p> <p>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 30-26 TDES1 Context Descriptor

| Bit  | Name | Description                                                                                                                                                                      |
|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RTSH | <p>Receive Packet Timestamp High</p> <p>The DMA updates this field with most significant 32 bits of the timestamp captured for corresponding receive packet. When this field</p> |

| Bit | Name | Description                                                                                   |
|-----|------|-----------------------------------------------------------------------------------------------|
|     |      | and the RTSL field of RDES0 show all-ones value, the timestamp must be considered as corrupt. |

Table 30-27 TDES2 Context Descriptor

| Bit  | Name | Description |
|------|------|-------------|
| 31:0 | Rsvd | Reserved    |

Table 30-28 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   | <p>Descriptor Error<br/>See the CTXT bit description for details of using the DE bit along with CTXT bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 28:0 | Rsvd | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## 30.6.10 Programming Guide

### 30.6.10.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 <= DWC\_EQOS\_NUM\_DMA\_TX\_CH-1) and DMA\_CH(#i)\_RxDesc\_Ring\_Length (for i = 0; i <= DWC\_EQOS\_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 <= DWC\_EQOS\_NUM\_DMA\_TX\_CH-1), DMA\_CH(#i)\_RxDesc\_List\_Address (for i = 0; i <= DWC\_EQOS\_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 <= DWC\_EQOS\_NUM\_DMA\_TX\_CH-1) and DMA\_CH(#i)\_RxDesc\_Tail\_Pointer (for i = 0; i <= DWC\_EQOS\_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 <= DWC\_EQOS\_NUM\_DMA\_TX\_CH-1)
  - DMA\_CH(#i)\_TX\_Control (for i = 0; i <= DWC\_EQOS\_NUM\_DMA\_TX\_CH-1)
  - DMA\_CH(#i)\_RX\_Control (for i = 0; i <= DWC\_EQOS\_NUM\_DMA\_RX\_CH-1)
8. Enable the interrupts by programming the DMA\_CH(#i)\_Interrupt\_Enable (for i = 0; i <= DWC\_EQOS\_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 <= DWC\_EQOS\_NUM\_DMA\_RX\_CH-1) and ST (bit 0) of the DMA\_CH(#i)\_TX\_Control (for i = 0; i <= DWC\_EQOS\_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.

### **30.6.10.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.

### **30.6.10.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.

#### **30.6.10.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)

#### **30.6.10.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 <= DWC\_EQOS\_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.

#### **30.6.10.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.

#### **30.6.10.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.

#### **30.6.10.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.

#### **30.6.11 Clock Architecture**

In RMII mode, reference clock and TX/RX clock can be from CRU or external OSC as following figure. The mux selecting rmii\_speed is CRU\_GMAC\_CON0[1].



Fig. 30-11 RMII Clock Architecture When Clock Source From CRU



Fig. 30-12 RMII Clock Architecture When Clock Source From External OSC

In RGMII mode, clock architecture only supports that TX clock source is from CRU as following figure. In order to dynamically adjust the timing between TX/RX clocks with data, delayline is integrated in TX and RX clock path. Register GRF\_MAC\_CON0[3:0] can enable the delayline and GRF\_MAC\_CON1[15:0]/GRF\_MAC\_CON2[15:0] is used to determine the delay length. There are 200 delay elements in each delayline.



Fig. 30-13 RGMII Clock Architecture When Clock Source From CRU



Fig. 30-14 RGMII Clock Architecture When Clock Source From External OSC

## Chapter 31 GPIO

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

### 31.2 Block Diagram



Fig. 31-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.

### 31.3 Function Description

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

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

### 31.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 internal 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).

## 31.4 Register Description

This section describes the control/status registers of the design. Software should read and write these registers using 32-bits accesses. There are five GPIOs (GPIO0 in PD\_PMU, GPIO1(GPIO2)/GPIO3(GPIO4) in PD\_BUS), and each of them has same register group.

Therefore, five GPIOs' register groups have five different base addresses.

### 31.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)     |

| Name                | Offset | Size | Reset Value | Description                              |
|---------------------|--------|------|-------------|------------------------------------------|
| 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 BOTEDGE L  | 0x0030 | W    | 0x00000000  | Interrupt Both Edge Type Register (Low)  |
| GPIO INT BOTEDGE 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    | 0x01000C2B  | Version ID Register                      |

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

### 31.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                                                                                                                                                                                                                                             |
| 15:0  | RW   | 0x0000      | 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<br>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. |

#### GPIO SWPORT DR H

Address: Operational Base + offset (0x0004)

| 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_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)

| <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> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0       | RW          | 0x0000             | <p>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</p> <p>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.</p> |

**GPIO INT EN H**

Address: Operational Base + offset (0x0014)

| <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>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</p> <p>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.</p> |

**GPIO INT MASK L**

Address: Operational Base + offset (0x0018)

| <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>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</p> <p>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.</p> |

**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             | <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>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</p> <p>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.</p> |

**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             | <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_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</p> <p>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.</p> |

**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             | <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_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</p> <p>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.</p> |

**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             | <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>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)

| <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>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)

| <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>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)

| <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> |

| <b>Bit</b> | <b>Attr</b> | <b>Reset Value</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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)

| <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>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)

| <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>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)

| <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             | 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.<br>1'b0: Disable divider for debounce clock<br>1'b1: Enable divider for debounce clock<br>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 divide 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. |

**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             | 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             | 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.<br>1'b0: Disable divider for debounce clock<br>1'b1: Enable divider for debounce clock<br>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 divide 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. |

**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          | dbclk_div_con<br>$dbclk\_div = dbclk / (dbclk\_div\_con + 1)$ |

**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         | int_status<br>Interrupt status of I/O Port. |

**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         | int_rawstatus<br>Interrupt raw status of I/O Port (premasking bits). |

**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          | 0x01000c2b         | ver_id<br>Version ID. |

## 31.5 Interface Description

Table 31-1 GPIO Interface Description

| <b>Module Pin</b>      | <b>Direction</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>              |
|------------------------|------------------|-----------------|-----------------------------------|
| <b>GPIO0 Interface</b> |                  |                 |                                   |
| gpio0_port[3:0]        | I/O              | GPIO0_A[3:0]    | PMUGRF_GPIO0A_IOMUX_L[15:0]=16'h0 |
| gpio0_port[7:4]        | I/O              | GPIO0_A[7:4]    | PMUGRF_GPIO0A_IOMUX_H[15:0]=16'h0 |

| <b>Module Pin</b>      | <b>Direction</b> | <b>Pad Name</b> | <b>IOMUX Setting</b>              |
|------------------------|------------------|-----------------|-----------------------------------|
| gpio0_port[11:8]       | I/O              | GPIO0_B[3:0]    | PMUGRF_GPIO0B_IOMUX_L[15:0]=16'h0 |
| gpio0_port[15:12]      | I/O              | GPIO0_B[7:4]    | PMUGRF_GPIO0B_IOMUX_H[15:0]=16'h0 |
| gpio0_port[19:16]      | I/O              | GPIO0_C[3:0]    | PMUGRF_GPIO0C_IOMUX_L[15:0]=16'h0 |
| gpio0_port[23:20]      | I/O              | GPIO0_C[7:4]    | GRF_GPIO0C_IOMUX_H[15:0]=16'h0    |
| gpio0_port[27:24]      | I/O              | GPIO0_D[3:0]    | GRF_GPIO0D_IOMUX_L[15:0]=16'h0    |
| gpio0_port[31:28]      | I/O              | GPIO0_D[7:4]    | GRF_GPIO0D_IOMUX_H[15:0]=16'h0    |
| <b>GPIO1 Interface</b> |                  |                 |                                   |
| gpio1_port[3:0]        | I/O              | GPIO1_A[3:0]    | GRF_GPIO1A_IOMUX_L[15:0]=16'h0    |
| gpio1_port[7:4]        | I/O              | GPIO1_A[7:4]    | GRF_GPIO1A_IOMUX_H[15:0]=16'h0    |
| gpio1_port[11:8]       | I/O              | GPIO1_B[3:0]    | GRF_GPIO1B_IOMUX_L[15:0]=16'h0    |
| gpio1_port[15:12]      | I/O              | GPIO1_B[7:4]    | GRF_GPIO1B_IOMUX_H[15:0]=16'h0    |
| gpio1_port[19:16]      | I/O              | GPIO1_C[3:0]    | GRF_GPIO1C_IOMUX_L[15:0]=16'h0    |
| gpio1_port[23:20]      | I/O              | GPIO1_C[7:4]    | GRF_GPIO1C_IOMUX_H[15:0]=16'h0    |
| gpio1_port[27:24]      | I/O              | GPIO1_D[3:0]    | GRF_GPIO1D_IOMUX_L[15:0]=16'h0    |
| gpio1_port[31:28]      | I/O              | GPIO1_D[7:4]    | GRF_GPIO1D_IOMUX_H[15:0]=16'h0    |
| <b>GPIO2 Interface</b> |                  |                 |                                   |
| gpio2_port[3:0]        | I/O              | GPIO2_A[3:0]    | GRF_GPIO2A_IOMUX_L[15:0]=16'h0    |
| gpio2_port[7:4]        | I/O              | GPIO2_A[7:4]    | GRF_GPIO2A_IOMUX_H[15:0]=16'h0    |
| gpio2_port[11:8]       | I/O              | GPIO2_B[3:0]    | GRF_GPIO2B_IOMUX_L[15:0]=16'h0    |
| gpio2_port[15:12]      | I/O              | GPIO2_B[7:4]    | GRF_GPIO2B_IOMUX_H[15:0]=16'h0    |
| gpio2_port[19:16]      | I/O              | GPIO2_C[3:0]    | GRF_GPIO2C_IOMUX_L[15:0]=16'h0    |
| gpio2_port[23:20]      | I/O              | GPIO2_C[7:4]    | GRF_GPIO2C_IOMUX_H[15:0]=16'h0    |
| gpio2_port[27:24]      | I/O              | GPIO2_D[3:0]    | GRF_GPIO2D_IOMUX_L[15:0]=16'h0    |
| gpio2_port[31:28]      | I/O              | GPIO2_D[7:4]    | GRF_GPIO2D_IOMUX_H[15:0]=16'h0    |
| <b>GPIO3 Interface</b> |                  |                 |                                   |
| gpio3_port[3:0]        | I/O              | GPIO3_A[3:0]    | GRF_GPIO3A_IOMUX_L[15:0]=16'h0    |
| gpio3_port[7:4]        | I/O              | GPIO3_A[7:4]    | GRF_GPIO3A_IOMUX_H[15:0]=16'h0    |
| gpio3_port[11:8]       | I/O              | GPIO3_B[3:0]    | GRF_GPIO3B_IOMUX_L[15:0]=16'h0    |
| gpio3_port[15:12]      | I/O              | GPIO3_B[7:4]    | GRF_GPIO3B_IOMUX_H[15:0]=16'h0    |
| gpio3_port[19:16]      | I/O              | GPIO3_C[3:0]    | GRF_GPIO3C_IOMUX_L[15:0]=16'h0    |
| gpio3_port[23:20]      | I/O              | GPIO3_C[7:4]    | GRF_GPIO3C_IOMUX_H[15:0]=16'h0    |
| gpio3_port[27:24]      | I/O              | GPIO3_D[3:0]    | GRF_GPIO3D_IOMUX_L[15:0]=16'h0    |
| gpio3_port[31:28]      | I/O              | GPIO3_D[7:4]    | GRF_GPIO3D_IOMUX_H[15:0]=16'h0    |
| <b>GPIO4 Interface</b> |                  |                 |                                   |
| gpio4_port[1:0]        | I/O              | GPIO4_A[1:0]    | GRF_GPIO4A_IOMUX_L[7:0]=8'h0      |

Notes: Unused Module Pin is tied to zero! I=input, O=output, I/O=input/output, bidirectional

## 31.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 in order to prevent spurious glitches on the interrupt output signal to the interrupt controller.